AN2646 Application Note: Smartcard Interface With The STM8S Microcontroller
AN2646 Application Note: Smartcard Interface With The STM8S Microcontroller
AN2646 Application Note: Smartcard Interface With The STM8S Microcontroller
Application note
Introduction
This document describes a firmware and hardware smartcard interface solution based on
the STM8 UART1 peripheral. The main purpose of this firmware and hardware package is to
provide resources that facilitate the development of an application using the UART1
peripheral in smartcard mode.
The firmware interface consists of library source files developed so as to support the
ISO 7816-3/4 specification. An application example is also provided.
This document and its associated firmware are available for download from the
STMicroelectronics website: www.st.com.
Contents
2/43
AN2646 - Application note Contents
8 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
9 Revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
3/43
Smartcard interface description AN2646 - Application note
1.1 Introduction
The smartcard interface is developed using the UART1 smartcard mode. For the description
of the UART1 registers, please refer to the STM8S/STM8A reference manual (RM0009).
The UART1 smartcard mode supports asynchronous protocol smartcards as defined in the
ISO 7816-3 (Class A) standard, please refer to the ISO 7816-3 specification for more
details.
With the smartcard mode enabled, the UART1 must be configured as:
● Eight data bits plus parity
● 0.5 or 1.5 stop bits
A 5-bit prescaler and the smartcard clock generator provide the clock to the smartcard.
GPIO pins in conjunction with software are used to provide the rest of the functions required
to interface to the smartcard.
The inverse signalling convention as defined in ISO 7816-3, inverted data and MSB first, is
not handled in the software.
There are three types of card that operate at different voltages:
● 5V (ISO7816-3 Class A)
● 3V (ISO7816-3 Class B)
● 1.8V (ISO7816-3 Class C)
1.3 Protocol
The ISO 7816-3 standard defines the bit times for the asynchronous protocol in terms of
time units called ETUs (elementary time units), that are related to the clock frequency input
4/43
AN2646 - Application note Smartcard interface description
to the card. The length of an ETU is a bit time. The UART1 transmitter output and receiver
input are internally connected through the Rx_SW line. For the transmission of data from the
STM8S20x to the smartcard, the UART1 must be set up in smartcard mode.
5/43
Smartcard reader hardware connection AN2646 - Application note
To interface to the smartcard, the ST8024 device was used. The ST8024 is a complete low-
cost, analog interface for asynchronous 3 V and 5 V smartcards. It is placed between the
smartcard and the STM8S20x with few external components to perform all supply protection
and control functions.
The M74HC4052 multiplexer/demultiplexer is configured by software to allow the
UART1_TX to the Smartcard_IO
6/43
AN2646 - Application note Smartcard reader hardware connection
7/43
ISO 7816 – protocol overview AN2646 - Application note
3.1 Introduction
"ISO 7816: Identification cards -- Integrated circuit(s) cards with contacts" provides the basis
to transition the relatively simple identification card from a token that can be compromised
through forgery, theft, or loss into a tamper-resistant and "intelligent" integrated circuit card
(ICC), more popularly known as a smartcard. ISO 7816 includes at least six approved parts
and has several additional parts under review:
● Part 1: Physical characteristics
● Part 2: Dimensions and location of the contacts
● Part 3: Electrical interface and transmission protocols
● Part 3: Amendment 2-Revision of protocol type selection
● Part 4: Organization, security and commands for interchange
● Part 5: Registration of application providers
8/43
AN2646 - Application note ISO 7816 – protocol overview
C1 VCC = 5 V or 3.3 V
C2 Reset
C3 Clock
C4 RFU
C5 GND
C6 VPP
C7 I/O
C8 RFU
9/43
ISO 7816-3 – electronic signal and transmission protocol AN2646 - Application note
ISO 7816-3 begins to delve into the specification of the "intelligent" aspects of the
smartcard. This standard describes the relationship between the smartcard and the reader
as one of "slave" (the smartcard) and "master" (the reader). Communications are
established by the reader signaling to the smartcard through the contacts noted previously
and are continued by the smartcard responding accordingly.
Communication between the card and reader proceed according to various state transitions
illustrated in Figure 4.
The communication channel is single-threaded; once the reader sends a command to the
smartcard, it blocks until a response is received.
10/43
AN2646 - Application note ISO 7816-3 – electronic signal and transmission protocol
11/43
ISO 7816-3 – electronic signal and transmission protocol AN2646 - Application note
12/43
AN2646 - Application note ISO 7816-3 – electronic signal and transmission protocol
Values
FI 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
Internal clk
F 372 558 774 1116 1488 1860 RFU RFU 512 768 1024 1536 2048 RFU RFU
Freq
- 5 6 8 12 16 20 - - 5 7.5 10 15 20 - -
max
13/43
ISO 7816-3 – electronic signal and transmission protocol AN2646 - Application note
Values
DI 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
D RFU 1 2 4 8 16 RFU RFU RFU RFU 1/2 1/4 1/8 1/16 1/32 RFU
14/43
AN2646 - Application note ISO 7816-3 – electronic signal and transmission protocol
II 00 01 10 11
I 25 50 100 RFU
15/43
ISO 7816-3 – electronic signal and transmission protocol AN2646 - Application note
16/43
AN2646 - Application note ISO 7816-3 – electronic signal and transmission protocol
The total length of the ATR sequence is limited to 33 bytes and must adhere to the following
format:
17/43
ISO 7816-4 – smartcard commands AN2646 - Application note
The previous chapter discussed the answer-to-reset (ATR) mechanism, which establishes a
basic communication channel between the smartcard and the reader. This channel is a half-
duplex physical channel. This chapter investigates the use of more complex protocols on top
of this physical channel.
A link-level communication protocol resides directly on top of the physical channel, providing
error-free communication between the reader and the smartcard. Once this link-level
protocol is established, application-level protocols can be defined. ISO 7816-4 defines two
such application-level protocols:
● File system API providing a set of functions to manipulate files (for example read, write,
select, etc.).
● Security service API allowing the smartcard and the reader to mutually authenticate
themselves and also to encrypt data to be exchanged between the card and the reader.
ISO 7816-4 defines a protocol message structure to support the application protocol APIs.
This message structure consists of application protocol data units (APDUs) which are
exchanged between the reader application and the smartcard application by the link-level
protocol. This chapter will provide an overview of the file access and security APIs.
5.1 T0 protocol
The T0 protocol is a byte-oriented protocol where a character is transmitted across the
channel between the reader and the card. In addition, error handling is performed on each
byte by looking at the parity bit. If the actual parity bit does not correspond to the parity of
the transmitted data, then an error must have occurred. In the T0 protocol, the receiving side
signals that it requires the byte to be retransmitted in the case of detecting a parity error.
This is done by holding the I/O line low (normally the I/O line is set high preceding the
transfer of a byte). When the transmitting side detects this, it resends the byte that was not
received correctly.
The reader and the smartcard exchange data structures known as transmission protocol
data units (TPDUs). It consists of two distinct structures:
● a command that is sent from the reader to the card
● a response that is sent from the card to the reader
The command header includes the following five fields each of one byte in length:
● CLA: class designation of the command set to establish a collection of instructions
● INS: specifies a specific instruction from within the set of instructions
● P1: used to specify the addressing used by the [CLA, INS] instruction
● P2: also used to specify the addressing used by the [CLA, INS] instruction
● P3: specifies the number of data bytes transferred to or from the card as part of the
[CLA, INS] instruction execution.
Each value of CLA defines an application-specific set of instructions. Table 8. below lists
values for some sets of instructions.
18/43
AN2646 - Application note ISO 7816-4 – smartcard commands
The INS byte is used to identify a specific instruction within a class of instructions identified
by the value of CLA.Table 9. lists the instructions in the ISO 7816-4 standard used to access
file system and security functions.
The parameters P1 and P2 are defined at the link level but are actually dependent on the
specific instruction (application level). They provide control or addressing parameters for the
various application-specific instructions. For example, in the Select File instruction, P1 is
used to indicate how the file will be referred to (by identifier, name, path etc.) and P2 offers
further refinement as to which file is to be selected. P3 defines the number of bytes to be
transmitted during the execution of the INS specified instruction. The convention used to
indicate movement of data is card-centric that is, outgoing refers to data moving from the
card to the reader and incoming refers to data moving from the reader to the card.
For each command TDPU sent from the reader, a response TPDU is sent by the card. The
response includes three mandatory fields and one optional field (all one byte in length):
● ACK: indicates that the card has received the [CLA, INS] command
● NULL: used for flow control on the I/O channel by the card. It signals (to the reader) that
the card is still processing the command and so the reader must wait before sending
another command
● SW1: status response of the current command
● SW2: (optional) also conveys a status response to the reader
19/43
ISO 7816-4 – smartcard commands AN2646 - Application note
The ACK byte is a repeat of the INS byte from the command TPDU. If the response does not
reach the reader within a specified time, the reader may initiate an RST sequence to restart
the protocol between the reader and the card. This can be prevented if the reader receives
at least one NULL byte from the card. SW1 informs the reader of the result of the requested
instruction. The values allowed for SW1 are defined as part of the application protocol.
Some instructions require the card to send data to the reader. In this case SW2 is returned
to the reader, triggering the reader to execute a GetResponse command. The card will then
return the data bytes generated by the execution of the previous command.
The APDU structure defined by ISO 7816-4 is very similar to the TPDU structure used in the
T0 protocol. In fact, when an APDU is transported by the T0 protocol, the elements of the
APDU directly overlay the elements of the TPDU.
20/43
AN2646 - Application note ISO 7816-4 – smartcard commands
The command APDU consists of a header and a body (this can be seen in the diagram
above). The header includes CLA, INS, P1 and P2 fields. As in the T0 protocol, CLA and
INS specify an application class and instruction. P1 and P2 are used to qualify specific
instructions and are given specific definitions by each [CLA, INS] instruction. The body of
the APDU can vary in size and is used to transmit data to the card's APDU processor as
part of a command or to convey a response from the card to the reader. The Lc field
specifies the number of bytes to be transmitted to the card as part of the instruction, that is,
the length of the data field. The data field contains information that must be sent to the card
to allow its APDU processor to execute the command specified in the APDU. The Le field
specifies the number of bytes that will be returned to the reader in the response APDU.
The body of the APDU can take on four different forms:
● Case 1: No data is transferred to or from the card, so the APDU only contains the
header.
● Case 2: No data is transferred to the card, but data is returned from the card. The body
of the APDU only contains a non-null Le field.
● Case 3: Data is transferred to the card, but none is returned from it. The body of the
APDU includes the Lc and data fields.
● Case 4: Data is transferred to the card and is also returned from the card as a result of
the command. The body of the APDU includes the Lc, data and Le fields.
The response APDU has a much simpler structure than that of the command APDU. It
consists of a body and a trailer. The body is either null or it includes a data field - depending
on the specific command. The length of the data field is determined by the Le field in the
corresponding command APDU. The trailer consists of up to two fields of status information
called SW1 and SW2. These fields return a status code in which one byte is used to specify
21/43
ISO 7816-4 – smartcard commands AN2646 - Application note
an error category and the other is used to specify a command-specific status or error
indication.
22/43
AN2646 - Application note ISO 7816-4 – smartcard commands
variable-length record file contains records that may vary in length. As a result, variable-
length record files have a higher overhead in read/write access times as well as a higher
administrative overhead required by the file system.
A cyclic file allows applications to access records in a consistent and transparent manner. It
can be thought of as a ring of files. Write operations are performed on the next physical
record in the ring.
Select File
This command establishes a logical pointer to a particular file in the smartcard's file system.
This pointer is required for any file manipulation operation. Access to the smartcard's file
system is not multithreaded, however it is possible to have several file pointers defined at
any point in time. This is accomplished by the Manage Channel command, which
establishes multiple logical channels between the reader side application and the card. This
allows different files on the card to be in various states of access by the reader application at
the same time. The identification of the file can be provided in the following ways:
● file identifier (2-byte value)
● DF name (string of bytes)
● path (concatenation of file identifiers)
● short ID
Note that not all smartcards support all four naming mechanisms.
Read Binary
This command is used by the application on the reader side to retrieve a part of an EF on
the card. However, the EF must be a transparent file (not record-oriented). If the Read
Binary command is attempted on a record-oriented EF, the command will abort with an error
indicator being returned from the card.
The Read Binary command takes two parameters: an offset pointer from the start of the file
to the initial byte to be read, and the number of bytes to be read and returned to the reader.
Write Binary
This command is used to insert data into a transparent EF on the card. This command can
be used to set a series of bytes in the EF (that is set selected bits within a specified byte to a
value of1), clear a series of bytes or perform a write of a series of bytes in the EF.
Update Binary
A reader-side application can utilize this command to directly erase and store a contiguous
sequence of bytes in a transparent EF on the card. It effectively functions as a write
command that is a string of bytes provided in the command are written into the EF on the
card. The input parameters consist of an offset pointer from the start of the file as well as the
number of bytes to be written.
23/43
ISO 7816-4 – smartcard commands AN2646 - Application note
Erase Binary
The Erase Binary command is used to clear bytes within a transparent EF on a card.
Similarly to the previous commands, the input parameters comprise an offset from the start
of the EF to the segment of bytes to be erased as well as the number of bytes to be erased.
Read Record
This command is used to read and return the contents of one or more records in an EF on a
card. Unlike the previous command, the EF for the Read Record command must be a
record-oriented file. If it is applied to a transparent EF, the command will abort and an error
will be returned to the reader.
The following may be returned from this command, depending on the input parameters:
● A specified record
● All the records from the beginning of the file to a specific record
● All the records from a specific record to the end of the file
Write Record
This command is used to write a record into a record-oriented EF. As with the Write Binary
command, this command can be used to write a record into an EF, set or clear specific bits
within a specific record in an EF.
Append Record
The Append Record command is used to add a record to the end of a linear, record-oriented
EF or to write the first record to a cyclic, record-oriented EF on a card.
Update Record
This command writes a specific record into a record-oriented EF on a card. As with the
Update Binary command, the old record is erased and the new one is written into the EF.
Get Data
This command reads and returns the contents of a data object stored within the file system
on the card. The Get Data command is card-specific as the definition of a data object varies
between different cards.
Put Data
This command (as the name suggests) puts information into a data object on the card. As
with the previous command, this is a card-specific command.
24/43
AN2646 - Application note ISO 7816-4 – smartcard commands
Verify
This command is sent by the application on the reader side to the security system on the
card. Its purpose is to convince the card that the reader knows a password maintained by
the card in order to restrict access to sensitive information stored on the card. The
password-type information may be associated with a specific file or to some or all of the file
hierarchy. If the Verify command fails i.e. the reader provides an incorrect password, an error
is returned to the reader.
Internal Authenticate
This command allows the card to authenticate itself to the reader by proving that it
possesses a secret key shared with the reader. The reader application software first
generates a random number and encrypts it with some algorithm known to both card and
reader. This constitutes a challenge to the card. The card then decrypts this challenge with
the secret key (that is stored on the card) and sends the resulting data back to the reader. If
the data received by the reader matches the random number that it generated then the
reader application software is assured of the identity of the card.
External Authenticate
This command is used in conjunction with the Get Challenge command to enable the reader
application software to authenticate itself to the card. The reader receives challenge data (a
random number) from the card and encrypts it with a secret key. This is then sent to the card
using the External Authenticate command. The card decrypts the data and compares it to
the random number that it generated in the previous Get Challenge command. If there is a
match, then the card is assured of the identity of the reader application.
Get Challenge
This command is sent by the reader to the card. Its purpose is to provide the reader
application with a random number generated by the smartcard. As previously described, this
number is used in the External Authenticate command.
Manage Channel
The Manage Channel command is used by the reader application to open and close the
logical communication channels between it and the card. Initially the card opens a basic
communication channel by establishing an application-level protocol with the reader
application through the completion of an ATR sequence. This channel is then used to open
or close additional logical channels through the Manage Channel command.
Envelope
This command supports the use of secure messaging using the T0 protocol. It enables an
APDU to be encrypted and then incorporated into the Envelope command's data section (of
its APDU). The APDU processor on the card can then extract and execute the command.
Get Response
As with the previous command, the Get Response command allows the use of the T0
protocol for transferring APDUs. The Case 4 type of APDU cannot be supported by the T0
protocol i.e. it is not possible to send a block of data to the card and then receive a block of
data in return. So when using the T0 protocol, the initial command results in a response
which indicates that more data is waiting to be sent by the card. The Get Response
command is then used to retrieve this data.
25/43
Smartcard interface library: description AN2646 - Application note
The user may access a smartcard using directly the application layer. It allows to
send/receive ADPU commands to/from the smartcard using the following user interface:
Handles all smartcard states and serves to send and receive all
SC_Handler
communication data between smartcard and reader.
SC_PowerCmd Enables or disables the power to the smartcard.
SC_Reset Sets or clears the smartcard reset pin.
Resends the byte that failed to be received (by the smartcard)
SC_ParityErrorHandler
correctly.
SC_PTSConfig Configures the IO speed (BaudRate) communication.
26/43
AN2646 - Application note Smartcard interface library: description
Handles all smartcard states and serves to send and receive all
Behavior description
communication data between smartcard and reader.
SCState: pointer to an SC_State enumeration that will contain the
Input parameter1
smartcard state.
SC_ADPU: pointer to an SC_ADPU_Commands structure that will be
Input parameter2
initialized.
SC_Response: pointer to a SC_ADPU_Responce structure which will be
Input parameter3
initialized.
Output parameter None
Return parameter None
Required preconditions None
Called functions None
SCState
SCState informs the user about the smartcard state and allows the user to power off the
smartcard. It can take one of the values defined in Table 12 below.
27/43
Smartcard interface library: description AN2646 - Application note
SC_ADPU_Commands
The SC_APDU_Commands structure is defined in the smartcard.h file:
typedef struct
{
SC_Header Header;
SC_Body Body;
} SC_ADPU_Commands;
● Header
Specifies the APDU command header. It is of the SC_Header type, which is defined in
the smartcard.h file:
typedef struct
{
u8 CLA; /* Command class */
u8 INS; /* Operation code */
u8 P1; /* Selection Mode */
u8 P2; /* Selection Option */
} SC_Header;
● CLA
Specifies the class designation of the command set to establish a collection of
instructions.
● INS
Specifies a specific instruction from within the set of instructions.
● P1
Specifies the addressing used by the [CLA, INS] instruction.
● P2
Specifies the addressing used by the [CLA, INS] instruction.
● Body
Specifies the APDU command body. It is of the SC_Body type, which is defined in the
smartcard.h file:
28/43
AN2646 - Application note Smartcard interface library: description
typedef struct
{
u8 LC; /* Data field length */
u8 Data[LCmax]; /* Command parameters */
u8 LE; /* Expected length of data to be returned */
} SC_Body;
● LC
Specifies the number of data bytes transferred to the card as part of the [CLA, INS]
instruction execution.
● Data
Specifies the pointer to the data buffer transferred to the card.
● LE
Specifies the number of data bytes transferred from the card as part of the [CLA, INS]
instruction execution.
● SC_Response
Specifies the APDU command response. It is of SC_ADPU_Response type, defined in
the smartcard.h file:
typedef struct
{
u8 Data[LCmax]; /* Data returned from the card */
u8 SW1; /* Command Processing status */
u8 SW2; /* Command Processing qualification */
} SC_ADPU_Responce;
● Data
Specifies the pointer to the data buffer which will contain the returned card data.
● SW1
Specifies the first status code byte. This byte stores the error category.
● SW2
Specifies the second status code byte. This byte stores a command-specific status or
error indication.
Example:
/* Select the Master Root MF */
SC_ADPU.Header.CLA = SC_CLA;
SC_ADPU.Header.INS = SC_SELECT_FILE;
SC_ADPU.Header.P1 = 0x00;
SC_ADPU.Header.P2 = 0x00;
SC_ADPU.Body.LC = 0x02;
29/43
Smartcard interface library: description AN2646 - Application note
6.2.2 SC_PowerCmd
Example:
/* Power ON the card */
SC_PowerCmd(ENABLE);
6.2.3 SC_Reset
Example:
/* Set the smartcard reset pin */
SC_Reset(Bit_SET);
30/43
AN2646 - Application note Smartcard interface library: description
6.2.4 SC_ParityErrorHandler
Behavior description Resends the byte that failed to be received correctly (by the smartcard)
Input parameter None
Output parameter None
Return parameter None
Required preconditions None
Called functions None
Example:
/* Resend the byte to the smartcard */
SC_ParityErrorHandler();
6.2.5 SC_PTSConfig
Example:
/* Configures the baudrate according to the card TA1 value */
SC_PTSConfig();
31/43
Smartcard interface library: description AN2646 - Application note
6.3.1 SC_GET_A2R
SC_ADPU.Header.CLA = 0x00;
SC_ADPU.Header.INS = SC_GET_A2R;
SC_ADPU.Header.P1 = 0x00;
SC_ADPU.Header.P2 = 0x00;
SC_ADPU.Body.LC = 0x00;
while(SCState != SC_ACTIVE_ON_T0)
{
SC_Handler(&SCState, &SC_ADPU, &SC_Responce);
}
● SCState: It stores the current smartcard state.
● SC_ATR_Table: Pointer to an array (filled in by the SC_Handler function) that
contains the smartcard ATR frame.
6.3.2 SELECT_FILE
SC_ADPU.Header.CLA = SC_CLA;
SC_ADPU.Header.INS = SC_SELECT_FILE;
SC_ADPU.Header.P1 = 0x00;
SC_ADPU.Header.P2 = 0x00;
SC_ADPU.Body.LC = 0x02;
for(i = 0; i < SC_ADPU.Body.LC; i++)
{
SC_ADPU.Body.Data[i] = FileName[i];
}
while(i < LCmax)
{
SC_ADPU.Body.Data[i++] = 0;
}
SC_ADPU.Body.LE = 0;
SC_Handler(&SCState, &SC_ADPU, &SC_Responce);
6.3.3 SC_GET_RESPONSE
SC_ADPU.Header.CLA = SC_CLA;
SC_ADPU.Header.INS = SC_GETRESPONSE;
SC_ADPU.Header.P1 = 0x00;
SC_ADPU.Header.P2 = 0x00;
SC_ADPU.Body.LC = 0x00;
i = 0;
while(i < LCmax)
{
32/43
AN2646 - Application note Smartcard interface library: description
SC_ADPU.Body.Data[i++] = 0;
}
SC_ADPU.Body.LE = SC_Responce.SW2;
SC_Handler(&SCState, &SC_ADPU, &SC_Responce);
● SCState: It stores the current smartcard state.
● SC_Response->SW1 and SC_Response->SW2: they return the smartcard response
to the SC_GET_RESPONSE command.
● SC_Response->Data: It returns the smartcard data response to the
SC_GET_RESPONSE command.
6.3.4 SC_READ_BINARY
SC_ADPU.Header.CLA = SC_CLA;
SC_ADPU.Header.INS = SC_READ_BINARY;
SC_ADPU.Header.P1 = OFFSET_MSB;
SC_ADPU.Header.P2 = OFFSET_LSB;
SC_ADPU.Body.LC = 0x00;
6.3.5 SC_CREATE_FILE
SC_ADPU.Header.CLA = SC_CLA;
SC_ADPU.Header.INS = SC_CREATE_FILE;
SC_ADPU.Header.P1 = 0x00;
SC_ADPU.Header.P2 = 0x00;
SC_ADPU.Body.LC = 0x10;
33/43
Smartcard interface library: description AN2646 - Application note
● FileParameters: It contains the 16 bytes file parameters (File ID, FILE Access
Conditions...).
● SCState: It stores the current smartcard state.
● SC_Response->SW1 and SC_Response->SW2: they return the smartcard response
to the SC_CREATE_FILE command.
6.3.6 SC_UPDATE_BINARY
SC_ADPU.Header.CLA = SC_CLA;
SC_ADPU.Header.INS = SC_UPDATE_BINARY;
SC_ADPU.Header.P1 = OFFSET_MSB;
SC_ADPU.Header.P2 = OFFSET_LSB;
SC_ADPU.Body.LC = LENGTH;
6.3.7 SC_VERIFY
SC_ADPU.Header.CLA = SC_CLA;
SC_ADPU.Header.INS = SC_VERIFY;
SC_ADPU.Header.P1 = 0x00;
SC_ADPU.Header.P2 = 0x00;
SC_ADPU.Body.LC = 0x08;
34/43
AN2646 - Application note Smartcard interface library: description
35/43
Smartcard interface example AN2646 - Application note
An example is provided in conjunction with the smartcard library in order to help the user
develop its custom application.
The example provides simple operations with an ISO 7816-3/4-compatible GSM11.11
smartcard, such as file system exploration, pin1 enable/disable, read/write operation on files
and pin verify on protected files.
This example was developed to run on the STM8/128-EVAL (evaluation board) that provides
all needed hardware to interface a smartcard.
36/43
AN2646 - Application note Smartcard interface example
No
Smartcard detected
Yes
Power Off
PowerCommand
Power On
Power On
Initialization
Answer received
Disable smartcard interface
Decode Answer
Smartcard Active on T0 protocol
Three directories have been defined for the GSM smartcard directory tree:
MasterRoot[3]={0x3F, 0x00};
GSMDir[3]={0x7F, 0x20};
TelecomDir[3]={0x7F, 0x10};
37/43
Smartcard interface example AN2646 - Application note
SC_ADPU.Header.CLA = 0x00;
SC_ADPU.Header.INS = SC_GET_A2R;
SC_ADPU.Header.P1 = 0x00;
SC_ADPU.Header.P2 = 0x00;
SC_ADPU.Body.LC = 0x00;
while(SCState != SC_ACTIVE_ON_T0)
{
SC_Handler(&SCState, &SC_ADPU, &SC_Responce);
}
When a card is detected, the A2R sequence is generated, received and decoded. If the
recognized protocol is the T0 protocol, the smartcard state of the reader is active
(SC_ACTIVE_ON_T0) and the smartcard is available for operations on the file system.
The procedure type selection (PTS) will be applied after the ATR using the SC_PTSConfig()
function. For the used GSM card, the PTS procedure is as follows:
PTSS = 0xFF
PTS0 = 0x10
PTS1 = 0x95
PCK = 0x7A
38/43
AN2646 - Application note Smartcard interface example
39/43
Smartcard interface example AN2646 - Application note
40/43
AN2646 - Application note Conclusion
8 Conclusion
Using the STM8S UART1’s smartcard mode that supports the ISO 7816-3/4 specification,
you can develop a smartcard-based application with reduced firmware and hardware
resources.
41/43
Revision history AN2646 - Application note
9 Revision history
42/43
AN2646 - Application note
Information in this document is provided solely in connection with ST products. STMicroelectronics NV and its subsidiaries (“ST”) reserve the
right to make changes, corrections, modifications or improvements, to this document, and the products and services described herein at any
time, without notice.
All ST products are sold pursuant to ST’s terms and conditions of sale.
Purchasers are solely responsible for the choice, selection and use of the ST products and services described herein, and ST assumes no
liability whatsoever relating to the choice, selection or use of the ST products and services described herein.
No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted under this document. If any part of this
document refers to any third party products or services it shall not be deemed a license grant by ST for the use of such third party products
or services, or any intellectual property contained therein or considered as a warranty covering the use in any manner whatsoever of such
third party products or services or any intellectual property contained therein.
UNLESS OTHERWISE SET FORTH IN ST’S TERMS AND CONDITIONS OF SALE ST DISCLAIMS ANY EXPRESS OR IMPLIED
WARRANTY WITH RESPECT TO THE USE AND/OR SALE OF ST PRODUCTS INCLUDING WITHOUT LIMITATION IMPLIED
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE (AND THEIR EQUIVALENTS UNDER THE LAWS
OF ANY JURISDICTION), OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT.
UNLESS EXPRESSLY APPROVED IN WRITING BY AN AUTHORIZED ST REPRESENTATIVE, ST PRODUCTS ARE NOT
RECOMMENDED, AUTHORIZED OR WARRANTED FOR USE IN MILITARY, AIR CRAFT, SPACE, LIFE SAVING, OR LIFE SUSTAINING
APPLICATIONS, NOR IN PRODUCTS OR SYSTEMS WHERE FAILURE OR MALFUNCTION MAY RESULT IN PERSONAL INJURY,
DEATH, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE. ST PRODUCTS WHICH ARE NOT SPECIFIED AS "AUTOMOTIVE
GRADE" MAY ONLY BE USED IN AUTOMOTIVE APPLICATIONS AT USER’S OWN RISK.
Resale of ST products with provisions different from the statements and/or technical features set forth in this document shall immediately void
any warranty granted by ST for the ST product or service described herein and shall not create or extend in any manner whatsoever, any
liability of ST.
Information in this document supersedes and replaces all information previously supplied.
The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners.
43/43