On Thu, Nov 13, 2008 at 14:40, Kay Sievers <kay.sievers@xxxxxxxx> wrote: > On Thu, Nov 13, 2008 at 13:55, Karel Zak <kzak@xxxxxxxxxx> wrote: >> On Tue, Nov 11, 2008 at 04:40:43PM +0100, Kay Sievers wrote: >>> > I've made an image of a newly-formatted partition and posted it at >>> > http://launchpadlibrarian.net/19129151/sdb1.img.bz2 and the Ubuntu bug >> >> Thanks. >> >>> > (Thought you can >>> > force-mount it with a -t vfat.) >>> > >>> > ----- Forwarded message from Matthew Garrett <mjg59@xxxxxxxxxxxxx> ----- >>> > >>> > From: Matthew Garrett <mjg59@xxxxxxxxxxxxx> >>> > To: Matt Behrens <matt@xxxxxxxx> >>> > Subject: Re: LifeDrive and T|X not seen by hal >>> > >>> > Ok. The following things appear to be causing the failure: >>> > >>> > 1) The FAT signature in bytes 510 and 511 isn't present. This causes the >>> > code to bail. >> >> Right. >> >> # hexdump -s 0x1fe -n 5 -C /dev/loop0 >> 000001fe 00 00 00 00 00 |.....| >> >> I'm not sure is the msdos signature (0x55 0xaa) at 510 and 511 is really >> mandatory. For example libblkid does not require this signature: >> >> # blkid /dev/loop0 >> /dev/loop0: LABEL="LIFEDRIVE" UUID="1234-5678" TYPE="vfat" >> >> when the standard FAT magic string is present. It works for years. > > Sure, and it happily detects for years old left-over signatures as FAT > which are not FAT anymore. :) And the kernel sometimes even mounts > them. and likely corrupts the image by using it as FAT. Blkid is just > not exposed to the crap out there. It is not used for any widely > deployed auto-mount setup. Udev and HAL get all the stuff, and that's > why there are more checks added to volume_id. Maybe they can be made > less strict, but we need to be very very careful, Auto-mounting is a > really dangerous business, and you risk data loss by mounting stuff as > FAT, which isn't FAT anymore - which we have seem several times when > we started with HAL auto-mounting and the /dev/disk/ links. > >>> > 2) The FAT32 signature in the fsinfo block isn't present. This causes >>> > the code to bail. >> >> Right. Frankly, I have no clue why volume_id is checking also the >> FSInfo block. >> >> IMHO the FSInfo block is optional (if fsinfo_sector is zero) and >> should be _ignored_ when the signature does not match. See >> >> http://mail.opensolaris.org/pipermail/ufs-discuss/2007-February/000813.html >> >> The linux kernel also does not require valid FSInfo signature, the >> wrong signature is only reported: >> >> FAT: Invalid FSINFO signature: 0x00000000, 0x00000000 (sector = 1) >> >> and the FSInfo block is ignored at all. > > It's mandatory by the Microsoft FAT spec. But seems, they don't > require it in their implementation, but that's easy if you need to > support like 4 filesystems. :) We can maybe allow them all to be \0's. > Maybe! > >> Fortunately, we check many other things (sector counts, number of FAT >> tabs, media check, cluster size, ...) in FAT super block. >> >>> Hmm, we can not really remove these checks, as there are many volumes >>> out there which we would detect as FAT, which are not FAT. Most of >>> these additional checks only got added after a several reports of >> >>> mis-detection. Even partition tables may get detected as FAT, if we >>> remove these checks, without adding new ones. >> >> The Palm uses the FAT32 magic string, so mis-detection based on bytes >> 510 and 511 shouldn't happen. >> >>> Maybe we should always probe for all known filesystems, and not stop >>> at the first match. And if we only find FAT, and nothing else, we >> >> Maybe for some cases. The mount(8) supports list of FS types. I can >> imagine that the library returns more results. It could be >> useful for example for CD-ROMs where is more filesystems. >> >>> might be able to say it's FAT even with less strict checks. Adding >>> Karel to Cc, because we plan to merge volume_id and blkid some day. >> >> Right now I'm working on regression tests ... so strange FS images >> are welcomed ;-) >> >> The patch below is for optimistic people :-) >> >> ./vol_id /dev/loop0 >> ID_FS_USAGE=filesystem >> ID_FS_TYPE=vfat >> ID_FS_VERSION=FAT32 >> ID_FS_UUID=1234-5678 >> ID_FS_UUID_ENC=1234-5678 >> ID_FS_LABEL=LIFEDRIVE >> ID_FS_LABEL_ENC=LIFEDRIVE >> ID_FS_LABEL_SAFE=LIFEDRIVE > >> From 6147da52751e437e7f6aaa6f6f32253b35eed174 Mon Sep 17 00:00:00 2001 >> From: Karel Zak <kzak@xxxxxxxxxx> >> Date: Thu, 13 Nov 2008 13:07:48 +0100 >> Subject: [PATCH] volume_id: less paranoid FAT32 detection >> >> This patch >> >> * makes the msdos signature (0x55 0xaa) at 510 and 511 optional when >> the standard FAT magic string is present. > > Sounds fine. > >> * removes FSInfo block detection. The block is optional and should be >> ignored when the block signature is not valid. The block is not >> required by Linux kernel. > > Sure, but that's no reason. The kernel allows you to mount a mkswap'd > image too, as FAT or as swap, just as you like. :) Autodetection can > not pass everything the kernel accepts. > > Maybe we can change the check to accept all bytes in the signature > beeing \0. This check exists for the reason that we had too many > wrongly detected FAT volumes, which are a formatted differently, and > even the kernel sometimes accepts, the no-loger-FAT volume and > corrupts the new filesystem. Just like it does after mkswap. I think a reasonable solution is to always probe for all filesystems we know, and don't return a single result when we find several non-compatible filesystems. We would need to group some filesytems to allow things like udf and iso9660, hfs(+) and iso9660, hfs and hfs+ to co-exist at the same time for the same volume. But most other combinations should by default not return a probing result, and just print an error with the conflicting signatures we have found. Users would be required to remove the wrong signature, or reformat the volume if they want auto-mounting to work. We can optionally limit this behavior to devices which are not read-only, like most optical media, and where mis-detection does not do any harm. That way we should be able to prevent common mis-detections and prevent damage by auto-mounting, in the common scenario of re-formatted volumes with a different filesystem, but left-over old signatures. As said earlier, the kernel allows sometimes to mount the filesystem in the "old" format and writes to it, and may just corrupt the "new" filesystem by doing that. If we find a raid signature, we must still stop here and just return it, to possibly set it up as a raid member. It's common to see the filesystem on top of raid while probing the raw disk. We also need to add size-checks, or an option, to skip probing for all filesystems on floppy disks and other really slow media, because they are too slow to seek, and read like 64-128 kBytes, just to check for other filesystems. Floppies are the main reason, we probe for FAT very early in the sequence, it just takes too long to probe them. After that, I think it is reasonable safe to remove some additional checks from FAT, because we can be sure that it's not any other known filesystem we know. I would still not return FAT32 if the fssig does not match and is not all zero. Every time I see this check in volume_id's FAT probing failing, it was all zero. What do you think? Kay -- To unsubscribe from this list: send the line "unsubscribe linux-hotplug" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html