xenial (1) usb_modeswitch.1.gz

Provided by: usb-modeswitch_2.2.5+repack0-1ubuntu1_amd64 bug

NAME

       usb_modeswitch - control the mode of 'multi-state' USB devices

SYNOPSIS

       usb_modeswitch [-heWQDIvpVPmM23rwKdHSOBGTNALnsRiuagft] [-c filename]

DESCRIPTION

       Several  new  USB  devices  have  their  proprietary  Windows drivers onboard, most of them WWAN and WLAN
       dongles. When plugged in for the first time, they act like a  flash  storage  and  start  installing  the
       Windows  driver from there. If the driver is already installed, it makes the storage device disappear and
       a new device, mainly composite with modem ports, shows up.

       On Linux, in most cases the drivers are available as kernel modules, such  as  "usbserial"  or  "option".
       However,  the device initially binds to "usb-storage" by default. usb_modeswitch can then send a provided
       bulk message (most likely a mass storage command) to the device; this message has  to  be  determined  by
       analyzing the actions of the Windows driver.

       In  some cases, USB control commands are used for switching. These cases are handled by custom functions,
       and no bulk message needs to be provided.

       Usually, the program is distributed with a set of configurations for many known devices, which  allows  a
       fully  automatic  handling of a device upon insertion, made possible by combining usb_modeswitch with the
       wrapper script usb_modeswitch_dispatcher which is launched by the udev daemon.

       Note that usb_modeswitch itself has no specific Linux dependencies.

OPTIONS

       This program follows the usual GNU command line syntax,  with  long  options  starting  with  two  dashes
       ('--').  A summary of options is included below.

       -h --help Show summary of options.

       -e --version
                 Print version information and exit

       -v --default-vendor NUM
                 Vendor  ID  to  look  for (mandatory), usually given as hex number (example: 0x12d1).  Each USB
                 device is identified by a number officialy assigned to the vendor by the USB association and  a
                 number for the respective model (product ID) chosen by the vendor

       -p --default-product NUM
                 Product ID to look for (mandatory)

       -V --target-vendor NUM
                 Target  vendor  ID.  When  given  will  be  searched for and detected initially for information
                 purposes. If success checking (option -s) is active, providing target IDs  (vendor/product)  or
                 target class is recommended

       -j --find-mbim
                 Return configuration number with MBIM interface and exit.

       -P --target-product NUM
                 Target product ID

       -b --bus-num NUM

       -g --device-num NUM
                 If bus and device number are provided, the handling of a specific device on a specific USB port
                 is guaranteed, in contrast to using only the USB ID. This is important if  there  are  multiple
                 similar devices on a system

       -C --target-class NUM
                 Target  Device  Class  according  to  the  USB  specification. Some devices keep their original
                 vendor/product ID after successful switching. To prevent them from  being  treated  again,  the
                 device  class  can  be  checked.   For  unswitched  devices it is always 8 (storage class), for
                 switched modems it is often 0xff (vendor specific). In composite modes, the class of the  first
                 interface is watched

       -m --message-endpoint NUM
                 A specific endpoint to use for data transfers. Only for testing purposes; usually endpoints are
                 determined from the device attributes

       -M --message-content STRING
                 A bulk message to send as a switching command. Provided as a hexadecimal string

       -2, -3  --message-content2, --message-content3 STRING
                 Additional bulk messages to send as switching commands. Provided as hexadecimal strings.   When
                 used  with  mass  storage  commands, setting --need-response is strongly advised to comply with
                 specifications and to avoid likely errors

       -w --release-delay NUM
                 After issuing all bulk messages, wait for NUM  milliseconds  before  releasing  the  interface.
                 Required for some modems on older systems (especially after an EJECT message)

       -n --need-response
                 Read  the  response  (command status wrapper) to a mass storage command transfer.  Some devices
                 have trouble switching if the response is not read; most  are  disappearing  right  away.  When
                 sending  multiple  mass  storage  commands  with  -2  and  -3, this may need to be set to avoid
                 transfer errors

       -r --response-endpoint NUM
                 Try to read the response to a storage command from there if  option  -n  is  active.  Only  for
                 testing purposes; usually endpoints are determined from the device attributes

       -K --std-eject
                 Apply  the  standard  SCSI  sequence  of  "Allow  Medium  Removal" and "Eject". Implies -n. One
                 'Message' can be added with -M that will be transmitted after the eject sequence

       -d --detach-only
                 Just detach  the  current  driver.  This  is  sufficient  for  some  early  devices  to  switch
                 successfully.  Otherwise  this  feature  can  be  used  as  a 'scalpel' for special cases, like
                 separating the driver from individual interfaces

       -H --huawei-mode
                 Send a special control message used by older Huawei devices

       -J --huawei-new-mode
                 Send a specific bulk message used by all newer Huawei devices

       -S --sierra-mode
                 Send a special control message used by Sierra devices

       -G --gct-mode
                 Send a special control message used by GCT chipsets

       -T --kobil-mode
                 Send a special control message used by Kobil devices

       -N --sequans-mode
                 Send a special control message used by Sequans chipset

       -A --mobileaction-mode
                 Send a special control message used by the MobileAction device

       -B --qisda-mode
                 Send a special control message used by Qisda devices

       -E --quanta-mode
                 Send a special control message used by Quanta devices

       -F --pantech-mode NUM
                 Send a special control message used by Pantech devices.  Value NUM  will  be  used  in  control
                 message as 'wValue'

       -Z --blackberry-mode
                 Send a special control message used by some newer Blackberry devices

       -O --sony-mode
                 Apply a special sequence used by Sony Ericsson devices. Implies option --check-success

       -L --cisco-mode
                 Send a sequence of bulk messages used by Cisco devices

       -R --reset-usb
                 Send  a  USB  reset  command  to the device. Can be combined with any switching method or stand
                 alone. It is always done as the last step of all device interactions.  Few devices need  it  to
                 complete the switching; apart from that it may be useful during testing

       -c --config-file FILENAME
                 Use  a  specific  config  file.  If  any  ID  or  switching  options  are given as command line
                 parameters, this option is ignored.  In that case all mandatory parameters have to be  provided
                 on the command line

       -f --long-config STRING
                 Provide device details in config file syntax as a multiline string on the command line

       -t --stdinput
                 Read  the  device  details  in  config  file syntax from standard input, e.g. redirected from a
                 command pipe (multiline text)

       -Q --quiet
                 Don't show progress or error messages

       -W --verbose
                 Print all settings before running and show libusb debug messages

       -D --sysmode
                 Changes the behaviour of the program slightly. A success message including the effective target
                 device  ID  is  put  out  and  a syslog notice is issued. Mainly for integration with a wrapper
                 script

       -s --check-success NUM
                 After switching, keep checking for the result up to max. NUM seconds. If target IDs  or  target
                 class were provided, their appearance indicates certain success. Otherwise the disconnection of
                 the original device is rated as likely proof

       -I --no-inquire
                 do not obtain SCSI attributes from  device  (default  is  on).  For  proper  identification  of
                 differing devices the attributes of the storage part provide valuable information.  This is not
                 needed for devices that are known and supported

       -i --interface NUM
                 Select initial USB interface (default: 0). Only for testing purposes

       -u --configuration NUM
                 Select USB configuration (applied after any other possible switching actions)

       -a --altsetting NUM
                 Select alternative USB interface setting (applied after switching). Mainly for testing

AUTHOR

       This manual page was originally written by Didier  Raboud  (didier@raboud.com)  for  the  Debian  system.
       Additions  made  by  Josua  Dietze. Permission is granted to copy, distribute and/or modify this document
       under the terms of the GNU General Public License, Version 2 or any later version published by  the  Free
       Software Foundation.

       The    complete    text    of    the   current   GNU   General   Public   License   can   be   found   in
       http://www.gnu.org/licenses/gpl.txt

                                                                                               USB_MODESWITCH(1)