FatFSUSB ======== When the onboard flash memory is used as a ``FatFS`` filesystem, the ``FatFSUSB`` can be used to allow exporting it to a PC as a standard memory stick. The PC can then access, add, and remove files as if the Pico was a USB memory stick, and upon ejection the Pico can access any new files just as if it made them itself. (Note, if you are using LittleFS then you need to use ``SingleFileDrive`` to export a single file, not this class, because the PC does not understand the LittleFS disk format.) Callbacks, Interrupt Safety, and File Operations ------------------------------------------------ The ``FatFSUSB`` library allows your application to get a callback when a PC attempts to mount or unmount the Pico as a FAT drive. When the drive is being used by the Pico (i.e. any ``File`` is open for read or write, the ``FatFS`` is not ``end()`` -ed and still mounted, etc.) the host may not access it. Conversely, while the host PC is connected to the drive no ``FatFS`` access by the Pico is allowed. Your ``driveReady`` callback will be called when the PC attempts to mount the drive. If you have any files open, then this callback can report back that the drive is not yet ready. When you complete file processing, the PC can re-attempt to mount the drive and your callback can return ``true`` . The ``onPlug`` callback will generally ``FatFS.end()`` and set a global flag letting your application know not to touch the filesystem until the flag is cleared by the ``onUnplug`` callback (which will also do a ``FatFS.begin()`` call). Failing to close all files **and** ``FatFS.end()`` before granting the PC access to flash memory will result in corruption. FAT does not allow multiple writers to access the same drive. Even mounting and only reading files from the PC may cause hidden writes (things like access time, etc.) which would also cause corruption. See the included ``Listfiles-USB`` sketch for an example of working with these limitations.