CCID (protocol) explained

CCID (chip card interface device) protocol is a USB protocol that allows a smartcard to be connected to a computer via a card reader using a standard USB interface, without the need for each manufacturer of smartcards to provide its own reader or protocol.[1] This allows the smartcard to be used as a security token for authentication and data encryption, such as that used in BitLocker. Chip card interface devices come in a variety of forms. The smallest CCID form is a standard USB dongle and may contain a SIM card or Secure Digital card inside the USB dongle. Another popular interface is a USB smart card reader keyboard, which in addition to being a standard USB keyboard, has an built-in slot for accepting a smartcard. However, not all CCID compliant devices accept removable smartcards, for example, select Yubikey hardware authentication devices support CCID, where they play the role of both the card reader and the smartcard itself.

Hardware implementation

According to the CCID specification by the USB standards work group, a CCID exchanges information through a host computer over USB by using a CCID message that consists of a 10-byte header followed by message-specific data.[2] The standard defines fourteen commands that the host computer can use to send data and status and control information in messages. Every command requires at least one response message from the CCID.[3]

Software driver

CCID driver support has been natively supported by Microsoft beginning with Windows 2000.[4] Apple has included some form of native CCID support since Mac OS X, with support evolving alongside Common Access Card and Personal Identity Verification specifications set by the US Federal Government.[5] [6] Apple's has included native CCID support on iOS since 16.0 and iPadOS since 16.1.[7] [8] On Linux and other Unixes, CCID and CT-API devices are usually accessed with user-space drivers, for which no special kernel adaptation is required.[9]

List of CCID providers

References

  1. 7748636. Portable identity card reader system for physical and logical access. US. patent. 2010-07-06. Jul 18, 2007. Nov 16, 2004. Finn, David. Dpd Patent Trust Ltd..
  2. Web site: Specification for Integrated Circuit(s) Cards Interface Devices Revision 1.1. usb.org. USB Implementers Forum, Inc.. January 26, 2015. 25.
  3. USB Complete: Everything you need to develop custom USB peripherals, Jan Axelson, 2005, page 189
  4. Web site: Microsoft Class Drivers for USB CCID Smart Cards. Microsoft Developer Network. Microsoft. January 26, 2015.
  5. Web site: Jamf Pro Overview—macOS Smart card Functionality . . 2020-11-26 . https://web.archive.org/web/20201126223538/https://resources.jamf.com/documents/technical-papers/macos-smart-card-overview.pdf . 2020-11-26 . 7 . PDF . 2018 . live.
  6. Web site: Intro to smart card integration . live . https://web.archive.org/web/20201126224617/https://support.apple.com/guide/deployment-reference-macos/intro-to-smart-card-integration-apd1fa5245b2/1/web/1 . 2020-11-26 . 2020-11-26 . Apple Support . . en.
  7. Web site: Use a smart card on iPhone and iPad . 2024-01-23 . Apple Support . en.
  8. Web site: Supported smart card functions on iPhone and iPad . 2024-01-23 . Apple Support . en.
  9. Web site: CCID free software driver. June 22, 2018.