Am Samstag, den 30.08.2008, 22:15 +0200 schrieb Felix Zielcke:
> Here's a patch which implements UUID support for the iso9660 filesystem,
> by using the creation date in the `superblock'.
> The specs say that it's allowed to contain only zeros but I think this
> shouldn't be a big problem.


I just got another idea, make GCC warnings more visible.
It did work fine with grub-emu and the CD I tested with.

I have removed now the offset, grub_sprintf doestn't support %hhu
format, and as far as I understand it's stored like a normal `signed
int' just with 8bit size i.e. `signed char' but not a ASCII digit.
Without it, it should be still unique enough.

So better try it out with this attached one :)

-- 
Felix Zielcke
2008-08-30  Felix Zielcke  <[EMAIL PROTECTED]>

	* fs/iso9660.c (grub_iso9660_date): New structure.
	(grub_iso9660_primary_voldesc): Add `grub_iso9660_date' member.
	(grub_iso9660_uuid): New function.

Index: fs/iso9660.c
===================================================================
--- fs/iso9660.c	(Revision 1836)
+++ fs/iso9660.c	(Arbeitskopie)
@@ -67,6 +67,18 @@ struct grub_iso9660_dir
   grub_uint8_t namelen;
 } __attribute__ ((packed));
 
+struct grub_iso9660_date
+{
+  grub_uint8_t year[4];
+  grub_uint8_t month[2];
+  grub_uint8_t day[2];
+  grub_uint8_t hour[2];
+  grub_uint8_t minute[2];
+  grub_uint8_t second[2];
+  grub_uint8_t hundredth[2];
+  grub_uint8_t offset;
+}__attribute__ ((packed));
+
 /* The primary volume descriptor.  Only little endian is used.  */
 struct grub_iso9660_primary_voldesc
 {
@@ -81,6 +93,8 @@ struct grub_iso9660_primary_voldesc
   grub_uint32_t path_table;
   grub_uint8_t unused5[12];
   struct grub_iso9660_dir rootdir;
+  grub_uint8_t unused6[641];
+  struct grub_iso9660_date created;
 } __attribute__ ((packed));
 
 /* A single entry in the path table.  */
@@ -812,8 +826,44 @@ grub_iso9660_label (grub_device_t device
   return grub_errno;
 }
 
-
 
+static grub_err_t
+grub_iso9660_uuid (grub_device_t device, char **uuid)
+{
+  struct grub_iso9660_data *data;
+  grub_disk_t disk = device->disk;
+
+#ifndef GRUB_UTIL
+  grub_dl_ref (my_mod);
+#endif
+
+  data = grub_iso9660_mount (disk);
+  if (data)
+    {
+      *uuid = grub_malloc (sizeof ("xxxxxxxxxxxxxxxx") + sizeof ('\0'));
+      grub_sprintf (*uuid, "%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c",
+		    data->voldesc.created.year[0], data->voldesc.created.year[1], 
+		    data->voldesc.created.year[2], data->voldesc.created.year[3],
+		    data->voldesc.created.month[0], data->voldesc.created.month[1],
+		    data->voldesc.created.day[0], data->voldesc.created.day[1],
+		    data->voldesc.created.hour[0], data->voldesc.created.hour[1],
+		    data->voldesc.created.minute[0], data->voldesc.created.minute[1],
+		    data->voldesc.created.second[0], data->voldesc.created.second[1],
+		    data->voldesc.created.hundredth[0], data->voldesc.created.hundredth[1])
+    }
+  else
+    *uuid = NULL;
+
+#ifndef GRUB_UTIL
+  grub_dl_unref (my_mod);
+#endif
+
+  grub_free (data);
+
+  return grub_errno;
+}
+
+
 static struct grub_fs grub_iso9660_fs =
   {
     .name = "iso9660",
@@ -822,6 +872,7 @@ static struct grub_fs grub_iso9660_fs =
     .read = grub_iso9660_read,
     .close = grub_iso9660_close,
     .label = grub_iso9660_label,
+    .uuid = grub_iso9660_uuid,
     .next = 0
   };
 
_______________________________________________
Grub-devel mailing list
Grub-devel@gnu.org
http://lists.gnu.org/mailman/listinfo/grub-devel

Reply via email to