uicc.txt 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. Introduction
  2. ============
  3. This feature requires supporting Mass Storage and Integrated Circuit Card
  4. interfaces exposed by the UICC (Universal Integrated Circuit Card) device.
  5. The MSM acts as a USB host and UICC acts as a peripheral. The UICC device
  6. that is used here is also referred to as Mega-SIM. This feature will be
  7. supported on MSM8x26.
  8. Hardware description
  9. ====================
  10. The USB3503 HSIC (High Speed Inter Chip) hub's down stream port is modified
  11. to support Inter-Chip USB for connecting the UICC device. The USB3503 is
  12. connected to MSM via HSIC interface. The UICC device operates in Full Speed
  13. mode.
  14. The UICC device will support CCID (Integrated Circuit Card interface Device)
  15. specification. This interface supports 1 Bulk In, 1 Bulk Out and 1 Interrupt
  16. endpoint. The Interrupt endpoint is used by the device to send asynchronous
  17. notifications like card insertion/removal and hardware error events.
  18. The Bulk endpoints are used for the data communication.
  19. The UICC device will support the Mass Storage Bulk Only 1.0 specification.
  20. It supports SCSI Transparent subclass '06', corresponding to support of the
  21. SCSI Primary Command set. It implements SCSI Peripheral Device Type '00'
  22. (TYPE_DISK) corresponding to a direct access SCSI block device.
  23. Software description
  24. ====================
  25. The MSM HSIC controller driver(drivers/usb/host/ehci-msm-hsic.c) takes care
  26. of HSIC PHY and link management. The USB3503 HSIC hub is managed by the SMSC
  27. hub driver(drivers/misc/smsc_hubc.c). Both these drivers are well tested on
  28. APQ8074 dragon board and are re-used to support this feature.
  29. The mass storage interface is managed by the standard Linux USB storage driver.
  30. This driver interfaces with SCSI and block layers to export the disk to
  31. user space.
  32. A new USB driver is implemented to manage the CCID interface. This driver is
  33. referred to as USB CCID driver in this document. This driver is implemented
  34. as a pass-through module and provides the character device interface to
  35. user space. The CCID specification is implemented in the user space.
  36. The CCID command and responses are exchanged over the Bulk endpoints. The
  37. user space application uses write() and read() calls to send commands and
  38. receive responses.
  39. The CCID class specific requests are sent over the control endpoint. As
  40. control requests have a specific format, ioctls are implemented.
  41. The UICC device sends asynchronous notifications over the interrupt endpoint.
  42. The card insertion/removal and hardware error events are sent to user space
  43. via an ioctl().
  44. Design Goals:
  45. ============
  46. 1. Re-use the existing services available in user space. This is achieved
  47. by implementing the kernel USB CCID driver as a pass-through module.
  48. 2. Support runtime card insertion/removal.
  49. 3. Support runtime power management.
  50. 4. Support Multiple card configuration. More than 1 IC can be connected to
  51. the USB UICC device.
  52. Power Management
  53. ================
  54. The USB core uses the runtime PM framework to auto suspend the USB devices that
  55. are not in use. The Auto-suspend is forbidden for all devices except hub class
  56. devices. The USB CCID driver enables auto-suspend for the UICC device.
  57. An USB device can be suspended only when all of its interfaces are suspended.
  58. The USB storage interface device acts as a parent device to the underlying
  59. SCSI host, target and block devices. Runtime PM must be enabled for the
  60. SCSI device to allow USB storage interface suspend. The SCSI device runtime
  61. suspend and auto-suspend timeout will be configured from user space via sysfs
  62. files.
  63. The HSIC platform device and USB3503 HUB device will be runtime suspended
  64. only after the USB UICC device is suspended.
  65. SMP/multi-core
  66. ==============
  67. The USB CCID driver does not allow multiple clients to open the device file
  68. concurrently. -EBUSY will be returned if open() is attempted when the
  69. file is already opened.
  70. The write() and read() methods are implemented synchronously. If another
  71. write() is called when a previous write() is in progress, -EBUSY is
  72. returned. The same is applicable to read().
  73. Mutexes will be used to prevent concurrent open(), read() and write() access.
  74. Interface
  75. =========
  76. A character device file (/dev/ccid_bridge) will be exposed by the USB CCID
  77. driver. open(), read(), write(), ioctl() and close() methods are implemented.
  78. This device node is accessible only to the root by default. User space init
  79. or udev scripts should change the permissions of this device file if it needs
  80. to be accessed by non-root applications.
  81. open(): The open() is blocked until the UICC device is detected and the CCID
  82. interface probe is completed. Returns the appropriate error code in case of
  83. failure.
  84. read(): An URB is submitted on the Bulk In endpoint. The read() is blocked
  85. until the URB is completed and the data is copied to the user space buffer
  86. upon success. An appropriate error code is returned in case of failure.
  87. -ENODEV must be treated as a serious error and no further I/O will be
  88. attempted.
  89. write(): An URB is submitted on the Bulk Out endpoint. The write() is blocked
  90. until the URB is completed. An appropriate error code is returned in case of
  91. failure. -ENODEV must be treated as a serious error and no further I/O will be
  92. attempted.
  93. ioctl(): The ioctl() method is required for facilitating Control transfers and
  94. Interrupt transfers.
  95. USB_CCID_GET_CLASS_DESC: This read-only ioctl returns the smart card class
  96. descriptor as described in the 5.1 section of USB smart card class spec.
  97. USB_CCID_ABORT: This write-only ioctl sends A ABORT class specific request on
  98. control endpoint. The class request details are mentioned in section 5.3.1.
  99. USB_CCID_GET_CLOCK_FREQUENCIES: This read and write ioctl returns the clock
  100. frequencies supported by the CCID device. A GET_CLOCK_FREQUENCIES class request
  101. is sent on the control endpoint. The class request details are mentioned in
  102. section 5.3.2.
  103. USB_CCID_GET_DATA_RATES: This read and write ioctl returns the data rates
  104. supported by the CCID device. A GET_DATA_RATES class request is sent on the
  105. control endpoint. The class request details are mentioned in section 5.3.3.
  106. USB_CCID_GET_EVENT: This read-only ioctl returns the asynchronous event sent
  107. by the UICC device. The ioctl() is blocked until such event is received from
  108. the UICC device. This ioctl() returns -ENOENT error code when the device
  109. does not have an interrupt endpoint and does not support remote wakeup
  110. capability.
  111. close(): Cancels any ongoing I/O before it returns.
  112. Config options
  113. ==============
  114. Turn on USB_EHCI_MSM_HSIC, USB_HSIC_SMSC_HUB and USB_CCID_BRIDGE configs to
  115. enable this feature.
  116. References
  117. ==========
  118. Specification for Integrated Circuit(s) Cards Interface Devices
  119. Smart Cards; UICC-Terminal interface; Physical and logical characteristics