wok-current rev 17156
syslinux: fix rockridge
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Mon Sep 15 18:45:08 2014 +0200 (2014-09-15) |
parents | 9c4b8d987746 |
children | 63ca4e6217bd |
files | dev86/stuff/com2exe syslinux/stuff/extra/iso9660.u |
line diff
1.1 --- a/dev86/stuff/com2exe Sun Sep 14 09:47:19 2014 +0200 1.2 +++ b/dev86/stuff/com2exe Mon Sep 15 18:45:08 2014 +0200 1.3 @@ -4,7 +4,7 @@ 1.4 S=$((32+$(stat -c %s $1))) 1.5 P=$((($S+511)/512)) 1.6 E=$((4096-(32*$P))) 1.7 -for i in 0x5A4D $(($S%512)) $P 0 2 $E $E $((${2:-0}-16)) -2 0 256 -16 28 0 0 0 1.8 +for i in 0x5A4D $(($S%512)) $P 0 2 $E -1 $((${2:-0}-16)) -2 0 256 -16 28 0x6C53 0x5469 0x7A61 1.9 do printf '\\\\x%02X\\\\x%02X' $(($i&255)) $((($i>>8)&255)) | xargs echo -en 1.10 done 1.11 cat $1
2.1 --- a/syslinux/stuff/extra/iso9660.u Sun Sep 14 09:47:19 2014 +0200 2.2 +++ b/syslinux/stuff/extra/iso9660.u Mon Sep 15 18:45:08 2014 +0200 2.3 @@ -1,24 +1,41 @@ 2.4 --- core/fs/iso9660/iso9660.c 2.5 +++ core/fs/iso9660/iso9660.c 2.6 -@@ -132,6 +132,28 @@ 2.7 +@@ -89,6 +89,24 @@ 2.8 + return true; 2.9 + } 2.10 + 2.11 ++#define __ROCKRIDGE 2.12 ++#ifdef __ROCKRIDGE 2.13 ++static size_t rockname(const struct iso_dir_entry *de, char **name) 2.14 ++{ 2.15 ++ size_t len, delen, n = (de->name_len + 34) & -2; 2.16 ++ char *data = (char *) de; 2.17 ++ 2.18 ++ for (delen = 0; n + 2 < de->length; n += len) { 2.19 ++ len = data[n + 2]; 2.20 ++ if (* (short *) (data + n) == 0x4D4E) { /* NM */ 2.21 ++ *name = data + n + 5; 2.22 ++ delen = len - 5; 2.23 ++ } 2.24 ++ } 2.25 ++ return delen; 2.26 ++} 2.27 ++#endif 2.28 ++ 2.29 + /* 2.30 + * Find a entry in the specified dir with name _dname_. 2.31 + */ 2.32 +@@ -132,6 +150,20 @@ 2.33 2.34 de_name_len = de->name_len; 2.35 de_name = de->name; 2.36 -+#define __ROCKRIDGE 2.37 +#ifdef __ROCKRIDGE 2.38 + { 2.39 -+ char *name = NULL, *end; 2.40 -+ int n = (offset - de_len + de->name_len + 34) & -2; 2.41 -+ int len = data[n + 2]; 2.42 -+ do { 2.43 -+ if (* (short *) (data + n) == 0x4D4E) { // NM 2.44 -+ name = data + n + 5; 2.45 -+ end = data + n + len; 2.46 -+ } 2.47 -+ n += len; 2.48 -+ } while (n + 2 < offset); 2.49 -+ if (name) { 2.50 -+ *end = 0; 2.51 ++ char *name; 2.52 ++ size_t len = rockname(de, &name); 2.53 ++ 2.54 ++ if (len) { 2.55 ++ name[len] = 0; 2.56 + if (!strcmp(name, dname)) { 2.57 + dprintf("Found rockridge.\n"); 2.58 + return de; 2.59 @@ -29,28 +46,29 @@ 2.60 if (iso_compare_name(de_name, de_name_len, dname)) { 2.61 dprintf("Found.\n"); 2.62 return de; 2.63 -@@ -211,6 +233,24 @@ 2.64 - data = NULL; 2.65 - continue; 2.66 - } 2.67 -+#ifdef __ROCKRIDGE2 2.68 +@@ -217,11 +249,22 @@ 2.69 + dirent->d_ino = 0; /* Inode number is invalid to ISO fs */ 2.70 + dirent->d_off = file->offset; 2.71 + dirent->d_type = get_inode_mode(de->flags); 2.72 +- dirent->d_reclen = offsetof(struct dirent, d_name) + 1 + 2.73 +- iso_convert_name(dirent->d_name, de->name, de->name_len); 2.74 ++ iso_convert_name(dirent->d_name, de->name, de->name_len); 2.75 + 2.76 ++#ifdef __ROCKRIDGE 2.77 + { 2.78 -+ char *name = NULL; 2.79 -+ int n = (offset + de->name_len + 34) & -2; 2.80 -+ int len = data[n + 2], delen; 2.81 -+ do { 2.82 -+ if (* (short *) (data + n) == 0x4D4E) { // NM 2.83 -+ name = data + n + 5; 2.84 -+ delen = len - 5; 2.85 -+ } 2.86 -+ n += len; 2.87 -+ } while (n + 2 < offset + de->length); 2.88 -+ if (name) { 2.89 -+ de->name_len = delen; 2.90 -+ strcpy(de->name, name, delen); 2.91 ++ char *name; 2.92 ++ size_t len = rockname(de, &name); 2.93 ++ 2.94 ++ if (len) { 2.95 ++ strcpy(dirent->d_name, name); 2.96 ++ dirent->d_name[len] = 0; 2.97 + } 2.98 + } 2.99 +#endif 2.100 - break; 2.101 - } 2.102 - 2.103 ++ dirent->d_reclen = offsetof(struct dirent, d_name) + 1 + strlen(dirent->d_name); 2.104 + file->offset += de->length; /* Update for next reading */ 2.105 +- 2.106 ++ 2.107 + return 0; 2.108 + } 2.109 +