nuttx-apps/system/usbmsc
anchao 220653f21c Squashed commit of the following:
Author: anchao <anchao@pinecone.net>

     apps/, most main() function: Correct CONFIG_BUILD_LOADABLE usage
     Loadable apps/: Correct loadable symbol table generate
     apps/system/ubloxmodem:  Fix build break
     apps/examples/ostest: start restart/waitpid/user test from main loop
     apps/nshlib:  Expand reboot and poweroff commands to include a second, optional mode argument

    Author: Gregory Nutt <gnutt@nuttx.org>

     An attempt to fix build issues.  Does not work.
     apps/examples/ostest:  Fix some inappropriate renaming of static functions introduced with recent patches.
     apps/builtin/exec_builtin.c:  Fix a error introduced by recent comments.  Found in build testing.

    Author: anchao <anchao@pinecone.net>

     apps/builtin/exec_builtin.c:  Try posix_spawn if builtin apps do not have have an entry point.
     apps/Application.mk: introduce MODULE config to simplify tristate(m)
     apps/nsh:  Change the nuttx shell module type to tristate
     apps:  Add loadable application support
     script/mksymtab:  Generate symbol table name by default
     apps/builtin:  Allow loadable applications can register with apps/builtin.
2018-08-23 11:06:15 -06:00
..
.gitignore
Kconfig apps/system/usbmsc: Added Kconfig options to configure write protection for each LUN 2018-01-14 17:11:32 -06:00
Make.defs make the full tree use wildcards make.defs 2016-06-02 16:21:21 +02:00
Makefile Squashed commit of the following: 2018-08-23 11:06:15 -06:00
README.txt Squashed commit of the following: 2018-08-23 11:06:15 -06:00
usbmsc_main.c Squashed commit of the following: 2018-08-23 11:06:15 -06:00
usbmsc.h Replace calls to OS internal cdcacm_*, usbmsc_*, and composite_* with boardctl() calls 2016-03-25 13:26:00 -06:00

system/usbmsc
^^^^^^^^^^^^^^^

  This add-on registers a block device driver, then exports the block
  the device using the USB storage class driver.  In order to use this
  add-on, your board-specific logic must provide the function:

    void board_usbmsc_initialize(void);

  This function will be called by the system/usbmsc indirectly via the
  boarctl BOARDIOC_USBDEV_CONTROL command in order to do the actual
  registration of the block device drivers.  For examples of the
  implementation of board_usbmsc_initialize() see
  configs/mcu123-lpc124x/src/up_usbmsc.c or
  configs/stm3210e-eval/src/usbmsc.c

  Configuration options:

  CONFIG_NSH_BUILTIN_APPS
    This add-on can be built as two NSH "built-in" commands if this option
    is selected: 'msconn' will connect the USB mass storage device; 'msdis'
    will disconnect the USB storage device.
  CONFIG_LIB_BOARDCTL
    Enables the boardctl() interfaces.
  CONFIG_BOARDCTL_USBDEVCTRL
    Enables the BOARDIOC_USBDEV_CONTROL boardctl() command.
  CONFIG_SYSTEM_USBMSC_NLUNS
    Defines the number of logical units (LUNs) exported by the USB storage
    driver.  Each LUN corresponds to one exported block driver (or partition
    of a block driver).  May be 1, 2, or 3.  Default is 1.
  CONFIG_SYSTEM_USBMSC_DEVMINOR1
    The minor device number of the block driver for the first LUN. For
    example, N in /dev/mmcsdN.  Used for registering the block driver. Default
    is zero.
  CONFIG_SYSTEM_USBMSC_DEVPATH1
    The full path to the registered block driver.  Default is "/dev/mmcsd0"
  CONFIG_SYSTEM_USBMSC_DEVMINOR2 and CONFIG_SYSTEM_USBMSC_DEVPATH2
    Similar parameters that would have to be provided if CONFIG_SYSTEM_USBMSC_NLUNS
    is 2 or 3.  No defaults.
  CONFIG_SYSTEM_USBMSC_DEVMINOR3 and CONFIG_SYSTEM_USBMSC_DEVPATH3
    Similar parameters that would have to be provided if CONFIG_SYSTEM_USBMSC_NLUNS
    is 3.  No defaults.
  CONFIG_SYSTEM_USBMSC_DEBUGMM
    Enables some debug tests to check for memory usage and memory leaks.

  If CONFIG_USBDEV_TRACE is enabled (or CONFIG_DEBUG_FEATURES and CONFIG_DEBUG_USB), then
  the code will also manage the USB trace output.  The amount of trace output
  can be controlled using:

  CONFIG_SYSTEM_USBMSC_TRACEINIT
    Show initialization events
  CONFIG_SYSTEM_USBMSC_TRACECLASS
    Show class driver events
  CONFIG_SYSTEM_USBMSC_TRACETRANSFERS
    Show data transfer events
  CONFIG_SYSTEM_USBMSC_TRACECONTROLLER
    Show controller events
  CONFIG_SYSTEM_USBMSC_TRACEINTERRUPTS
    Show interrupt-related events.

  Error results are always shown in the trace output

  NOTE 1: When built as an NSH add-on command (CONFIG_NSH_BUILTIN_APPS=y),
  Caution should be used to assure that the SD drive (or other storage device) is
  not in use when the USB storage device is configured.  Specifically, the SD
  driver should be unmounted like:

  nsh> mount -t vfat /dev/mmcsd0 /mnt/sdcard # Card is mounted in NSH
  ...
  nsh> umount /mnd/sdcard                    # Unmount before connecting USB!!!
  nsh> msconn                                # Connect the USB storage device
  ...
  nsh> msdis                                 # Disconnect USB storate device
  nsh> mount -t vfat /dev/mmcsd0 /mnt/sdcard # Restore the mount

  Failure to do this could result in corruption of the SD card format.

  NOTE 2: This add-on used internal USB device driver interfaces.  As such,
  it relies on internal OS interfaces that are not normally available to a
  user-space program.  As a result, this add-on cannot be used if a
  NuttX is built as a protected, supervisor kernel (CONFIG_BUILD_PROTECTED
  or CONFIG_BUILD_LOADABLE).