system/corennnnn
Revisión | 1964942af0f194287bbdd5dc7ce97399b19f97b7 (tree) |
---|---|
Tiempo | 2008-11-20 09:20:44 |
Autor | Jay Freeman (saurik) <saurik@saur...> |
Commiter | Jay Freeman (saurik) |
Removed special consideration of EBUSY from mountd's auto-mounter.
If the SD card is partitioned and one attempts to use a partition of the SD card for another purpose (maybe even booting off of it), then mmcblk0 is considered "busy" when mountd tries to mount it (as specified by /etc/mountd.conf). Normally, it would then attempt to mount partitions of the device, but as "busy" is specially treated in the code it does not consider this to be an error condition.
The argment for this check is that "the device is likely already mounted", but that is obviously not something that should be assumed (and is not true in this example situation). Even if the device were already mounted, from the auto-mounter's viewpoint this should be considered an error anyway, as it failed to mount it as it was told. I therefore believe this check to not only be causing the above problem but also to be incorrect. This change removes it.
For more information, see this thread:
http://groups.google.com/group/android-porting/browse_thread/thread/a67cbe36603d429a
@@ -254,9 +254,6 @@ static int DoMountDevice(const char* device, const char* mountPoint) | ||
254 | 254 | |
255 | 255 | if (result == 0) { |
256 | 256 | NotifyMediaState(mountPoint, MEDIA_MOUNTED, (flags & MS_RDONLY) != 0); |
257 | - } else if (errno == EBUSY) { | |
258 | - // ignore EBUSY, since it usually means the device is already mounted | |
259 | - result = 0; | |
260 | 257 | } else { |
261 | 258 | #if CREATE_MOUNT_POINTS |
262 | 259 | rmdir(mountPoint); |