The Hitachi MultiMediaCard HB288016MM1 is a highly integrated flash memory with serial and
random access capability. It is accessible via a dedicated serial interface optimized for fast and reliable
data transmission. This interface allows several cards to be stacked by through connecting their peripheral
contacts. The HB288016MM1 is fully compatible to a new consumer standard, called the MultiMediaCard
system standard defined in the MultiMediaCard system specification [1]. The MultiMediaCard system is a
new mass-storage system based on innovations in semiconductor technology. It has been developed to
provide an inexpensive, mechanically robust storage medium in card form for multimedia consumer
applications. MultiMediaCard allows the design of inexpensive players and drives without moving parts.
A low power consumption and a wide supply voltage range favors mobile, battery-powered applications
such as audio players, organizers, palmtops, electronic books, encyclopedia and dictionaries. Using very
effective data compression schemes such as MPEG, the MultiMediaCard will deliver enough capacity for
all kinds of multimedia data: software/programs, text, music, speech, images, video etc.
Note: MultiMediaCard is a trademark of Siemens AG.
Features
• 16 MByte memory capacity
• On card error correction
HB288016MM1
• MultiMediaCard system standard compatibility
System specification version 2.11 compliant
SPI interface supported
Block and partial block read supported (Command classes 0 and 2)
Stream read supported (Command class 1)
Block write and erase supported (Command classes 4 and 5)
Group write protection (Command classes 6)
Stream write supported (Command classes 3)
Password data access protection
Small erase block size of 512 bytes, tagged erase supported
Read block size programmable between 1 and 2048 bytes
VCC = 2.7 V to 3.6 V operation voltage range (VCC = 2.0 V to 3.6 V for the interface)
No external programming voltage required
Damage free powered card insertion and removal
4kV ESD protection
• High speed serial interface with random access
Read speed: sustained: 13.7 Mbits/s (multi-block read)
Up to 10 stacked card (at 20 MHz, VCC = 2.7 to 3.6V)
Access time: 300 µs (max) (at 20 MHz, VCC = 2.7 to 3.6V, random byte access (Typical case))
• Low power dissipation
High speed: 95 mW (max) (at 20 MHz, VCC = 2.7 V)
2
Block Diagram
HB288016MM1
V
PP
Generator
Flash control
1234
V
CC
CS CMD/DIDAT/DOCLK/SCLK
Internal clock
OCR[31:0]
CID[127:0]
set
CSD[127:0]
Register
RCA[15:0]
Interface driver
Interface
Core control
Memory core
567
DA T
CMD
Power on reset unit
All units in the HB288016MM1 are clocked by an internal clock generator. The Interface driver unit
synchronizes the DAT and CMD signals from external CLK to the internal used clock signal. The card is
controlled by the three line MultiMediaCard interface containing the signals: CMD, CLK, DAT (refer to
Chapter “Interfaces”). For the identification of the HB288016MM1 in a stack of MultiMediaCards a card
identification register (CID) and a relative card address register (RCA) is foreseen. An additional register
contains different types of operation parameters. This register is called card specific data register (CSD).
The communication using the MultiMediaCard lines to access either the memory field or the registers is
defined by the MultiMediaCard standard (refer to Chapter “Communication”). The card has its own power
on detection unit. No additional master reset signal is required to setup the card after power on. It is
protected against short circuit during insertion and removal while the MultiMediaCard system is powered
up (refer to Chapter “Power Supply”). No external programming voltage supply is required. The
programming voltage is generated on card. HB288016MM1 supports a second interface operation mode
the SPI interface mode. The SPI mode is activated if the CS signal is asserted (negative) during the
reception of the reset command (CMD0) (refer to Chapter “SPI Communication”).
3
HB288016MM1
Interface
The HB288016MM1 interface can operate in two different modes:
• MultiMediaCard mode
• SPI mode
Both modes are using the same pins. The default mode is the MultiMediaCard mode. The SPI mode is
selected by activating (= 0) the CS signal (Pin1) and sending the CMD0.
MultiMediaCard Mode
In the HB288016MM1, all data is transferred over a minimal number of lines:
• CLK: with each cycle of this signal an one bit transfer on the command and data lines is done. The
frequency may vary between zero and the maximum clock frequency. The MultiMediaCard bus master
is free to generate these cycles without restrictions in the range of 0 to 20 MHz.
• CMD: is a bidirectional command channel used for card initialization and data transfer commands.
The CMD signal has two operation modes: open drain for initialization mode and push pull for fast
command transfer. Commands are sent from the MultiMediaCard bus master to the HB288016MM1
and responses vice versa.
• DAT: is a bidirectional data channel with a width of one line. The DAT signal of the HB288016MM1
operates in push pull mode.
Interface driver
R
OD
MultiMediaCard Host
R
DA T
R
CMD
CMD
DA T
CLK
1 2 3 4 5 6 7
HB288016MM1
MultiMediaCard Mode Interface
All MultiMediaCards are connected directly to the lines of the MultiMediaCard bus. The following table
defines the card contacts.
Note:1. S: power supply; I: input; O: output; PP: push-pull; OD: open-drain; NC: No connection or V
DAT
enable
V
SS2
CLK
IH
V
CC
V
SS1
CMD
1 2 3 4 5 6 7
enable
Interface driver
MultiMediaCard Mode I/O-drivers
MultiMediaCard interface controller
Memory core interface
OD/PP
5
HB288016MM1
SPI Mode
The Serial Peripheral Interface (SPI) is a general-purpose synchronous serial interface originally found on
certain Motorola microcontrollers. The MultiMediaCard SPI interface is compatible with SPI hosts
available on the market. As any other SPI device the MultiMediaCard SPI interface consists of the
following four signals:
CS: Host to card Chip Select signal.
CLK: Host to card clock signal
Data in: Host to card data signal.
Data out: Card to host data signal.
The MultiMediaCard card identification and addressing methods are replaced by a hardware Chip Select
(CS) signal. There are no broadcast commands. For every command, a card (slave) is selected by asserting
(active low) the CS signal (refer to Figure “SPI Bus System”). The CS signal must be continuously active
for the duration of the SPI transaction (command, response and data). The only exception occurs during
card programming, when the host can de-assert the CS signal without affecting the programming process.
The bidirectional CMD and DAT lines are replaced by unidirectional data in and data out signals. This
eliminates the ability of executing commands while data is being read or written and, therefore, makes the
sequential and multi block read/write operations obsolete. Only single block read/write commands are
supported by the SPI channel. The SPI interface uses the same seven signals of the standard
MultiMediaCard bus (refer to Table “SPI Interface Pin Configuration”).
Power
supply
SPI bus (CLK, Datain, Dataout)
SPI Bus System
SPI bus master
SPI cardSPI card
CS
CS
6
HB288016MM1
SPI Interface Pin Configuration
MuitiMediaCardSPI
Pin No. NameType*
1
1RSVNCReserved for future use CSIChip select (neg true)
2CMDI/O/PP/ODCommand/ResponseDIIData in
3V
Note:1. S: power supply; I: input; O: output; PP: push-pull; OD: open-drain; NC: No connection or V
DescriptionNameTypeDescription
SS
CC
SS2
SGround
SPower supply
SGround
IH
7
HB288016MM1
Registers
The HB288016MM1 contains the following information registers:
NameWidthTypeDescription
OCR32Programmed by the
manufacturer.
Read only for user
CID128Programmed by the
manufacturer.
Read only for user
RCA16Programmed during
initialization, not readable
CSD128Programmed by the
manufacturer. Partially
programmable by the user.
CID and RCA are used for identifying and addressing the HB288016MM1. The third register contains the
card specific data record. This record is a set of information fields to define the operation conditions of the
HB288016MM1.
Supported voltage range, card power up status bit
Card identification number, card individual number for
identification.
Relative card address, local system address of a card,
dynamically assigned by the host during initialization.
Card specific data, information about the card operation
conditions.
For the user the CID and the CSD are read only registers. They are read out by special commands (refer to
Chapter “Commands”). The RCA registers are write only registers. Unlike CID and CSD, RCA looses its
contents after powering down the card. Its value is reassigned in each initialization cycle. The
MultiMediaCard registers usage in SPI mode is summarized in Table “MultiMediaCard Registers in SPI
Mode”:
MultiMediaCard Registers in SPI Mode
NameAvailable in SPI mode Width (Bytes)Description
OCRYes32Operation condition register.
CIDYes16Card identification data (serial number, manufacturer ID
etc.)
RCANo
CSDYes16Card specific data, information about the card operation
conditions.
8
HB288016MM1
Card Identification (CID)
This register contains the card identification information used during the card identification procedure. It is
a 128 bit wide register, one-time programmable by the provider. The CID is divided into eight slices:
CID Fields
NameFieldWidthCID-slice
Manufacturer IDMID8[127:120]
OEM/Application IDOID16[119:104]
Product namePNM48[103:56]
Product revisionPRV8[55:48]
Product serial numberPSN32[47:16]
Manufacturing dateMDT8[15:8]
CRC checksumCRC7[7:1]
not used, always 1—1[0:0]
The CID has to be error free. To ensure the correctness of the CID a CRC checksum is added to the end of
the CID. The CRC checksum is computed by the following formula:
CRC Calculation: G(x) = x7 + x3 + 1
M(x) = CID[127]∗x
CRC[6...0] = Remainder [(M(x)∗x7)/G(x)]
119
+...+ CID[8]∗x
0
Relative Card Address (RCA)
The 16-bit relative card address register carries the card address assigned by the host during the card
identification. This address is used for the addressed host to card communication after the card
identification procedure. The default value of the RCA register is 0x0001. The value 0x0000 is reserved to
set all cards in Standby State with the command SELECT_DESELECT_CARD (CMD7). The RCA is
programmed with the command SET_RELATIVE_ADDRESS (CMD3) during the initialization procedure.
The content of this register is lost after power down. The default value is assigned when an internal reset is
applied by the power up detection unit of the HB288016MM1.
9
HB288016MM1
Card Specific Data (CSD)
The card specific data register describes how to access the card content. The CSD defines card operating
parameters like maximum data access time, data transfer speed.
The CSD Fields
NameFieldWidth CSD-slice ValueType
CSD structureCSD_STRUCTURE2[127:126]1read only
Spec versionSPEC_VERS4[125:122]2read only
Reserved—2[121:120]0read only
Data read access-time-1TAAC8[119:112]0x0E (1 ms)read only
Data read access-time-2 in
CLK cycles (NAC*100)
Max. data transfer rateTRAN_SPEED8[103:96]0x2A (20 Mbit/s)read only
Card command classesCCC12[95:84]0x0FF (class 0, 1,
Max. read data block length READ_BLK_LEN4[83:80]0x9 (512 bytes)read only
Partial blocks for read
allowed
Write block misalignmentWRITE_BLK_MISALIGN1[78:78]‘0’ (Disabled)read only
NSAC8[111:104]0x01 (100 cycles) read only
read only
2, 3, 4, 5, 6, 7)
READ_BLK_PARTIAL1[79:79]‘1’*1 (Enabled)read only
Read block misalignmentREAD_BLK_MISALIGN 1[77:77]‘0’ (Disabled)read only
DSR implementedDSR_IMP1[76:76]‘0’ (Disabled)read only
Reserved—2[75:74]0read only
Device sizeC_SIZE12[73:62]0x7AB
(16 MByte)*
2
read only
Max. read current at VDD min VDD_R_CURR_MIN3[61:59]0x5 (35 mA)read only
Max. read current at VDD max VDD_R_CURR_MAX3[58:56]0x4 (35 mA)read only
Max. write current at V
Max. write current at V
Device size multiplierC_SIZE_MULT3[49:47]2 (16 MByte)*
min VDD_W_CURR_MIN3[55:53]0x5 (35 mA)read only
DD
max VDD_W_CURR_MAX3[52:50]0x4 (35 mA)read only
DD
3
read only
Erase sector sizeSECTOR_SIZE5[46:42]0 (512 Bytes)read only
Erase group sizeERASE_GRP_SIZE5[41:37]0x0F (8 kByte)read only
10
HB288016MM1
NameFieldWidth CSD-slice ValueType
Write protect group sizeWP_GRP_SIZE5[36:32]0x01 (16 kByte)read only
Write protect group enableWP_GRP_ENABLE1[31:31]‘1’read only
Manufacturer default ECCDEFAULT_ECC2[30:29]0read only
Write speed factorR2W_FACTOR3[28:26]2 (4)read only
Max. write data block length WRITE_BLK_LEN4[25:22]9 (512 Bytes)read only
Partial blocks for write
allowed
Reserved—5[20:16]0read only
File format groupFILE_FORMAT_GRP1[15:15]×read/write
Copy flag (OTP)COPY1[14:14]×*
Permanent write protectionPERM_WRITE_PROTECT1[13:13]×read/write
Not used, always 1—0[0:0]1read only
Notes: 1. Access time from block to block within sector is 1 µs. For blocks smaller than 256 Byte, it is 62
µs.
2. This field is depended on the model. Refer to also C_SIZE_MULT
3. This field is depended on the model. Refer to also C_SIZE
4. × means user programmable
WRITE_BLK_PARTIAL 1[21:21]‘0’read only
4
read/write
erase
erase
erase
Some of the CSD fields are one-time or multiple programmable by the customer or provider. All other
field values are fixed. The following section describes the CSD fields and their values for the
HB288016MM1:
• CSD_STRUCTURE
CSD Register Structure
CSD_STRUCTURECSD register structure
‘01’CSD version No. 1.1
The CSD version of the HB288016MM1 is related to the “MultiMediaCard system specification, Version
2.11”. The parameter CSD_STRUCTURE has permanently the value 1.
11
HB288016MM1
• SPEC_VERS
Defines the Spec version supported by the card. It includes the commands set definition and the definition
of the card responses. The card identification procedure is compatible for all spec versions!
SPEC Version
SPEC_VERSSystem specification version number
‘0010’System specification version 2.11
The Spec version of the HB288016MM1 is related to the “MultiMediaCard system specification, Version
2.11”. The parameter SPEC_VERS has permanently the value 2.
5 = 2.0, 6 = 2.5, 7 = 3.0, 8 = 3.5, 9 = 4.0, A = 4.5,
B = 5.0, C = 5.5, D = 6.0, E = 7.0, F = 8.0
7reservedalways ‘0’
The value for the asynchronous delay for the HB288016MM1 is 1 ms. The coded TAAC value is 0x0E (=
1 ms). For more details refer to Chapter “Operating Characteristics”.
• NSAC
Defines the worst case for the synchronous data access time. NAC is defined as 100*NSAC clock cycles,
where NSAC presents a binary value. Max. value for the data access time NAC is 25.6k clock cycles. The
total access time is the sum of both TAAC and NAC*clock period. The value of NSAC for the
HB288016MM1 is 0x01 (100 cycles). For more details refer to Chapter “Operating Characteristics”.
12
HB288016MM1
• TRAN_SPEED
The following table defines the maximum data transfer rate TRAN_SPEED:
The HB288016MM1 supports a transfer rate between 0 and 20 Mbit/s. The parameter TRAN_SPEED is
0x2A.
• CCC
The MultiMediaCard command set is divided into subsets (command classes). The card command class
register CCC defines which command classes are supported by this card. A set CCC bit means that the
corresponding command class is supported. For command class definition refer to Table “HB288016MM1
Command Classes”.
Supported Card Command Classes
CCC bitSupported card command classes
0class0
1class1
............
11class11
The HB288016MM1 supports the command classes 0, 1, 2, 3, 4, 5, 6 and 7. The parameter CCC is
permanently assigned to the value 0x0FF.
13
HB288016MM1
• READ_BLK_LEN
The data block length is computed as 2
READ_BLK_LEN
.
Data Block Length
READ_BLK_LENBlock lengthRemark
0
02
12
............
11211 = 2048 bytes
12–15reserved
= 1 byte
1
= 2 bytes
The block length might therefore be in the range 1, 2, 4...2048 bytes. This parameter defines the block
length if READ_BLK_PARTIAL is not set. If READ_BLK_PARTIAL is set this parameter contains the
maximum allowed value of the block length in bytes. All block lengths between one and this value are
permitted. The actual block size is programmed by the command SET_BLOCKLEN (CMD16). The
HB288016MM1 supports block lengths from 1 byte up to 2048 bytes. The parameter READ_BLK_LEN is
permanently assigned to the value 0x9.
• READ_BLK_PARTIAL
READ_BLK_PARTIAL defines whether partial block sizes can be used in block read and block write
commands. READ_BLK_PARTIAL = 0 means that only the block size defined by READ_BLK_LEN can
be used for block-oriented data transfers. READ_BLK_PARTIAL = 1 means that smaller blocks can be
used as well. The minimum block size will be equal to minimum addressable unit (one byte). The
HB288016MM1 supports partial block read. The parameter READ_BLK_PARTIAL is permanently
assigned to the value ‘1’.
• WRITE_BLK_MISALIGN
Defines if the data block to be written by one command can be spread over more than one physical blocks
of the memory device. The size of the memory block is defined in WRITE_BLK_LEN.
WRITE_BLK_MISALIGN is permanently assigned to the value ‘0’, signalling that crossing physical block
boundaries is not allowed.
• READ_BLK_MISALIGN
Defines if the data block to be read by one command can be spread over more than one physical block of
the memory device. The size of the data block is defined in READ_BLK_LEN. READ_BLK_MISALIGN
= 0 signals that crossing physical block boundaries is not allowed. READ_BLK_MISALIGN = 1 signals
that crossing physical block boundaries is allowed. The HB288016MM1 does not support read block
operations with boundary crossing. The parameter READ_BLK_MISALIGN is permanently assigned to
the value ‘0’.
14
HB288016MM1
• DSR_IMP
Defines if the configurable driver stage option is integrated on the card or not. If implemented a driver
stage register (DSR) must be implemented also.
DSR Implementation
DSR_IMPDSR type
0no DSR implemented
1DSR implemented
The HB288016MM1 output drivers are not configurable. The parameter DSR_IMP is permanently
assigned to the value ‘0’.
• C_SIZE
This parameter is used to compute the card capacity. The memory capacity of the card is computed from
the entries C_SIZE, C_SIZE_MULT and READ_BLK_LEN as follows:
memory capacity = BLOCKNR*BLOCK_LEN
Where
BLOCKNR = (C_SIZE+1)*MULT
MULT = 2
BLOCK_LEN = 2
C_SIZE_MULT+2
READ_BLK_LEN
(C_SIZE_MULT < 8)
, (READ_BLK_LEN < 12)
Therefore, the maximal capacity which can be coded is 4096*512*512 = 1 GBytes.
Example: A 16 MBytes card with BLOCK_LEN = 512 can be coded with C_SIZE_MULT = 2 and
C_SIZE = 1963.
The card capacity is 16 MBytes.
The value of the parameter C_SIZE used in the formula above for the HB288016MM1 is 0x7AB.
15
HB288016MM1
• VDD_R_CURR_MIN, VDD_W_CURR_MIN
The maximum supply current at the minimum supply voltage V
Maximum Supply Current Consumption at V
VDD_R_CURR_MIN
VDD_W_CURR_MINCode for current consumption at 2.7 V
The parameter VDD_R_CURR_MAX and VDD_W_CURR_MAXare permanently assigned to the value 4
(35 mA). For more details refer to Chapter “Characteristics”.
16
• C_SIZE_MULT
HB288016MM1
This parameter is used for coding a factor MULT for computing the total device size (refer to “C_SIZE”).
The factor MULT is defined as 2
C_SIZE_MULT+2
.
Multiply Factor for the Device Size
C_SIZE_MULTMULTRemark
2
02
12
22
32
42
52
62
72
= 4
3
= 8
4
= 16
5
= 32
6
= 64
7
= 128
8
= 256
9
= 512
The card capacity is 16 MBytes. The value of the parameter C_SIZE_MULT used in the formula to
calculate the card capacity (refer to parameter “C_SIZE”) for the HB288016MM1 is 2 (multiplier = 16).
• SECTOR_SIZE
The size of an erasable or write protection sector. The content of this register is a binary coded value
defining the number of write blocks (refer to “WRITE_BLK_LEN”) of a sector. The sector size of the
HB288016MM1 is set to 0 (= one write block = 512 bytes).
• ERASE_GROUP_SIZE
The size of an erasable group. The content of this register is a binary coded value defining the number of
sectors (refer to “SECTOR_SIZE”) of a group. This parameters value is 15 which means a group size of
(15+1)*512 bytes = 8 kByte.
• WP_GRP_SIZE
The size of a write protection group. The content of this register is a binary coded value defining the
number of sectors (refer to “SECTOR_SIZE”) of a group. This parameters value is 1 which means a group
size of (1+1)*(ERASE_GROUP_SIZE) = 16 kByte.
• WP_GRP_ENABLE
The value is set to ‘1’, meaning group write protection is enabled.
17
HB288016MM1
• DEFAULT_ECC
Set by the card manufacturer and defines the ECC code which is recommended to use (e.g. the device is
tested for). The value is set to ‘0’, indicating that no designated ECC is recommended.
• R2W_FACTOR
Defines the typical block program time as a multiple of the read access time. The following table defines
the field format.
R2W_FACTOR
R2W_FACTORMultiples of read access time
01
12 (write half as fast as read)
24
38
416
532
6, 7reserved
This parameter value is 2 for the HB288016MM1.
• WRITE_BLK_LEN
The data block length is computed as 2
WRITE_BLK_LEN
.
Data Block Length
WRITE_BLK_LENBlock lengthRemark
0
02
12
............
11211 = 2048 bytes
12–15reserved
= 1 byte
1
= 2 bytes
The block length might therefore be in the range 1, 2, 4...2048 bytes. This parameter defines the block
length if WRITE_BLK_PARTIAL is not set. If WRITE_BLK_PARTIAL is set this parameter contains the
maximum allowed value of the block length in bytes. All block lengths between one and this value are
permitted. The actual block size is programmed by the command SET_BLOCKLEN (CMD16). The
HB288016MM1 supports blocks with the length 512 bytes. The parameter WRITE_BLK_LEN is
permanently assigned to the value 0x9.
18
HB288016MM1
• WRITE_BLK_PARTIAL
WRITE_BLK_PARTIAL defines whether partial block sizes can be used in block read and block write
commands. WRITE_BLK_PARTIAL = 0 means that only the block size defined by WRITE_BLK_LEN
can be used for block-oriented data transfers. WRITE_BLK_PARTIAL = 1 means that smaller blocks can
be used as well. The minimum block size will be equal to minimum addressable unit (one byte). The
HB288016MM1 supports no partial block write. The parameter WRITE_BLK_PARTIAL is permanently
assigned to the value ‘0’.
• FILE_FORMAT_GRP
Indicates the selected group of file formats. This field is read-only for ROM. The usage of this field is
shown in table “File_Formats”.
• COPY
Defines if the contents are an original (COPY = “0”) or a copy (= “1”). The COPY bit for OTP and MTP
devices, sold to end consumers, is set to “1” which identifies the card content as a copy. The COPY bit is a
one time programmable bit, being set by the customer
• PERM_WRITE_PROTECT
Permanently protects the whole card content against overwriting or erasing (all write and erase commands
for this card is permanently disabled). This parameter is one-time programmable by the customer. The
default value is ‘0’ (not protected).
• TMP_WRITE_PROTECT
Temporarily protects the whole card content from being overwritten or erased (all write and erase
commands for this card are temporarily disabled). This parameter is programmable by the customer. The
default value is ‘0’ (not protected).
• FILE_FORMAT
Indicates the file format on the card. This field is read-only for ROM. The following formats are defined:
File_Formats
FILE_FORMAT_GRPFILE_FORMAT Type
00Hard disk-like file system with partition table
01DOS FAT (floppy-like) with boot sector only (no partition table)
02Universal File Format
03Others/Unknown
10, 1, 2, 3Reserved
19
HB288016MM1
• ECC
Defines the ECC code that was used for storing data on the card. This field is used by the host (or
application) to decode the user data. The following table defines the field format.
ECC Type
ECCECC typeMaximum number of correctable bits
0none (default)none
1BCH (542,512)3
2–15reserved—
The content provider or customer defines which kind of error correction may be used to protect the contents
of the HB288016MM1. This value is programmable.
• CRC
The CRC register contains the check sum for the CSD content. The check sum is computed by the
following formulas: Generator polynomial:
The user has to recalculate a new CRC after defining a new CSD.
20
HB288016MM1
MultiMediaCard Communication
All communication between host and cards is controlled by the host (master). The host sends commands
and, depending on the command, receives a corresponding response from the selected card. In this chapter
the commands to control the HB288016MM1, the card responses and the contents of the status and error
field included in the responses, are defined.
Memory Array Partitioning
The basic unit of data transfer to/from the MultiMediaCard is one byte. All data transfer operations which
require a block size always define block lengths as integer multiples of bytes. Some special functions need
other partition granularity. For block-oriented commands, the following definition is used:
• Block: is the unit which is related to the block-oriented read and write commands. Its size is the
number of bytes which will be transferred when one block command is sent by the host. The size of a
block is either programmable or fixed. The information about allowed block sizes and the
programmability is stored in the CSD.
For devices which have erasable memory cells, special erase commands are defined. The granularity of the
erasable units is in general not the same as for the block-oriented commands:
• Sector: is the unit which is related to the erase commands. Its size is the number of blocks which will
be erased in one portion. The size of a sector is fixed for each device. The information about the sector
size (in blocks) is stored in the CSD.
• Group: is a number of sectors. Its size is the number of consecutive sectors which will be erased at
once. The size of a group is fixed for each device. The information about the size is stored in the CSD.
For devices which include a write protection:
• WP-Group: is the minimal unit which may have individual write protection. Its size is the number of
sectors which will be write protected by one bit. The size of a WP-group is fixed for each device. The
information about the size is stored in the CSD.
Each erasable unit (group and sector) has a special “tag” bit. This bit may be set or cleared by special
commands to tag the unit. All tagged units will be erased in parallel by one erase command following a
number of tag commands. All tag bits are cleared by each command except a tag or untag command.
Therefore, immediately after a sequence of tag commands an erase command has to be sent by the host.
Commands others than tagging or erasing abort a tag-erase cycle irregularly.
21
HB288016MM1
MultiMediaCard
GROUP 0
Block 0Block 1Block 2Block 3Block n
Sector 0.0
Sector 0.1
Sector 0.2
Sector tagging
Group tagging
GROUP 1
GROUP n
Sector 0.3
Sector 0.n
Erase Tagging Hierarchy
Each WP-group may have an additional write protection bit. The write protection bits are programmable
via special commands (refer to Chapter “Commands”). Both functions are optional and only useful for
writable/erasable devices. The write protection may also be useful for multi type MultiMediaCards (e.g. a
ROM - Flash combination). The information about the availability is stored in the CSD.
WP-GROUP 0
WP-GROUP 1
22
WP-GROUP n
Group write protection
Write Protection
HB288016MM1
Commands
The command set of the MultiMediaCard system is divided into classes corresponding to the type of card
(see also [1]). The HB288016MM1 supports the following command classes:
HB288016MM1 Command Classes (Class 0 to Class 2)
Supported commands
Card command
class (CCC)Class description
Class 0basic+++++++++++
Class 1stream read+
Class 2block read+++
HB288016MM1 Command Classes (Class 3 to Class 8)
Card command
class (CCC)Class description
Class 3stream write+
Class 4block write++++
Class 5erase+++++++
Class 6write protection+++
Class 7lock card+
Class 0 is mandatory and supported by all cards. It represents the card identification and initialization
commands, which are intended to handle different cards and card types on the same bus lines. The Card
Command Class (CCC) is coded in the card specific data register of each card, so that the host knows how
to access the card. There are four kinds of commands defined on the MultiMediaCard bus:
• broadcast commands (bc) sent on CMD line, no response
• broadcast commands with response (bcr) sent on CMD line, response (all cards simultaneously) on
CMD line
• addressed (point-to-point) commands (ac) sent on CMD line, response on CMD line
• addressed (point-to-point) data transfer commands (adtc) sent on CMD line, response on CMD line,
data transfer on DAT line
23
HB288016MM1
The command transmission always starts with the MSB. Each command starts with a start bit and ends with
a CRC command protection field followed by an end bit. The length of each command frame is fixed to 48
bits (2.4 µs at 20 MHz):
0
start bit1host
Note: 1. (Cyclic Redundancy Check)
bit5...bit0
command
bit31...bit0
argument
bit6...bit0
CRC*
1
1
end bit
The start bit is always ‘0’ in command frames (sent from host to MultiMediaCard). The host bit is always
‘1’ for commands. The command field contains the binary coded command number. The argument
depends on the command (refer to Table “Basic Commands (class 0) and Table “Block-Oriented Read
Commands (class 2)”). The CRC field is defined in Chapter “Cyclic Redundancy Check (CRC)”. The
HB288016MM1 supports the following MultiMediaCard commands:
24
Loading...
+ 55 hidden pages
You need points to download manuals.
1 point = 1 manual.
You can buy points or you can get point for every manual you upload.