On Thu, Feb 04, 2016 at 06:47:06PM -0800, Marc MERLIN wrote: > On Thu, Feb 04, 2016 at 09:49:22AM +0100, Oliver Neukum wrote: > > On Wed, 2016-02-03 at 22:20 -0800, Marc MERLIN wrote: > > > > > But the main point remains that default mount options and default cp > > > work at horrible speed. I'm happy to try stuff to get around that > > > (nosync might be one, but having my stick write after I unmounted it, > > > makes me very nervous), so I'd love a solution where cp succeeds when > > > > It should. Have you tried to time a manual sync after writing? > > Mmmh, this time it worked as expected: > legolas:~# mount -o async /dev/sdd1 /mnt/mnt > legolas:~# time cp /var/local/space/vid/282MB /mnt/mnt; time umount /mnt/mnt; time sync > > real 0m0.598s > user 0m0.004s > sys 0m0.572s > > real 0m11.454s > user 0m0.000s > sys 0m0.256s > > real 0m0.117s > user 0m0.004s > sys 0m0.028s > > This goes back to 23MB/s (size/time), which is proper speed. > I also verified that this time the LED wasn't flashing after unmount. Great, so all is good now? > > Still, it's a more appropriate value, indicating that the actual > > transfer speed is reasonably close to what it should be. > > Correct. There seems to be a problem between sync and the underlying > usb-storage driver? > Maybe the windows driver takes many packets at a time, and returns sync > for a bunch of them while linux syncs them one by one, which ends up > being 50 times slower. That's up to the filesystem layer, what it wants to do, not the usb-storage driver. > > > If I had to guess, sync causes cp(1) to be very conservative and wait > > > for a sync after each 4KB block while windows probably blasts all the > > > data with fewer sync calls in between? > > > (wild guess at this point) > > > > Probably something like that. It doesn't actually change the behavior > > of the cp program; it changes the behavior of the kernel's filesystem > > layer. The end effect is the same, though. > > Right. Since running in async mode, especially with usb automounting, is > not safe, it would be good if usb-storage or whichever underlying driver > could do the same batching of blocks and sync them 100 or 1000 at a > time? usb-storage is just a tiny scsi driver, no real "logic" is in it, it's up to the filesystem above it to tell it what to do with the blocks it has. So it's up to the distro's settings of the vfat filesystem rules for ejectable hardware as to if it wants to sync more aggressively or not. So you get to go poke your favorite distro about this, it's not something the kernel can do much, if anything, about. :) > > > > But the main point remains that default mount options and default cp > > > work at horrible speed. > > > > That's a new main point. Your original main point was that write > > transfers under Linux were horribly slow. You now know this was due to > > the sync option, not any fault in the USB driver stack. > > The default mount options are a question for another mailing list; they > > have nothing at all to do with USB. > > You're correct. > Let's forget about async for now since it's not very safe for the > average user and windows gets async like speed in close enough to sync > mode. > Could the usb system aggregate requests and ack them by block? > (yes, I guess that means lying to cp and acking packets that haven't > been written yet, but I think everyone expects that if they pull a USB > stick in the middle of a copy, they'll lose data, so if we ack some data > that really hasn't made it to flash and won't for another second or so, > this likely would not cause problems to most (hopefully all?) users. > > Either way, sync mode is so excruciatingly slow that few people must be > using it for any reasonable data. Some distros default to this as they value data integrity over _perceived_ speed. I know openSUSE used to do this, but people did complain, I don't know if they changed it back or not. So again, it's not something the kernel can do anything about. thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html