SCR
Smart Card Reader Controller Core

Implements an interface and controller for communicating between smart cards and host systems using a variety of standard system interfaces.

The SCR supports the ISO/IEC 7816-3:2006 and EMV2000 4.2 specifications, which define the electrical signals and transmission protocols for smart cards (also known as integrated circuit cards). It acts as a communication controller, passing data to and from the host system and the smart card. It is fully-featured, and can activate and deactivate cards, perform cold/warm resets, handle ATR response reception, and execute other essential functions.

The SCR consists of the core smart card reader logic with a wrapper for the desired system interface. (AMBA APB and Wishbone interfaces are available; support for other bus interfaces is optional.)

The core is fully synchronous for easier testing and is designed for efficient ASIC or FPGA implementation. For an Altera Cyclone, for example, it requires just 925 LEs, 54 I/Os, and operates at 102 MHz.

Applications
Smart cards embed a computer chip in a credit-card sized plastic card, and are gaining global popularity for a variety of applications, including:

- personal identification
- satellite TV security
- mobile phone personalization
- health care records storage
- credit/debit functions

Block Diagram

Features
- Supports the ISO/IEC 7816-3:2006 and EMV2000 4.2 specifications
- Performs functions needed for complete smart card sessions, including:
  - Card activation and deactivation
  - Cold/warm reset
  - Answer to Reset (ATR) response reception
  - Data transfers to and from the card
- Extensive interrupt support system
- Adjustable clock rate and bit (baud) rate
- Configurable automatic byte repetition
- Handles commonly used communication protocols:
  - T=0 for asynchronous half-duplex character transmission, and
  - T=1 for asynchronous half-duplex block transmission
- Automatic convention detection
- Automatic voltage class selection
- Adjustable FIFOs for receive and transmit buffers (up to 32k characters) with threshold
- Configurable timing functions:
  - Smart card activation time
  - Guard time
  - Timeout timers
- Supports synchronous and any other non-ISO 7816 and non-EMV'96 cards
- Standard system interface wrapper architecture for easy integration with host systems
- Fully-synchronous design suitable for scan-based testing
- Available as an EDIF netlist optimized for a specific FPGA device (synthesizable HDL source code also available)
Functional Description
The SCR manages the interactions between an inserted smart card and the host system. It handles all timing issues, and safely transfers data from and to the card.

As shown in the block diagram, the core consists of a main SCR core block which performs according to the 7816 specification, and a wrapper that interfaces the SCR functions to a host system with APB.

SCR Top Level Entity
The wrapper that connects the SCR core to the AMBA APB. It converts the APB signals and makes them useful to the core.

Smart Card Reader Core
Contains five blocks that implement the SCR, and communicates with the host system through the APB wrapper.

Configuration Registers
Store values that provide control over all SCR functions.

Controller with UART
The main functional block, controlling the received and transmitted characters and performing card activation and deactivation, and cold and warm reset.

Includes a UART (Universal Asynchronous Receiver Transmitter) that converts the data from parallel to serial for transmitting from the SCR to a Smart Card and from serial to parallel for transmitting from a Smart Card to the SCR. The UART also performs the guard time, parity checking, and character repeating functions.

Receive FIFO
Stores the data received from the smart card until it is read out by the host system.

Transmit FIFO
Stores the data to be transmitted to the smart card.

Clock Generator
Generates the Smart Card Clock and the Baud Clock Impulse signals, used in timing the SCR.

Implementation Results
SCR reference designs have been evaluated in a variety of technologies. The following are sample results for the APB version, optimized for area and using a 2 x 8 byte FIFO.

<table>
<thead>
<tr>
<th>Supported Family</th>
<th>LEs</th>
<th>Memory</th>
<th>I/Os</th>
<th>Performance (fmax, MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cyclone EP1C6-7</td>
<td>765</td>
<td>2 M4Ks</td>
<td>54</td>
<td>140</td>
</tr>
<tr>
<td>Cyclone-II EP2C8-8</td>
<td>744</td>
<td>2 M4Ks</td>
<td>54</td>
<td>122</td>
</tr>
<tr>
<td>Stratix EP1S10-7</td>
<td>765</td>
<td>2 M512s</td>
<td>54</td>
<td>131</td>
</tr>
<tr>
<td>Stratix-II EP2S15-4</td>
<td>692</td>
<td>2 M512s</td>
<td>54</td>
<td>203</td>
</tr>
</tbody>
</table>

Support
The core as delivered is warranted against defects for ninety days from purchase. Thirty days of phone and email technical support are included, starting with the first interaction. Additional maintenance and support options are available.

Verification
The core has been verified through extensive simulation and rigorous code coverage measurements.

Deliverables
The Altera version of this core includes everything required for successful implementation:

- Post-synthesis EDIF netlist
- Sophisticated, self-checking HDL Testbench including everything necessary to test the core
- Sample driver in C code
- Scripts for simulation
- Comprehensive user documentation, including detailed specifications and design integration guidelines