EasyManua.ls Logo

SanDisk SDSDB-016G-A11 - 4.7 Error Conditions

SanDisk SDSDB-016G-A11
123 pages
To Next Page IconTo Next Page
To Next Page IconTo Next Page
To Previous Page IconTo Previous Page
To Previous Page IconTo Previous Page
Loading...
Chapter 4 – SD Card Protocol Description
Revision 2.2 SanDisk SD Card Product Manual
© 2004 SanDisk Corporation 4-29 12/08/04
4.6.2 CRC16
The CRC16 is used for payload protection in block transfer mode when on DAT line is
used. The CRC checksum is a 16-bit value and is computed as follows:
generator polynomial: G(x) = x
16
+ x
12
+ x
5 +1
M(x) = (first bit) * x
n
+ (second bit) * x
n-1
+...+ (last bit) * x
0
CRC[15...0] = Remainder [(M(x) * x
16
) / G(x)]
All CRC registers are initialized to zero. The first bit is the first data-bit of the
corresponding block. The degree n of the polynomial denotes the number of bits of the data
block decreased by one. For example, n = 4,095 for a block length of 512 bytes. The
generator polynomial G(x) is a standard CCITT polynomial. The code has a minimal
distance d=4 and is used for a payload length of up to 2,048 bytes (n < 16,383). The same
CRC16 method is used in single DAT line mode and in wide-bus mode. In wide-bus mode,
the CRC16 is done on each line separately.
Figure 4-14 CRC16 Generator/Checker
4.7 Error Conditions
The following sections provide valuable information on error conditions.
4.7.1 CRC and Illegal Commands
CRC-bits protect all commands. If the addressed SD Card CRC check fails, the card does
not respond and the command is not executed. The card does not change its state, and the
COM_CRC_ERROR bit is set in the Status Register.
Similarly, if an illegal command has been received, an SD Card will not change its state or
respond, and will set the ILLEGAL_COMMAND error bit in the Status Register. Only the
non-erroneous state branches are shown in the state diagrams (Figure 4-7 and Figure 4-8).
Table 4-18 contains a complete state transition description.
Different types of illegal commands include:
Commands belonging to classes not supported by the SD Card (e.g., I/O command
CMD39).
Commands not allowed in the current state (e.g., CMD2 in Transfer State).
Commands not defined (e.g., CMD6).

Table of Contents

Related product manuals