# **GD25R32C**

# **DATASHEET**



# **Contents**

| 1 | F    | FEATURES                                          | 4  |
|---|------|---------------------------------------------------|----|
| 2 | G    | GENERAL DESCRIPTIONS                              | 5  |
| 3 | R.   | MEMORY ORGANIZATION                               | 7  |
|   |      |                                                   |    |
| 4 | D    | DEVICE OPERATIONS                                 | 8  |
|   | 4.1  | SPI Mode                                          | 8  |
| 5 | D    | DATA PROTECTION                                   | 9  |
| 6 | 9    | STATUS REGISTER                                   | 11 |
|   |      |                                                   |    |
| 7 | C    | COMMAND DESCRIPTIONS                              | 14 |
|   | 7.1  | Write Enable (WREN) (06H)                         | 17 |
|   | 7.2  | Write Disable (WRDI) (04H)                        | 17 |
|   | 7.3  | READ STATUS REGISTER (RDSR) (05H or 35H or 15H)   | 17 |
|   | 7.4  | Write Status Register (WRSR) (01H or 31H or 11H)  | 18 |
|   | 7.5  | Write Enable for Volatile Status Register (50H)   | 18 |
|   | 7.6  | READ DATA BYTES (READ) (03H)                      | 19 |
|   | 7.7  | READ DATA BYTES AT HIGHER SPEED (FAST READ) (OBH) | 19 |
|   | 7.8  | DUAL OUTPUT FAST READ (3BH)                       | 20 |
|   | 7.9  | QUAD OUTPUT FAST READ (6BH)                       | 21 |
|   | 7.10 | 0 Dual I/O Fast Read (BBH)                        | 21 |
|   | 7.11 | 1 Quad I/O Fast Read (EBH)                        | 22 |
|   | 7.12 | 2 SET BURST WITH WRAP (77H)                       | 23 |
|   | 7.13 | 3 PAGE PROGRAM (PP) (02H)                         | 23 |
|   | 7.14 | 4 Quad Page Program (32H)                         | 24 |
|   | 7.15 | 5 Sector Erase (SE) (20H)                         | 25 |
|   | 7.16 | 6 32KB BLOCK ERASE (BE32) (52H)                   | 25 |
|   | 7.17 | 7 64KB Block Erase (BE64) (D8H)                   | 26 |
|   | 7.18 | 8 CHIP ERASE (CE) (60/C7H)                        | 26 |
|   | 7.19 | 9 HIGH PERFORMANCE MODE (HPM) (A3H)               | 27 |
|   | 7.20 | 0 READ MANUFACTURE ID/ DEVICE ID (REMS) (90H)     | 27 |
|   | 7.21 | 1 READ IDENTIFICATION (RDID) (9FH)                | 28 |
|   | 7.22 | 2 READ UNIQUE ID (4BH)                            | 29 |
|   | 7.23 | 3 Erase Security Registers (44H)                  | 29 |
|   | 7.24 | 4 Program Security Registers (42H)                | 30 |
|   | 7.25 | 5 READ SECURITY REGISTERS (48H)                   | 30 |
|   | 7.26 | 6 Enable Reset (66H) and Reset (99H)              | 31 |
|   | 7.27 | 7 Program/Erase Suspend (PES) (75H)               | 32 |
|   | 7.28 | 8 Program/Erase Resume (PER) (7AH)                | 32 |

# **GD25R32C**

| 7.29 | DEEP POWER-DOWN (DP) (B9H)                                  | 33 |
|------|-------------------------------------------------------------|----|
| 7.30 | RELEASE FROM DEEP POWER-DOWN AND READ DEVICE ID (RDI) (ABH) | 33 |
| 7.31 | READ SERIAL FLASH DISCOVERABLE PARAMETER (5AH)              | 34 |
| 8 R  | PMC COMMANDS DESCRIPTION                                    | 36 |
| 8.1  | COMMAND: WRITE ROOT KEY REGISTER                            | 37 |
| 8.2  | COMMAND: UPDATE HMAC KEY REGISTER                           | 38 |
| 8.3  | COMMAND: INCREMENT MONOTONIC COUNTER                        | 39 |
| 8.4  | COMMAND: REQUEST MONOTONIC COUNTER                          | 40 |
| 8.5  | COMMAND: READ DATA                                          | 41 |
| 8.6  | OPERATIONS ALLOWED/DISALLOWED DURING RPMC OPERATION         | 42 |
| 9 E  | LECTRICAL CHARACTERISTICS                                   | 44 |
| 9.1  | Power-On Timing                                             | 44 |
| 9.2  | Initial Delivery State                                      | 44 |
| 9.3  | Absolute Maximum Ratings                                    | 44 |
| 9.4  | CAPACITANCE MEASUREMENT CONDITIONS                          | 45 |
| 9.5  | DC CHARACTERISTICS                                          | 46 |
| 9.6  | AC CHARACTERISTICS                                          | 47 |
| 10   | ORDERING INFORMATION                                        | 50 |
| 10.1 | Valid Part Numbers                                          | 51 |
| 11   | PACKAGE INFORMATION                                         | 52 |
| 11.1 | PACKAGE SOP8 208MIL                                         | 52 |
| 11.2 | PACKAGE WSON8 (6x5mm)                                       | 53 |
| 12   | REVISION HISTORY                                            | 54 |

#### 1 FEATURES

- 32M-bit Serial Flash
  - 4096K-Byte
  - 256 Bytes per programmable page
- Standard, Dual, Quad SPI
  - Standard SPI: SCLK, CS#, SI, SO,
  - Dual SPI: SCLK, CS#, IO0, IO1,
  - Quad SPI: SCLK, CS#, IO0, IO1, IO2, IO3
- High Speed Clock Frequency
  - 104MHz for fast read with 30PF load
  - Dual I/O Data transfer up to 208Mbits/s
  - Quad I/O Data transfer up to 416Mbits/s
- ◆ Software Write Protection
  - Write protect all/portion of memory via software
  - Top/Bottom Block protection
- Endurance and Data Retention
  - Minimum 100,000 Program/Erase Cycles
  - 20-year data retention typical
- ◆ RPMC Function
  - Four 32-bit Monotonic Counters
  - Volatile HMAC Key Register
  - Non-volatile Root Key Register

- ◆ Fast Program/Erase Speed
  - Page Program time: 0.6ms typical
  - Sector Erase time: 50ms typical
  - Block Erase time: 0.15s/0.25s typical
  - Chip Erase time: 15s typical
- Flexible Architecture
  - Uniform Sector of 4K-Byte
  - Uniform Block of 32/64K-Byte
- ◆ Low Power Consumption
  - 2µA typical standby current
  - 2µA typical deep power down current
- Advanced Security Features
  - 128-bit Unique ID for each device
  - Serial Flash Discoverable parameters (SFDP) register
  - 3x1024-Byte Security Registers With OTP Locks
- Single Power Supply Voltage
  - Full voltage range: 2.7-3.6V
- Package Information
  - SOP8 208mil
  - WSON8 (6x5mm)

### **2 GENERAL DESCRIPTIONS**

The GD25R32C (32M-bit) Serial flash supports the standard Serial Peripheral Interface (SPI), and the Dual/Quad SPI: Serial Clock, Chip Select, Serial Data I/O0 (SI), I/O1 (SO), I/O2, I/O3. The Dual I/O data is transferred with speed of 208Mbit/s, and the Quad I/O data is transferred with speed of 416Mbit/s.

#### **CONNECTION DIAGRAM**



#### **PIN DESCRIPTION**

Table 1. Pin Description for SOP8/WSON8 Package

| Pin No. | Pin Name | 1/0 | Description                       |
|---------|----------|-----|-----------------------------------|
| 1       | CS#      | I   | Chip Select Input                 |
| 2       | SO (IO1) | I/O | Data Output (Data Input Output 1) |
| 3       | IO2      | I/O | Data Input Output 2               |
| 4       | VSS      |     | Ground                            |
| 5       | SI (IO0) | I/O | Data Input (Data Input Output 0)  |
| 6       | SCLK     | I   | Serial Clock Input                |
| 7       | IO3      | I/O | Data Input Output 3               |
| 8       | VCC      |     | Power Supply                      |

Note: CS# must be driven high if chip is not selected. Please don't leave CS# floating any time after power is on.

#### **BLOCK DIAGRAM**





# **3 MEMORY ORGANIZATION**

#### **GD25R32C**

| Each device has | Each block has | Each sector has | Each page has |         |
|-----------------|----------------|-----------------|---------------|---------|
| 4M              | 64/32K         | 4K              | 256           | Bytes   |
| 16K             | 256/128        | 16              | -             | pages   |
| 1K              | 16/8           | -               | -             | sectors |
| 64/128          | -              | -               | -             | blocks  |

#### UNIFORM BLOCK SECTOR ARCHITECTURE

**GD25R32C 64K Bytes Block Sector Architecture** 

| Block | Sector | Addres  | s range |
|-------|--------|---------|---------|
|       | 1023   | 3FF000H | 3FFFFFH |
| 63    |        |         |         |
|       | 1008   | 3F0000H | 3F0FFFH |
|       | 1007   | 3EF000H | 3EFFFFH |
| 62    |        |         |         |
|       | 992    | 3E0000H | 3E0FFFH |
|       |        |         |         |
|       |        |         |         |
|       |        |         |         |
|       |        |         |         |
|       |        |         |         |
|       |        |         |         |
|       | 47     | 02F000H | 02FFFFH |
| 2     |        |         |         |
|       | 32     | 020000H | 020FFFH |
|       | 31     | 01F000H | 01FFFFH |
| 1     |        |         |         |
|       | 16     | 010000H | 010FFFH |
|       | 15     | 00F000H | 00FFFFH |
| 0     |        |         |         |
|       | 0      | 000000H | 000FFFH |



### **4 DEVICE OPERATIONS**

#### 4.1 SPI Mode

#### Standard SPI

The GD25R32C features a serial peripheral interface on 4 signals bus: Serial Clock (SCLK), Chip Select (CS#), Serial Data Input (SI) and Serial Data Output (SO). Both SPI bus mode 0 and 3 are supported. Input data is latched on the rising edge of SCLK and data shifts out on the falling edge of SCLK.

#### **Dual SPI**

The GD25R32C supports Dual SPI operation when using the "Dual Output Fast Read" and "Dual I/O Fast Read" (3BH and BBH) commands. These commands allow data to be transferred to or from the device at twice the rate of the standard SPI. When using the Dual SPI commands, the SI and SO pins become bidirectional I/O pins: IO0 and IO1.

#### **Quad SPI**

The GD25R32C supports Quad SPI operation when using the "Quad Output Fast Read", "Quad I/O Fast Read", "Quad I/O Word Fast Read" (6BH, EBH, E7H) commands. These commands allow data to be transferred to or from the device at four times the rate of the standard SPI. When using the Quad SPI commands, the SI and SO pins become bidirectional I/O pins: IOO and IO1, in addition to IO2 and IO3 pins. For GD25R32C, the QE bit is set to 1 as default and cannot be changed.

#### 5 **DATA PROTECTION**

The GD25R32C provide the following data protection methods:

- Write Enable (WREN) command: The WREN command is set the Write Enable Latch bit (WEL). The WEL bit will return to reset by the following situation:
  - -Power-Up / Software Reset (66H+99H)
  - -Write Disable (WRDI)
  - -Write Status Register (WRSR)
  - -Page Program (PP)
  - -Sector Erase (SE) / Block Erase (BE) / Chip Erase (CE)
- Software Protection Mode: The Block Protect bits (BP4-BP0) define the section of the memory array that can be read but not changed.
- Deep Power-Down Mode: In Deep Power-Down Mode, all commands are ignored except the Release from Deep Power-Down Mode command and Software Reset (66H+99H).
- Write Inhibit Voltage (VWI): Device would reset automatically when VCC is below a certain threshold VWI.

|     | Table 2. GD25R32C Protected area size (CMP=0) |         |        |     |          |                 |         |              |  |
|-----|-----------------------------------------------|---------|--------|-----|----------|-----------------|---------|--------------|--|
| S   | tatus R                                       | egister | Conten | t   |          | Memory Content  |         |              |  |
| BP4 | BP3                                           | BP2     | BP1    | BP0 | Blocks   | Addresses       | Density | Portion      |  |
| Х   | Χ                                             | 0       | 0      | 0   | NONE     | NONE            | NONE    | NONE         |  |
| 0   | 0                                             | 0       | 0      | 1   | 63       | 3F0000H-3FFFFFH | 64KB    | Upper 1/64   |  |
| 0   | 0                                             | 0       | 1      | 0   | 62 to 63 | 3E0000H-3FFFFFH | 128KB   | Upper 1/32   |  |
| 0   | 0                                             | 0       | 1      | 1   | 60 to 63 | 3C0000H-3FFFFFH | 256KB   | Upper 1/16   |  |
| 0   | 0                                             | 1       | 0      | 0   | 56 to 63 | 380000H-3FFFFFH | 512KB   | Upper 1/8    |  |
| 0   | 0                                             | 1       | 0      | 1   | 48 to 63 | 300000H-3FFFFFH | 1MB     | Upper 1/4    |  |
| 0   | 0                                             | 1       | 1      | 0   | 32 to 63 | 200000H-3FFFFFH | 2MB     | Upper 1/2    |  |
| 0   | 1                                             | 0       | 0      | 1   | 0        | 000000H-00FFFFH | 64KB    | Lower 1/64   |  |
| 0   | 1                                             | 0       | 1      | 0   | 0 to 1   | 000000H-01FFFFH | 128KB   | Lower 1/32   |  |
| 0   | 1                                             | 0       | 1      | 1   | 0 to 3   | 000000H-03FFFFH | 256KB   | Lower 1/16   |  |
| 0   | 1                                             | 1       | 0      | 0   | 0 to 7   | 000000H-07FFFFH | 512KB   | Lower 1/8    |  |
| 0   | 1                                             | 1       | 0      | 1   | 0 to 15  | 000000H-0FFFFFH | 1MB     | Lower 1/4    |  |
| 0   | 1                                             | 1       | 1      | 0   | 0 to 31  | 000000H-1FFFFFH | 2MB     | Lower 1/2    |  |
| Х   | Х                                             | 1       | 1      | 1   | 0 to 63  | 000000H-3FFFFFH | 4MB     | ALL          |  |
| 1   | 0                                             | 0       | 0      | 1   | 63       | 3FF000H-3FFFFFH | 4KB     | Top Block    |  |
| 1   | 0                                             | 0       | 1      | 0   | 63       | 3FE000H-3FFFFFH | 8KB     | Top Block    |  |
| 1   | 0                                             | 0       | 1      | 1   | 63       | 3FC000H-3FFFFFH | 16KB    | Top Block    |  |
| 1   | 0                                             | 1       | 0      | Х   | 63       | 3F8000H-3FFFFFH | 32KB    | Top Block    |  |
| 1   | 0                                             | 1       | 1      | 0   | 63       | 3F8000H-3FFFFFH | 32KB    | Top Block    |  |
| 1   | 1                                             | 0       | 0      | 1   | 0        | 000000H-000FFFH | 4KB     | Bottom Block |  |
| 1   | 1                                             | 0       | 1      | 0   | 0        | 000000H-001FFFH | 8KB     | Bottom Block |  |
| 1   | 1                                             | 0       | 1      | 1   | 0        | 000000H-003FFFH | 16KB    | Bottom Block |  |
| 1   | 1                                             | 1       | 0      | Х   | 0        | 000000H-007FFFH | 32KB    | Bottom Block |  |



**GD25R32C** 

Table 3. GD25R32C Protected area size (CMP=1)

| ;   | Status Register Content |     |     |     |          | Protected area size (CMP=1)  Memory Conte | nt      |             |
|-----|-------------------------|-----|-----|-----|----------|-------------------------------------------|---------|-------------|
| BP4 | BP3                     | BP2 | BP1 | BP0 | Blocks   | Addresses                                 | Density | Portion     |
| Х   | Х                       | 0   | 0   | 0   | ALL      | 000000H-3FFFFFH                           | 4MB     | ALL         |
| 0   | 0                       | 0   | 0   | 1   | 0 to 62  | 000000H-3EFFFFH                           | 4032KB  | Lower 63/64 |
| 0   | 0                       | 0   | 1   | 0   | 0 to 61  | 000000H-3DFFFFH                           | 3968KB  | Lower 31/32 |
| 0   | 0                       | 0   | 1   | 1   | 0 to 59  | 000000H-3BFFFFH                           | 3840KB  | Lower 15/16 |
| 0   | 0                       | 1   | 0   | 0   | 0 to 55  | 000000H-37FFFFH                           | 3584KB  | Lower 7/8   |
| 0   | 0                       | 1   | 0   | 1   | 0 to 47  | 000000H-2FFFFFH                           | 3MB     | Lower 3/4   |
| 0   | 0                       | 1   | 1   | 0   | 0 to 31  | 000000H-1FFFFFH                           | 2MB     | Lower 1/2   |
| 0   | 1                       | 0   | 0   | 1   | 1 to 63  | 010000H-3FFFFFH                           | 4032KB  | Upper 63/64 |
| 0   | 1                       | 0   | 1   | 0   | 2 to 63  | 020000H-3FFFFFH                           | 3968KB  | Upper 31/32 |
| 0   | 1                       | 0   | 1   | 1   | 4 to 63  | 040000H-3FFFFFH                           | 3840KB  | Upper 15/16 |
| 0   | 1                       | 1   | 0   | 0   | 8 to 63  | 080000H-3FFFFFH                           | 3584KB  | Upper 7/8   |
| 0   | 1                       | 1   | 0   | 1   | 16 to 63 | 100000H-3FFFFFH                           | 3MB     | Upper 3/4   |
| 0   | 1                       | 1   | 1   | 0   | 32 to 63 | 200000H-3FFFFFH                           | 2MB     | Upper 1/2   |
| Х   | Х                       | 1   | 1   | 1   | NONE     | NONE                                      | NONE    | NONE        |
| 1   | 0                       | 0   | 0   | 1   | 0 to 63  | 000000H-3FEFFFH                           | 4092KB  | L-1023/1024 |
| 1   | 0                       | 0   | 1   | 0   | 0 to 63  | 000000H-3FDFFFH                           | 4088KB  | L-511/512   |
| 1   | 0                       | 0   | 1   | 1   | 0 to 63  | 000000H-3FBFFFH                           | 4080KB  | L-255/256   |
| 1   | 0                       | 1   | 0   | Х   | 0 to 63  | 000000H-3F7FFFH                           | 4064KB  | L-127/128   |
| 1   | 0                       | 1   | 1   | 0   | 0 to 63  | 000000H-3F7FFFH                           | 4064KB  | L-127/128   |
| 1   | 1                       | 0   | 0   | 1   | 0 to 63  | 001000H-3FFFFFH                           | 4092KB  | U-1023/1024 |
| 1   | 1                       | 0   | 1   | 0   | 0 to 63  | 002000H-3FFFFFH                           | 4088KB  | U-511/512   |
| 1   | 1                       | 0   | 1   | 1   | 0 to 63  | 004000H-3FFFFFH                           | 4080KB  | U-255/256   |
| 1   | 1                       | 1   | 0   | Х   | 0 to 63  | 008000H-3FFFFFH                           | 4064KB  | U-127/128   |
| 1   | 1                       | 1   | 1   | 0   | 0 to 63  | 008000H-3FFFFFH                           | 4064KB  | U-127/128   |



#### **6 STATUS REGISTER**

Table 4. Status Register-SR No.1

| No. | Name | Description                    | Note                  |
|-----|------|--------------------------------|-----------------------|
| S7  | SRP0 | Status Register Protection Bit | Non-volatile writable |
| S6  | BP4  | Block Protect Bit              | Non-volatile writable |
| S5  | BP3  | Block Protect Bit              | Non-volatile writable |
| S4  | BP2  | Block Protect Bit              | Non-volatile writable |
| S3  | BP1  | Block Protect Bit              | Non-volatile writable |
| S2  | BP0  | Block Protect Bit              | Non-volatile writable |
| S1  | WEL  | Write Enable Latch             | Volatile, read only   |
| S0  | WIP  | Erase/Write In Progress        | Volatile, read only   |

Table 5. Status Register-SR No.2

| No. | Name | Description                    | Note                        |
|-----|------|--------------------------------|-----------------------------|
| S15 | SUS1 | Erase Suspend Bit              | Volatile, read only         |
| S14 | CMP  | Complement Protect Bit         | Non-volatile writable       |
| S13 | LB3  | Security Register Lock Bit     | Non-volatile writable (OTP) |
| S12 | LB2  | Security Register Lock Bit     | Non-volatile writable (OTP) |
| S11 | LB1  | Security Register Lock Bit     | Non-volatile writable (OTP) |
| S10 | SUS2 | Program Suspend Bit            | Volatile, read only         |
| S9  | QE   | Quad Enable Bit                | QE = 1 permanently          |
| S8  | SRP1 | Status Register Protection Bit | Non-volatile writable       |

Table 6. Status Register-SR No.3

| No. | Name     | Description                | Note                  |
|-----|----------|----------------------------|-----------------------|
| S23 | Reserved | Reserved                   | Reserved              |
| S22 | DRV1     | Output Driver Strength Bit | Non-volatile writable |
| S21 | DRV0     | Output Driver Strength Bit | Non-volatile writable |
| S20 | HPF      | High Performance Flag Bit  | Volatile, read only   |
| S19 | Reserved | Reserved                   | Reserved              |
| S18 | Reserved | Reserved                   | Reserved              |
| S17 | Reserved | Reserved                   | Reserved              |
| S16 | Reserved | Reserved                   | Reserved              |

The status and control bits of the Status Register are as follows:

#### WIP bit

The Write in Progress (WIP) bit indicates whether the memory is busy in program/erase/write status register progress. When WIP bit sets to 1, means the device is busy in program/erase/write status register progress, when WIP bit sets 0, means the device is not in program/erase/write status register progress.



#### **WEL** bit

The Write Enable Latch (WEL) bit indicates the status of the internal Write Enable Latch. When set to 1 the internal Write Enable Latch is set, when set to 0 the internal Write Enable Latch is reset and no Write Status Register, Program or Erase command is accepted.

#### BP4, BP3, BP2, BP1, BP0 bits

The Block Protect (BP4, BP3, BP2, BP1, and BP0) bits are non-volatile. They define the size of the area to be software protected against Program and Erase commands. These bits are written with the Write Status Register (WRSR) command. When the Block Protect (BP4, BP3, BP2, BP1, BP0) bits are set to 1, the relevant memory area (as defined in Table 2&3) becomes protected against Page Program (PP), Sector Erase (SE) and Block Erase (BE) commands. The Chip Erase (CE) command is executed, if the Block Protect (BP2, BP1, and BP0) bits are 0 and CMP=0 or the Block Protect (BP2, BP1, and BP0) bits are 1 and CMP=1.

#### SRP1, SRP0 bits

The Status Register Protect (SRP1 and SRP0) bits are non-volatile Read/Write bits in the status register. The SRP bits control the method of write protection: software protection, power supply lock-down or one time programmable protection.

| SRP1 | SRP0 | Status Register                            | Description                                                                         |
|------|------|--------------------------------------------|-------------------------------------------------------------------------------------|
| 0    | 0    | Software Protected                         | The Status Register can be written to after a Write Enable command, WEL=1.(Default) |
|      |      |                                            | Confinanc, WEL=1.(Delauit)                                                          |
| 1    | 0    | 0 Power Supply Lock-Down <sup>(1)(2)</sup> | Status Register is protected and cannot be written to again until                   |
| '    |      | Tower Supply Lock-Down                     | the next Power-Down, Power-Up cycle.                                                |
| 1    | 1    | 1 One Time Program <sup>(2)</sup>          | Status Register is permanently protected and cannot be written                      |
|      |      |                                            | to.                                                                                 |

#### NOTE:

- 1. When SRP1, SRP0= (1, 0), a Power-Down, Power-Up cycle will change SRP1, SRP0 to (0, 0) state.
- 2. This feature is available on special order. Please contact GigaDevice for details.

#### QE bit

The Quad Enable (QE) bit is a non-volatile bit in the Status Register that allows Quad operation. The default value of QE bit is 1 and it cannot be changed, so that the IO2 and IO3 pins are enabled all the time.

#### LB3, LB2, LB1 bits

The LB3, LB2 and LB1 bits are non-volatile One Time Program (OTP) bits in Status Register (S13, S12 and S11) that provide the write protect control and status to the Security Registers. The default state of LB3, LB2 and LB1 bits are 0, the security registers are unlocked. The LB3, LB2 and LB1 bits can be set to 1 individually using the Write Register instruction. The LB3, LB2 and LB1 bits are One Time Programmable, once they are set to 1, the Security Registers will become read-only permanently.

#### **CMP** bit

The CMP bit is a non-volatile Read/Write bit in the Status Register (S14). It is used in conjunction with the BP4-BP0 bits to provide more flexibility for the array protection. Please see the Status registers Memory Protection table for details. The default setting is CMP=0.

**GD25R32C** 

#### SUS1, SUS2 bits

The SUS1 and SUS2 bits are read only bits in the status register (S15 and S10) that are set to 1 after executing an Erase/Program Suspend (75H) command (The Erase Suspend will set the SUS1 bit to 1, and the Program Suspend will set the SUS2 bit to 1). The SUS1 and SUS2 bits are cleared to 0 by Erase/Program Resume (7AH) command, software reset (66H+99H) command, as well as a power-down, power-up cycle.

#### **HPF** bit

The High Performance Flag (HPF) bit is read only bit, that indicates the status of High Performance Mode (HPM). When HPF bit is set to 1, it means the device is in High Performance Mode, When HPF bit is set to 0 (default), it means the device is not in High Performance Mode.

#### DRV1, DRV0 bits

The DRV1 and DRV0 bits are used to determine the output driver strength for the Read operations.

**Table 7. Driver Strength for Read Operations** 

| DRV1, DRV0 | Driver Strength |
|------------|-----------------|
| 00         | 100%            |
| 01         | 75% (default)   |
| 10         | 50%             |
| 11         | 25%             |

#### Reserved bit

It is recommended to set the value of the reserved bit as "0".

#### 7 COMMAND DESCRIPTIONS

All commands, addresses and data are shifted in and out of the device, beginning with the most significant bit on the first rising edge of SCLK after CS# is driven low. Then, the one-byte command code must be shifted in to the device, with most significant bit first on SI, and each bit is latched on the rising edges of SCLK.

Every command sequence starts with a one-byte command code. Depending on the command, this might be followed by address bytes, or by data bytes, or by both or none. CS# must be driven high after the last bit of the command sequence has been completed. For the command of Read, Fast Read, Read Status Register or Release from Deep Power-Down, and Read Device ID, the shifted-in command sequence is followed by a data-out sequence. All read instruction can be completed after any bit of the data-out sequence is being shifted out, and then CS# must be driven high to return to deselected status.

For the command of Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register, Write Enable, Write Disable or Deep Power-Down command, CS# must be driven high exactly at a byte boundary, otherwise the command is rejected, and is not executed. That is CS# must be driven high when the number of clock pulses after CS# being driven low is an exact multiple of eight. For Page Program, if at any time the input byte is not a full byte, nothing will happen and WEL will not be reset.

**Table 8. Commands** 

| Command Name                | Byte 1 | Byte 2                 | Byte 3                | Byte 4               | Byte 5               | Byte 6                 | Byte 7  | Byte 8                 | Byte 9  |
|-----------------------------|--------|------------------------|-----------------------|----------------------|----------------------|------------------------|---------|------------------------|---------|
| Write Enable                | 06H    |                        |                       |                      |                      |                        |         |                        |         |
| Write Disable               | 04H    |                        |                       |                      |                      |                        |         |                        |         |
| Read Status Register-1      | 05H    | (S7-S0)                | (cont.)               |                      |                      |                        |         |                        |         |
| Read Status Register-2      | 35H    | (S15-S8)               | (cont.)               |                      |                      |                        |         |                        |         |
| Read Status Register-3      | 15H    | (S23-S16)              | (cont.)               |                      |                      |                        |         |                        |         |
| Write Status Register-1     | 01H    | S7-S0                  |                       |                      |                      |                        |         |                        |         |
| Write Status Register-2     | 31H    | S15-S8                 |                       |                      |                      |                        |         |                        |         |
| Write Status Register-3     | 11H    | S23-S16                |                       |                      |                      |                        |         |                        |         |
| Volatile SR write<br>Enable | 50H    |                        |                       |                      |                      |                        |         |                        |         |
| Read Data                   | 03H    | A23-A16                | A15-A8                | A7-A0                | (D7-D0)              | (cont.)                |         |                        |         |
| Fast Read                   | 0BH    | A23-A16                | A15-A8                | A7-A0                | dummy                | (D7-D0)                | (cont.) |                        |         |
| Dual Output Fast Read       | 3ВН    | A23-A16                | A15-A8                | A7-A0                | dummy                | (D7-D0) <sup>(1)</sup> | (cont.) |                        |         |
| Quad Output Fast<br>Read    | 6BH    | A23-A16                | A15-A8                | A7-A0                | dummy                | (D7-D0) <sup>(2)</sup> | (cont.) |                        |         |
| Dual I/O Fast Read          | BBH    | A23-A16 <sup>(3)</sup> | A15-A8 <sup>(3)</sup> | A7-A0 <sup>(3)</sup> | M7-M0 <sup>(4)</sup> | (D7-D0) <sup>(1)</sup> | (cont.) |                        |         |
| Quad I/O Fast Read          | EBH    | A23-A16 <sup>(5)</sup> | A15-A8 <sup>(5)</sup> | A7-A0 <sup>(5)</sup> | M7-M0 <sup>(6)</sup> | dummy                  | dummy   | (D7-D0) <sup>(2)</sup> | (cont.) |
| Set Burst with Wrap         | 77H    | dummy <sup>(7)</sup>   | dummy <sup>(7)</sup>  | dummy <sup>(7)</sup> | W7-W0 <sup>(7)</sup> |                        |         |                        |         |
| Page Program                | 02H    | A23-A16                | A15-A8                | A7-A0                | D7-D0                | Next Byte              |         |                        |         |



# **GD25R32C**

| Quad Page Program                                     | 32H    | A23-A16         | A15-A8     | A7-A0     | D7-D0 <sup>(9)</sup> | Next Byte       |         |  |
|-------------------------------------------------------|--------|-----------------|------------|-----------|----------------------|-----------------|---------|--|
| Sector Erase                                          | 20H    | A23-A16         | A15-A8     | A7-A0     |                      |                 |         |  |
| Block Erase (32K)                                     | 52H    | A23-A16         | A15-A8     | A7-A0     |                      |                 |         |  |
| Block Erase (64K)                                     | D8H    | A23-A16         | A15-A8     | A7-A0     |                      |                 |         |  |
| Chip Erase                                            | C7/60H |                 |            |           |                      |                 |         |  |
| High Performance<br>Mode                              | АЗН    | dummy           | dummy      | dummy     |                      |                 |         |  |
| Read Manufacturer/<br>Device ID                       | 90H    | 00H             | 00H        | 00H       | (MID7-<br>MID0)      | (ID7-ID0)       | (cont.) |  |
| Read Identification                                   | 9FH    | (MID7-<br>MID0) | (ID15-ID8) | (ID7-ID0) | (cont.)              |                 |         |  |
| Read Unique ID                                        | 4BH    | 00H             | 00H        | 00H       | dummy                | (UID7-<br>UID0) | (cont.) |  |
| Erase Security Registers <sup>(10)</sup>              | 44H    | A23-A16         | A15-A8     | A7-A0     |                      |                 |         |  |
| Program Security<br>Registers <sup>(10)</sup>         | 42H    | A23-A16         | A15-A8     | A7-A0     | D7-D0                | Next Byte       |         |  |
| Read Security<br>Registers <sup>(10)</sup>            | 48H    | A23-A16         | A15-A8     | A7-A0     | dummy                | (D7-D0)         | (cont.) |  |
| Enable Reset                                          | 66H    |                 |            |           |                      |                 |         |  |
| Reset                                                 | 99H    |                 |            |           |                      |                 |         |  |
| Program/Erase<br>Suspend                              | 75H    |                 |            |           |                      |                 |         |  |
| Program/Erase<br>Resume                               | 7AH    |                 |            |           |                      |                 |         |  |
| Deep Power-Down                                       | В9Н    |                 |            |           |                      |                 |         |  |
| Release From Deep<br>Power-Down                       | ABH    |                 |            |           |                      |                 |         |  |
| Release From Deep<br>Power-Down and Read<br>Device ID | АВН    | dummy           | dummy      | dummy     | (ID7-ID0)            | (cont.)         |         |  |
| Read Serial Flash<br>Discoverable<br>Parameter        | 5AH    | A23-A16         | A15-A8     | A7-A0     | dummy                | (D7-D0)         | (cont.) |  |

#### Note:

1. Dual Output data

IO0 = (D6, D4, D2, D0)

IO1 = (D7, D5, D3, D1)

2. Quad Output Data

IO0 = (D4, D0, ...)

IO1 = (D5, D1, ...)

IO2 = (D6, D2, ...)

IO3 = (D7, D3, ...)

3. Dual Input Address

IO0 = A22, A20, A18, A16, A14, A12, A10, A8 A6, A4, A2, A0

IO1 = A23, A21, A19, A17, A15, A13, A11, A9 A7, A5, A3, A1

4. Dual Input Mode bit

IO0 = M6, M4, M2, M0

IO1 = M7, M5, M3, M1

5. Quad Input Address

IO0 = A20, A16, A12, A8, A4, A0

IO1 = A21, A17, A13, A9, A5, A1

IO2 = A22, A18, A14, A10, A6, A2

IO3 = A23, A19, A15, A11, A7, A3

6. Quad Input Mode bit

IO0 = M4, M0

IO1 = M5, M1

102 = M6, M2

103 = M7, M3

7. Dummy bits and Wrap Bits

IO0 = (x, x, x, x, x, x, W4, x)

IO1 = (x, x, x, x, x, x, W5, x)

IO2 = (x, x, x, x, x, x, W6, x)

IO3 = (x, x, x, x, x, x, x, x)

8. Fast Word Read Quad I/O Data: the lowest address bit must be 0.

9. Quad Output Data

IO0 = D4, D0, ...

IO1 = D5, D1, ...

IO2 = D6, D2, ...

IO3 = D7, D3, ...

10. Security Registers Address

Security Register1: A23-A16=00H, A15-A12=1H, A11-A10 = 00b, A9-A0= Byte Address;

Security Register2: A23-A16=00H, A15-A12=2H, A11-A10 = 00b, A9-A0= Byte Address;

Security Register3: A23-A16=00H, A15-A12=3H, A11-A10 = 00b, A9-A0= Byte Address;

#### TABLE OF ID DEFINITIONS

#### **GD25R32C**

| Operation Code | MID7-MID0 | ID15-ID8 | ID7-ID0 |
|----------------|-----------|----------|---------|
| 9FH            | C8        | 40       | 16      |
| 90H            | C8        |          | 15      |
| ABH            |           |          | 15      |



### 7.1 Write Enable (WREN) (06H)

The Write Enable (WREN) command is for setting the Write Enable Latch (WEL) bit. The Write Enable Latch (WEL) bit must be set prior to every Page Program (PP), Quad Page Program (QPP), Sector Erase (SE), Block Erase (BE), Chip Erase (CE), Write Status Register (WRSR) and Erase/Program Security Registers command.

The Write Enable (WREN) command sequence: CS# goes low → sending the Write Enable command → CS# goes high.

CS#

0 1 2 3 4 5 6 7

SCLK Command Command High-Z

SO High-Z

Figure 1. Write Enable Sequence Diagram

### 7.2 Write Disable (WRDI) (04H)

The Write Disable command is for resetting the Write Enable Latch (WEL) bit. The Write Enable Latch (WEL) bit may be set to 0 by issuing the Write Disable (WRDI) command to disable Page Program (PP), Quad Page Program (QPP), Sector Erase (SE), Block Erase (BE), Chip Erase (CE), Write Status Register (WRSR), that require WEL be set to 1 for execution. The WRDI command can be used by the user to protect memory areas against inadvertent writes that can possibly corrupt the contents of the memory. The WRDI command is ignored during an embedded operation while WIP bit =1.

The WEL bit is reset by following condition: Write Disable command (WRDI), Power-up, and upon completion of the Write Status Register, Page Program, Sector Erase, Block Erase and Chip Erase commands.

The Write Disable command sequence: CS# goes low →Sending the Write Disable command →CS# goes high.



Figure 2. Write Disable Sequence Diagram

### 7.3 Read Status Register (RDSR) (05H or 35H or 15H)

The Read Status Register (RDSR) command is for reading the Status Register. The Status Register may be read at any time, even while a Program, Erase or Write Status Register cycle is in progress. When one of these cycles is in progress, it is recommended to check the Write in Progress (WIP) bit before sending a new command to the device. It is also possible to read the Status Register continuously. For command code of "05H" / "35H" / "15H", the SO will output Status Register bits \$7~\$0 / \$15~\$8 / \$23~\$16.

CS# 3 9 10 11 12 13 14 15 16 17 18 19 20 21 **SCLK** Command 05H or 35H or 15H SI Status Register 1/2/3 Status Register 1/2/3 High-Z (3) (0) (7)SO (6X5X4) MSB **MSB** 

Figure 3. Read Status Register Sequence Diagram

### 7.4 Write Status Register (WRSR) (01H or 31H or 11H)

The Write Status Register (WRSR) command allows new values to be written to the Status Register. Before it can be accepted, a Write Enable (WREN) command must previously have been executed. After the Write Enable (WREN) command has been decoded and executed, the device sets the Write Enable Latch (WEL).

The Write Status Register (WRSR) command has no effect on S20, S15, S10, S9, S1 and S0 of the Status Register. For command code of "01H" / "31H" / "11H", the Status Register bits S7~S0 / S15~S8 / S23~S16 would be written. CS# must be driven high after the eighth bit of the data byte has been latched in. Otherwise, the Write Status Register (WRSR) command is not executed. As soon as CS# is driven high, the self-timed Write Status Register cycle (whose duration is tw) is initiated. While the Write Status Register cycle is in progress, the Status Register may still be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Write Status Register cycle, and is 0 when it is completed. When the cycle is completed, the Write Enable Latch (WEL) is reset.

The Write Status Register (WRSR) command allows the user to change the values of the Block Protect (BP4, BP3, BP2, BP1, and BP0) bits, to define the size of the area that is to be treated as read-only.



Figure 4. Write Status Register Sequence Diagram

### 7.5 Write Enable for Volatile Status Register (50H)

The non-volatile Status Register bits can also be written to as volatile bits. This gives more flexibility to change the system configuration and memory protection schemes quickly without waiting for the typical non-volatile bit write cycles or affecting the endurance of the Status Register non-volatile bits. The Write Enable for Volatile Status Register command must be issued prior to a Write Status Register command and any other commands can't be inserted between them. Otherwise, Write Enable for Volatile Status Register will be cleared. The Write Enable for Volatile Status Register command will not set the Write Enable Latch bit, it is only valid for the Write Status Register command to change the volatile Status Register bit values.

Figure 5. Write Enable for Volatile Status Register Sequence Diagram



### 7.6 Read Data Bytes (READ) (03H)

The Read Data Bytes (READ) command is followed by a 3-byte address (A23-A0), and each bit is latched-in on the rising edge of SCLK. Then the memory content, at that address, is shifted out on SO, and each bit is shifted out, at a Max frequency f<sub>R</sub>, on the falling edge of SCLK. The first byte addressed can be at any location. The address is automatically incremented to the next higher address after each byte of data is shifted out. The whole memory can, therefore, be read with a single Read Data Bytes (READ) command. Any Read Data Bytes (READ) command, while an Erase, Program or Write cycle is in progress, is rejected without having any effects on the cycle that is in progress.

Figure 6. Read Data Bytes Sequence Diagram



## 7.7 Read Data Bytes at Higher Speed (Fast Read) (0BH)

The Read Data Bytes at Higher Speed (Fast Read) command is for quickly reading data out. It is followed by a 3-byte address (A23-A0) and a dummy byte, and each bit is latched-in on the rising edge of SCLK. Then the memory content, at that address, is shifted out on SO, and each bit is shifted out, at a Max frequency f<sub>C</sub>, on the falling edge of SCLK. The first byte address can be at any location. The address is automatically incremented to the next higher address after each byte of data is shifted out.



Figure 7. Read Data Bytes at Higher Speed Sequence Diagram

### 7.8 Dual Output Fast Read (3BH)

The Dual Output Fast Read command is followed by 3-byte address (A23-A0) and a dummy byte, and each bit is latched in on the rising edge of SCLK, then the memory contents are shifted out 2-bit per clock cycle from SI and SO.

The first byte addressed can be at any location. The address is automatically incremented to the next higher address after each byte of data is shifted out.



Figure 8. Dual Output Fast Read Sequence Diagram

### 7.9 Quad Output Fast Read (6BH)

The Quad Output Fast Read command is followed by 3-byte address (A23-A0) and a dummy byte, and each bit is latched in on the rising edge of SCLK, then the memory contents are shifted out 4-bit per clock cycle from IO3, IO2, IO1 and IO0. The first byte addressed can be at any location. The address is automatically incremented to the next higher address after each byte of data is shifted out.



Figure 9. Quad Output Fast Read Sequence Diagram

### 7.10 Dual I/O Fast Read (BBH)

The Dual I/O Fast Read command is similar to the Dual Output Fast Read command but with the capability to input the 3-byte address (A23-0) and a "Continuous Read Mode" byte 2-bit per clock by SI and SO, and each bit is latched in on the rising edge of SCLK, then the memory contents are shifted out 2-bit per clock cycle from SI and SO. The first byte addressed can be at any location. The address is automatically incremented to the next higher address after each byte of data is shifted out.

"Continuous Read Mode" bits must NOT be set as (M5-4) = (1, 0)



Figure 10. Dual I/O Fast Read Sequence Diagram ((M5-4) ≠ (1, 0))

### 7.11 Quad I/O Fast Read (EBH)

The Quad I/O Fast Read command is similar to the Dual I/O Fast Read command but with the capability to input the 3-byte address (A23-0) and a "Continuous Read Mode" byte and 4-dummy clock 4-bit per clock by IO0, IO1, IO2, IO3, and each bit is latched in on the rising edge of SCLK, then the memory contents are shifted out 4-bit per clock cycle from IO0, IO1, IO2, IO3. The first byte addressed can be at any location. The address is automatically incremented to the next higher address after each byte of data is shifted out.

"Continuous Read Mode" bits must NOT be set as (M5-4) = (1, 0)

CS# 13 18 19 20 21 12 16 **SCLK** Command IO0 **EBH IO1** IO<sub>2</sub> **IO3** A23-16 | A15-8 | A7-0 | M7-0 Dummy Byte1 Byte2

Figure 11. Quad I/O Fast Read Sequence Diagram ((M5-4) ≠ (1, 0))

#### Quad I/O Fast Read with "8/16/32/64-Byte Wrap Around" in Standard SPI mode

The Quad I/O Fast Read command can be used to access a specific portion within a page by issuing "Set Burst with Wrap" (77H) commands prior to EBH. The "Set Burst with Wrap" (77H) command can either enable or disable the "Wrap Around"

feature for the following EBH commands. When "Wrap Around" is enabled, the data being accessed can be limited to either an 8/16/32/64-byte section of a 256-byte page. The output data starts at the initial address specified in the command, once it reaches the ending boundary of the 8/16/32/64-byte section, the output will wrap around the beginning boundary automatically until CS# is pulled high to terminate the command.

The Burst with Wrap feature allows applications that use cache to quickly fetch a critical address and then fill the cache afterwards within a fixed length (8/16/32/64-byte) of data without issuing multiple read commands. The "Set Burst with Wrap" command allows three "Wrap Bits" W6-W4 to be set. The W4 bit is used to enable or disable the "Wrap Around" operation while W6-W5 is used to specify the length of the wrap around section within a page.

### 7.12 Set Burst with Wrap (77H)

The Set Burst with Wrap command is used in conjunction with "Quad I/O Fast Read" command to access a fixed length of 8/16/32/64-byte section within a 256-byte page, in standard SPI mode.

The Set Burst with Wrap command sequence: CS# goes low  $\rightarrow$  Send Set Burst with Wrap command  $\rightarrow$  Send 24 dummy bits  $\rightarrow$  Send 8 bits "Wrap bits"  $\rightarrow$  CS# goes high.

| MC ME |             | l=0         | W4=1 (default) |             |  |
|-------|-------------|-------------|----------------|-------------|--|
| W6,W5 | Wrap Around | Wrap Length | Wrap Around    | Wrap Length |  |
| 0, 0  | Yes         | 8-byte      | No             | N/A         |  |
| 0, 1  | Yes         | 16-byte     | No             | N/A         |  |
| 1, 0  | Yes         | 32-byte     | No             | N/A         |  |
| 1, 1  | Yes         | 64-byte     | No             | N/A         |  |

If the W6-W4 bits are set by the Set Burst with Wrap command, all the following "Quad I/O Fast Read" command will use the W6-W4 setting to access the 8/16/32/64-byte section within any page. To exit the "Wrap Around" function and return to normal read operation, another Set Burst with Wrap command should be issued to set W4=1.

CS#

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

SCLK

Command

77H

XXXXXXXXX

IO1

IO2

XXXXXXXX

IO3

XXXXXXXX

W6-W4

Figure 12. Set Burst with Wrap Sequence Diagram

# 7.13 Page Program (PP) (02H)

The Page Program (PP) command is for programming the memory. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the Page Program command.

The Page Program (PP) command is entered by driving CS# Low, followed by the command code, three address bytes and at least one data byte on SI. If the 8 least significant address bits (A7-A0) are not all zero, all transmitted data that goes

beyond the end of the current page are programmed from the start address of the same page (from the address whose 8 least significant bits (A7-A0) are all zero). CS# must be driven low for the entire duration of the sequence. The Page Program command sequence: CS# goes low  $\rightarrow$  sending Page Program command  $\rightarrow$  3-byte address on SI  $\rightarrow$  at least 1 byte data on SI  $\rightarrow$  CS# goes high. If more than 256 bytes are sent to the device, previously latched data are discarded and the last 256 data bytes are guaranteed to be programmed correctly within the same page. If less than 256 data bytes are sent to device, they are correctly programmed at the requested addresses without having any effects on the other bytes of the same page. CS# must be driven high after the eighth bit of the last data byte has been latched in; otherwise the Page Program (PP) command is not executed.

As soon as CS# is driven high, the self-timed Page Program cycle (whose duration is tpp) is initiated. While the Page Program cycle is in progress, the Status Register may be read to check the value of the Write in Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Page Program cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset.

A Page Program (PP) command applied to a page which is protected by the Block Protect (BP4, BP3, BP2, BP1, and BP0) is not executed.



Figure 13. Page Program Sequence Diagram

#### 7.14 Quad Page Program (32H)

The Quad Page Program command is for programming the memory using four pins: IO0, IO1, IO2, and IO3. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the Page Program command. The quad Page Program command is entered by driving CS# Low, followed by the command code (32H), three address bytes and at least one data byte on IO pins.

If more than 256 bytes are sent to the device, previously latched data are discarded and the last 256 data bytes are guaranteed to be programmed correctly within the same page. If less than 256 data bytes are sent to device, they are correctly programmed at the requested addresses without having any effects on the other bytes of the same page. CS# must be driven high after the eighth bit of the last data byte has been latched in; otherwise the Quad Page Program (PP) command is not executed.

As soon as CS# is driven high, the self-timed Quad Page Program cycle (whose duration is tpp) is initiated. While the Quad Page Program cycle is in progress, the Status Register may be read to check the value of the Write In Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Quad Page Program cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset.

A Quad Page Program command applied to a page which is protected by the Block Protect (BP4, BP3, BP2, BP1, and BP0)

is not executed.

Figure 14. Quad Page Program Sequence Diagram



#### 7.15 Sector Erase (SE) (20H)

The Sector Erase (SE) command is for erasing the all data of the chosen sector. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit. The Sector Erase (SE) command is entered by driving CS# low, followed by the command code, and 3-address byte on SI. Any address inside the sector is a valid address for the Sector Erase (SE) command. CS# must be driven low for the entire duration of the sequence.

The Sector Erase command sequence: CS# goes low  $\rightarrow$  sending Sector Erase command  $\rightarrow$  3-byte address on SI  $\rightarrow$  CS# goes high. CS# must be driven high after the eighth bit of the last address byte has been latched in; otherwise the Sector Erase (SE) command is not executed. As soon as CS# is driven high, the self-timed Sector Erase cycle (whose duration is  $t_{SE}$ ) is initiated. While the Sector Erase cycle is in progress, the Status Register may be read to check the value of the Write in Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Sector Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A Sector Erase (SE) command applied to a sector which is protected by the Block Protect (BP4, BP3, BP2, BP1, and BP0) bit is not executed.

CS#

0 1 2 3 4 5 6 7 8 9 29 30 31

SCLK

Command

Command

24 Bits Address

SI

MSB

Figure 15. Sector Erase Sequence Diagram

### 7.16 32KB Block Erase (BE32) (52H)

The 32KB Block Erase command is for erasing the all data of the chosen block. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit. The 32KB Block Erase command is entered by driving CS# low, followed by the command code, and three address bytes on SI. Any address inside the block is a valid address for the 32KB Block Erase command. CS# must be driven low for the entire duration of the sequence.

The 32KB Block Erase command sequence: CS# goes low → sending 32KB Block Erase command → 3-byte address on

 $SI \rightarrow CS\#$  goes high. CS# must be driven high after the eighth bit of the last address byte has been latched in; otherwise the 32KB Block Erase command is not executed. As soon as CS# is driven high, the self-timed Block Erase cycle (whose duration is  $t_{BE1}$ ) is initiated. While the Block Erase cycle is in progress, the Status Register may be read to check the value of the Write in Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Block Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A 32KB Block Erase command applied to a block which is protected by the Block Protect (BP4, BP3, BP2, BP1, and BP0) bits is not executed.

CS#

0 1 2 3 4 5 6 7 8 9 29 30 31

SCLK Command 24 Bits Address

SI 52H 23 22 - - - 2 1 0 MSB

Figure 16. 32KB Block Erase Sequence Diagram

### 7.17 64KB Block Erase (BE64) (D8H)

The 64KB Block Erase command is for erasing the all data of the chosen block. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit. The 64KB Block Erase command is entered by driving CS# low, followed by the command code, and three address bytes on SI. Any address inside the block is a valid address for the 64KB Block Erase command. CS# must be driven low for the entire duration of the sequence.

The 64KB Block Erase command sequence: CS# goes low  $\rightarrow$  sending 64KB Block Erase command  $\rightarrow$  3-byte address on SI  $\rightarrow$  CS# goes high. CS# must be driven high after the eighth bit of the last address byte has been latched in; otherwise the 64KB Block Erase command is not executed. As soon as CS# is driven high, the self-timed Block Erase cycle (whose duration is  $t_{BE2}$ ) is initiated. While the Block Erase cycle is in progress, the Status Register may be read to check the value of the Write in Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Block Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A 64KB Block Erase command applied to a block which is protected by the Block Protect (BP4, BP3, BP2, BP1, and BP0) bits is not executed.



Figure 17. 64KB Block Erase Sequence Diagram

### 7.18 Chip Erase (CE) (60/C7H)

The Chip Erase (CE) command is for erasing the all data of the chip. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit .The Chip Erase (CE) command is entered by driving CS# Low, followed by the command code on Serial Data Input (SI). CS# must be driven Low for the entire duration of the sequence.

The Chip Erase command sequence: CS# goes low → sending Chip Erase command → CS# goes high. CS# must be

driven high after the eighth bit of the command code has been latched in; otherwise the Chip Erase command is not executed. As soon as CS# is driven high, the self-timed Chip Erase cycle (whose duration is tcE) is initiated. While the Chip Erase cycle is in progress, the Status Register may be read to check the value of the Write in Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Chip Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. The Chip Erase (CE) command is executed, if the Block Protect (BP2, BP1, and BP0) bits are 0 and CMP=0 or the Block Protect (BP2, BP1, and BP0) bits are 1 and CMP=1. The Chip Erase (CE) command is ignored if one or more sectors are protected.

Figure 18. Chip Erase Sequence Diagram



### 7.19 High Performance Mode (HPM) (A3H)

The High Performance Mode (HPM) command must be executed prior to Dual or Quad I/O commands when operating at high frequencies (see  $f_R$  and  $f_{C2}$  in AC Electrical Characteristics). This command allows pre-charging of internal charge pumps so the voltages required for accessing the flash memory array are readily available. The command sequence: CS# goes Iow $\rightarrow$ Sending A3H command $\rightarrow$  Sending 3-dummy Byte $\rightarrow$ CS# goes high. After the HPM command is executed, HPF bit of status register will be set to 1, the device will maintain a slightly higher standby current (ICC9) than standard SPI operation. The Release from Power-Down or HPM command (ABH) can be used to return to standard SPI standby current (ICC1). In addition, Power-Down command (B9H) will release the device from HPM mode back to deep-power-down state.

Figure 19. High Performance Mode Sequence Diagram



### 7.20 Read Manufacture ID/ Device ID (REMS) (90H)

The Read Manufacturer/Device ID command is an alternative to the Release from Power-Down / Device ID command that provides both the JEDEC assigned Manufacturer ID and the specific Device ID.

The command is initiated by driving the CS# pin low and shifting the command code "90H" followed by a 24-bit address (A23-A0) of 000000H. After which, the Manufacturer ID and the Device ID are shifted out on the falling edge of SCLK with most significant bit (MSB) first.



Figure 20. Read Manufacture ID/ Device ID Sequence Diagram

#### 7.21 Read Identification (RDID) (9FH)

The Read Identification (RDID) command allows the 8-bit manufacturer identification to be read, followed by two bytes of device identification. The device identification indicates the memory type in the first byte, and the memory capacity of the device in the second byte. The Read Identification (RDID) command while an Erase or Program cycle is in progress, is not decoded, and has no effect on the cycle that is in progress. The Read Identification (RDID) command should not be issued while the device is in Deep Power-Down Mode.

The device is first selected by driving CS# low. Then, the 8-bit command code for the command is shifted in. This is followed by the 24-bit device identification, stored in the memory. Each bit is shifted out on the falling edge of Serial Clock. The Read Identification (RDID) command is terminated by driving CS# high at any time during data output. When CS# is driven high, the device is in the Standby Mode. Once in the Standby Mode, the device waits to be selected, so that it can receive, decode and execute commands.



Figure 21. Read Identification ID Sequence Diagram

### 7.22 Read Unique ID (4BH)

The Read Unique ID command accesses a factory-set read-only 128bit number that is unique to each device. The Unique ID can be used in conjunction with user software methods to help prevent copying or cloning of a system.

The Read Unique ID command sequence: CS# goes low  $\rightarrow$  sending Read Unique ID command  $\rightarrow$  3-Byte Address (000000H)  $\rightarrow$ Dummy Byte $\rightarrow$ 128bit Unique ID Out  $\rightarrow$ CS# goes high.



Figure 22. Read Unique ID Sequence Diagram

## 7.23 Erase Security Registers (44H)

The GD25R32C provides 3x1024-Byte Security Registers which can be erased and programmed individually. These registers may be used by the system manufacturers to store security and other important information separately from the main memory array.

The Erase Security Registers command is similar to Sector/Block Erase command. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit.

The Erase Security Registers command sequence: CS# goes low  $\rightarrow$  sending Erase Security Registers command  $\rightarrow$  3-byte address on SI  $\rightarrow$  CS# goes high. The command sequence is shown below. CS# must be driven high after the eighth bit of the last address byte has been latched in; otherwise the Erase Security Registers command is not executed. As soon as CS# is driven high, the self-timed Erase Security Registers cycle (whose duration is  $t_{SE}$ ) is initiated. While the Erase Security Registers cycle is in progress, the Status Register may be read to check the value of the Write in Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Erase Security Registers cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. The Security Registers Lock Bit (LB1, LB2, LB3) in the Status Register can be used to OTP protect the security registers. Once the LB bit is set to 1, the Security Registers will be permanently locked; the Erase Security Registers command will be ignored.

| Address              | A23-16 | A15-12 | A11-10 | A9-0       |
|----------------------|--------|--------|--------|------------|
| Security Register #1 | 00H    | 0001b  | 00b    | Don't care |
| Security Register #2 | 00H    | 0010b  | 00b    | Don't care |
| Security Register #3 | 00H    | 0011b  | 00b    | Don't care |



Figure 23. Erase Security Registers command Sequence Diagram

### 7.24 Program Security Registers (42H)

The Program Security Registers command is similar to the Page Program command. Each security register contains four pages content. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the Program Security Registers command. The Program Security Registers command is entered by driving CS# Low, followed by the command code (42H), three address bytes and at least one data byte on SI. As soon as CS# is driven high, the self-timed Program Security Registers cycle (whose duration is tpp) is initiated. While the Program Security Registers cycle is in progress, the Status Register may be read to check the value of the Write in Progress (WIP) bit. The Write in Progress (WIP) bit is 1 during the self-timed Program Security Registers cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset.

If the Security Registers Lock Bit (LB1, LB2, LB3) is set to 1, the Security Registers will be permanently locked. Program Security Registers command will be ignored.

| Address              | A23-16 | A15-12 | A11-10 | A9-0         |
|----------------------|--------|--------|--------|--------------|
| Security Register #1 | 00H    | 0001b  | 00b    | Byte Address |
| Security Register #2 | 00H    | 0010b  | 00b    | Byte Address |
| Security Register #3 | 00H    | 0011b  | 00b    | Byte Address |

CS# 30 31 32 33 34 35 36 37 3 6 10 28 29 **SCLK** 24-bit address Command Data Byte 42H SI **MSB MSB** CS# 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 Data Byte 2 Data Byte 3 Data Byte 256 SI 6 **MSB MSB MSB** 

Figure 24. Program Security Registers command Sequence Diagram

### 7.25 Read Security Registers (48H)

The Read Security Registers command is similar to Fast Read command. The command is followed by a 3-byte address (A23-A0) and a dummy byte, and each bit is latched-in on the rising edge of SCLK. Then the memory content, at that address, is shifted out on SO, and each bit is shifted out, at a Max frequency fc, on the falling edge of SCLK. The first byte addressed can be at any location. The address is automatically incremented to the next higher address after each byte of data is shifted out. Once the A9-0 address reaches the last byte of the register (Byte 3FFH), it will reset to 000H, the command is completed by driving CS# high.

| Address              | A23-16 | 16 A15-12 A11-10 |     | A9-0         |
|----------------------|--------|------------------|-----|--------------|
| Security Register #1 | 00H    | 0001b            | 00b | Byte Address |
| Security Register #2 | 00H    | 0010b            | 00b | Byte Address |
| Security Register #3 | 00H    | 0011b            | 00b | Byte Address |

CS# 28 29 30 31 SCLK SI 48H High-Z SO CS# SCLK Byte (2) 3 SI Data Out1 Data Out2 (4) 5) SO

Figure 25. Read Security Registers command Sequence Diagram

### 7.26 Enable Reset (66H) and Reset (99H)

If the Reset command is accepted, any on-going internal operation will be terminated and the device will return to its default power-on state and lose all the current volatile settings, such as Volatile Status Register bits, Write Enable Latch status (WEL), Program/Erase Suspend status, Read Parameter setting (P7-P0), Deep Power Down Mode, Continuous Read Mode bit setting (M7-M0) and Wrap Bit Setting (W6-W4).

The "Enable Reset (66H)" and "Reset (99H)" command sequence as follow: CS# goes low  $\rightarrow$  Sending Enable Reset command  $\rightarrow$  CS# goes high  $\rightarrow$  CS# goes low  $\rightarrow$  Sending Reset command  $\rightarrow$  CS# goes high. Once the Reset command is accepted by the device, the device will take approximately  $t_{RST}$  /  $t_{RST\_E}$  to reset. During this period, no command will be accepted. Data corruption may happen if there is an on-going or suspended internal Erase or Program operation when Reset command sequence is accepted by the device. It is recommended to check the WIP bit and the SUS1/SUS2 bit in Status Register before issuing the Reset command sequence.

CS# 2 3 4 5 6 0 2 3 4 5 6 SCLK Command Command 66H 99H SI High-Z SO

Figure 26. Enable Reset and Reset command Sequence Diagram

### 7.27 Program/Erase Suspend (PES) (75H)

The Program/Erase Suspend command "75H", allows the system to interrupt a page program or sector/block erase operation and then read data from any other sector or block. The Write Status Register command (01H, 31H, 11H) and Erase/Program Security Registers command (44H, 42H) and Erase commands (20H, 52H, D8H, C7H, 60H) and Page Program command (02H, 32H) are not allowed during Program suspend. The Write Status Register command (01H, 31H, 11H) and Erase Security Registers command (44H) and Erase commands (20H, 52H, D8H, C7H, 60H) are not allowed during Erase suspend. Program/Erase Suspend is valid only during the page program or sector/block erase operation. A maximum of time of "tsus" (See AC Characteristics) is required to suspend the program/erase operation.

The Program/Erase Suspend command will be accepted by the device only if the SUS1/SUS2 bit in the Status Register equal to 0 and WIP bit equal to 1 while a Page Program or a Sector or Block Erase operation is on-going. If the SUS1/SUS2 bit equal to 1 or WIP bit equal to 0, the Suspend command will be ignored by the device. The WIP bit will be cleared from 1 to 0 within "tsus" and the SUS1/SUS2 bit will be set from 0 to 1 immediately after Program/Erase Suspend. A power-off during the suspend period will reset the device and release the suspend state.



Figure 27. Program/Erase Suspend Sequence Diagram

#### 7.28 Program/Erase Resume (PER) (7AH)

The Program/Erase Resume command must be written to resume the program or sector/block erase operation after a Program/Erase Suspend command. The Program/Erase Resume command will be accepted by the device only if the SUS1/SUS2 bit equal to 1 and the WIP bit equal to 0. After issued the SUS1/SUS2 bit in the status register will be cleared from 1 to 0 immediately, the WIP bit will be set from 0 to 1 within 200ns and the Sector or Block will complete the erase operation or the page will complete the program operation. The Program/Erase Resume command will be ignored unless a Program/Erase Suspend is active.

CS#

O 1 2 3 4 5 6 7

SCLK

Command

Command

Resume Erase/Program

Figure 28. Program/Erase Resume Sequence Diagram

#### 7.29 Deep Power-Down (DP) (B9H)

Executing the Deep Power-Down (DP) command is the only way to put the device in the lowest consumption mode (the Deep Power-Down Mode). It can also be used as an extra software protection mechanism, while the device is not in active use, since in this mode, the device ignores all Write, Program and Erase commands. Driving CS# high deselects the device, and puts the device in the Standby Mode (if there is no internal cycle currently in progress). But this mode is not the Deep Power-Down Mode. The Deep Power-Down Mode can only be entered by executing the Deep Power-Down (DP) command. Once the device has entered the Deep Power-Down Mode, all commands are ignored except the Release from Deep Power-Down and Read Device ID (RDI) command or software reset command. The Release from Deep Power-Down and Read Device ID (RDI) command releases the device from Deep Power-Down mode, also allows the Device ID of the device to be output on SO.

The Deep Power-Down Mode automatically stops at Power-Down, and the device always in the Standby Mode after Power-Up.

The Deep Power-Down command sequence: CS# goes low → sending Deep Power-Down command → CS# goes high. CS# must be driven high after the eighth bit of the command code has been latched in; otherwise the Deep Power-Down (DP) command is not executed. As soon as CS# is driven high, it requires a delay of t<sub>DP</sub> before the supply current is reduced to I<sub>CC2</sub> and the Deep Power-Down Mode is entered. Any Deep Power-Down (DP) command, while an Erase, Program or Write cycle is in progress, is rejected without having any effects on the cycle that is in progress.

CS#

0 1 2 3 4 5 6 7

SCLK

Command

Deep Power-down mode

SI

B9H

Figure 29. Deep Power-Down Sequence Diagram

# 7.30 Release from Deep Power-Down and Read Device ID (RDI) (ABH)

The Release from Power-Down and Read Device ID command is a multi-purpose command. It can be used to release the device from the Power-Down state or obtain the devices electronic identification (ID) number.

To release the device from the Power-Down state, the command is issued by driving the CS# pin low, shifting the instruction code "ABH" and driving CS# high. Release from Power-Down will take the time duration of t<sub>RES1</sub> (See AC Characteristics) before the device will resume normal operation and other command are accepted. The CS# pin must remain high during the t<sub>RES1</sub> time duration.

When used only to obtain the Device ID while not in the Power-Down state, the command is initiated by driving the CS#



pin low and shifting the instruction code "ABH" followed by 3-dummy byte. The ID7~ID0 are then shifted out on the falling edge of SCLK with most significant bit (MSB) first. The Device ID value is listed in Manufacturer and Device Identification table. The Device ID can be read continuously. The command is completed by driving CS# high.

When used to release the device from the Power-Down state and obtain the ID7~ID0, the command is the same as previously described, except that after CS# is driven high it must remain high for a time duration of t<sub>RES2</sub> (See AC Characteristics). After this time duration the device will resume normal operation and other command will be accepted. If the Release from Power-Down / Device ID command is issued while an Erase, Program or Write cycle is in process (when WIP equals 1) the command is ignored and will not have any effects on the current cycle.



Figure 30. Release Power-Down Sequence Diagram





### 7.31 Read Serial Flash Discoverable Parameter (5AH)

The Serial Flash Discoverable Parameter (SFDP) standard provides a consistent method of describing the functional and feature capabilities of serial flash devices in a standard set of internal parameter tables. These parameter tables can be interrogated by host system software to enable adjustments needed to accommodate divergent features from multiple vendors. The concept is similar to the one found in the Introduction of JEDEC Standard, JESD68 on CFI. SFDP is a standard of JEDEC Standard No.216B.

Figure 32. Read Serial Flash Discoverable Parameter command Sequence Diagram



Table 9. Signature and Parameter Identification Data Values (Please contact GigaDevice for Details)

### 8 RPMC COMMANDS DESCRIPTION

Table 10. Replay Protected Monotonic Counter (RPMC) Commands

| Function           | Opcode  | Payload Phase Max 512 Bits |                                 | Comment                           |
|--------------------|---------|----------------------------|---------------------------------|-----------------------------------|
|                    | Phase 8 | Byte#                      | Field Description               |                                   |
|                    | bits    |                            |                                 |                                   |
| Command: Write     | OP1     | 1                          | CmdType[7:0] = 00H              | OP1 + Payload phase driven by     |
| Root Key Register  |         | 2                          | CounterAddr[7:0] = 8 Bits       | host controller. Root Key         |
|                    |         | 3                          | Reserved[7:0] = 8 Bits          | Register is written only once.    |
|                    |         | 4-35                       | RootKey[255:0] = 256 Bits       |                                   |
|                    |         | 36-63                      | TruncatedSign[223:0] = 224 Bits |                                   |
| Command: Update    | OP1     | 1                          | CmdType[7:0]= 01H               | OP1 + Payload phase is Issued     |
| HMAC Key Register  |         | 2                          | CounterAddr[7:0]= 8 Bits        | by host controller on every       |
|                    |         | 3                          | Reserved[7:0] = 8 Bits          | power up to initialize HMAC Key   |
|                    |         | 4-7                        | KeyData[31:0] = 32 Bits,        | Register.                         |
|                    |         | 8-39                       | Signature[255:0] = 256 Bits     |                                   |
| Command: Increment | OP1     | 1                          | CmdType[7:0] = 02H              | OP1 + Payload Phase is Issued     |
| Monotonic Counter  |         | 2                          | CounterAddr[7:0] = 8 Bits       | by host controller during runtime |
|                    |         | 3                          | Reserved[7:0] = 8 Bits          | to increment the counter.         |
|                    |         | 4-7                        | CounterData[31:0] = 32 Bits,    |                                   |
|                    |         | 8-39                       | Signature[255:0] = 256 Bits     |                                   |
| Command: Request   | OP1     | 1                          | CmdType[7:0] = 03H              | OP1 + Payload Phase is Issued     |
| Monotonic Counter  |         | 2                          | CounterAddr[7:0] = 8 Bits       | by host controller during runtime |
|                    |         | 3                          | Reserved[7:0] = 8 Bits Tag      | to request counter data           |
|                    |         | 4-15                       | [95:0] = 96 Bits                |                                   |
|                    |         | 16-47                      | Signature[255:0] = 256 Bits     |                                   |
| Command: Read      | OP2     | 2                          | ExtendedStatus[7:0] = 8 Bits    | OP2 is issued by Host Controller  |
| Data               |         | 3-14                       | Tag[95:0] = 96 Bits             | generally after an OP1. SPI       |
|                    |         | 15-18                      | CounterData[31:0] = 32 Bits     | Flash device responds with the    |
|                    |         | 19-50                      | Signature[255:0] = 256 Bits     | Payload phase to return           |
|                    |         |                            |                                 | Extended Status and counter       |
|                    |         |                            |                                 | data.                             |

All individual fields are Byte wide fields. For a multi-byte field, Most Significant Byte is issued first; Least Significant Byte is issued last. Within a Byte, Most Significant Bit is issued first; Least Significant Bit is issued last. CmdType is always the first byte issued after OP1 commands. OP2 delay is the same as Fast Read Command delay which is 8 dummy bits.

Table 11. OP1 and OP2 are defined for 1-1-1 mode.

| Byte # | 0   | 1       | 2           | 3     | 4                             | 5        | 6       |     |  |  |
|--------|-----|---------|-------------|-------|-------------------------------|----------|---------|-----|--|--|
| Name   | OP1 | CmdType | Counter     | As de | As defined in the table above |          |         |     |  |  |
|        |     |         | Address     |       |                               |          |         |     |  |  |
| Name   | OP2 | 8 Dummy | Extended    | As de | efined i                      | n the ta | ble abo | ove |  |  |
|        |     | clocks  | Status[7:0] |       |                               |          |         |     |  |  |

After an OP1 command is received, the SPI Flash will indicate status busy indication using either the status register or extended status register as defined below.

Table 12. Extended Status Register Definition

| Extended    | Applicable             | Description                                                                                                                                                                                                                                                                                                     |
|-------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status[7:0] | CmdType(s)             |                                                                                                                                                                                                                                                                                                                 |
| 00000000    | -                      | Power On State (OP2 issued directly after power-up).                                                                                                                                                                                                                                                            |
| 10000000    | 00,01,02,03            | This status is set on successful completion (no errors) of OP1 command.                                                                                                                                                                                                                                         |
| 0xxxxxx1    | 00,01,02,03,04-<br>0FF | This bit is set to 1, when device is busy executing OP1 command. It is reset to 0 when OP1 command execution is done.                                                                                                                                                                                           |
| 0xxxxx1x    | 00,01                  | This bit is set only when the correct payload size is received. When cmdtype = 0, this error bit must be set on Root Key Register Overwrite or Counter Address out of range or Truncated Signature mis-match error.  For cmdtype = 01 this bit is set when the corresponding monotonic counter is uninitialized |
| 0xxxx1xx    | 00,01,02,03            | This bit is set on Signature Mismatch, Counter Address out of range when correct payload size is received; or Cmdtype is out of range; or incorrect payload size is received.                                                                                                                                   |
| 0xxx1xxx    | 02,03                  | This bit is set on HMAC Key Register or monotonic counter uninitialized on previous OP1 command when correct payload size is received                                                                                                                                                                           |
| 0xx1xxxx    | 02                     | This bit is set on Counter Data Mismatch on previous increment when correct payload size is received                                                                                                                                                                                                            |
| 0x1xxxxx    | -                      | Fatal Error. It is set when no valid counter is found after initialization.                                                                                                                                                                                                                                     |
| Current     |                        | Extended status register will not be updated until first 8 bits of OP1 is received. The                                                                                                                                                                                                                         |
| value       |                        | correct error type is reflected for any OP1 operation that exceeds a minimum of 16 clocks with active chip-select.                                                                                                                                                                                              |

# 8.1 Command: Write Root Key Register

This command is used to initialize the Root Key Register corresponding to the received Counter Address with the received Root Key. It is suggested to be used in an OEM manufacturing environment when the SPI Flash Controller and SPI Flash are powered together for the first time.

Figure 33. Write Root Key Register Sequence Diagram



Truncated signature field is the same as least significant 224 bits of HMAC-SHA-256 based signature computed based on

received input parameters:

- > HMAC message[31:0] = (OpCode[7:0], CmdType[7:0], CounterAddr[7:0], Reserved[7:0])
- HMAC Key[255:0] = Root\_Key[255:0]

If Root Key != 256'HFF..FF then this command can be executed one time. If the received transaction is error free SPI Flash device successfully executes the command and posts "successful completion" extended status.

Root Key Register Write with root key is = 256'HFF...FF can be used as a temporary key.

If the received transaction has errors the SPI Flash does not execute the transaction and posts the corresponding error in extended status.

| Extended    | Applicable | Description                                                                                                                                                                                                                                                                |
|-------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status[7:0] | CmdType(s) |                                                                                                                                                                                                                                                                            |
| 10000000    | 00         | Successful completion                                                                                                                                                                                                                                                      |
| 0xxxxxx1    | 00         | If Busy_Polling_Method bit in SFDP table is zero, then this bit must be set to 1, when device is busy executing command. It is reset to 0 when OP1 command execution is done. If Busy_Polling_Method bit in SFDP table is one, then this bit is ignored by the controller. |
| 0xxxxx1x    | 00         | This bit is only set when correct payload size is received. It is set on Root Key Register Overwrite or Counter Address is out of range or when there is a truncated signature mismatch error                                                                              |
| 0xxxx1xx    | 00         | This bit is set when incorrect payload size is received.                                                                                                                                                                                                                   |

Table 13. Expected Extended Status [7:0] results

# 8.2 Command: Update HMAC Key Register

This command is used by the SPI Flash Controller to update the HMAC-Key register corresponding to the received Counter Address with a new HMAC key calculated based on received input. This command must be issued on every power cycle event on the interface. The HMAC key storage is volatile.



Figure 34. Update HMAC Key Register Sequence Diagram

Signature matches the HMAC-SHA-256 based signature computed based on received input parameters. This command performs two HMAC-SHA-256 operations.

- HMAC-SHA-256 Operation 1 Output = HMAC\_Storage[255:0]
  - HMAC Message[31:0] = KeyData[31:0]
  - HMAC Key[255:0] = Root\_Key\_Register[CounterAddr][255:0]



- HMAC-SHA-256 Operation 2 Output = HMAC-SHA-256 based signature[255:0]
  - HMAC message[63:0] = (OpCode[7:0], CmdType[7:0].CounterAddr[7:0].Reserved[7:0], KeyData[31:0])
  - HMAC Key[255:0] = HMAC\_Storage[255:0]

If the received transaction is error free SPI Flash device successfully executes the command and posts "successful completion" extended status.

If the received transaction has errors the SPI Flash does not execute the transaction and posts the corresponding error in extended status.

| Extended    | Applicable | Description                                                                                                                                       |
|-------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Status[7:0] | CmdType(s) |                                                                                                                                                   |
| 10000000    | 01         | This status is set on successful completion (no errors) of OP1 command.                                                                           |
| 0xxxxxx1    | 01         | This bit is set to 1, when device is busy executing OP1 command. It is reset to 0 when OP1 command execution is done.                             |
| 0xxxxx1x    | 01         | This bit is set only when the correct payload size is received.  This bit is set when the corresponding monotonic counter is uninitialized        |
| 0xxxx1xx    | 01         | This bit is set on Signature Mismatch, Counter Address out of range when correct payload size is received; or incorrect payload size is received. |

Table 14. Expected Extended Status [7:0] results

#### 8.3 Command: Increment Monotonic Counter

This command is used by the SPI Flash Controller to increment the Monotonic counter by 1 inside the SPI Flash Device.



Figure 35. Increment Monotonic Counter Sequence Diagram

The requested Signature matches the HMAC-SHA-256 based signature computed based on received input parameters. The received Counter Data matches the current value of the counter read from the SPI Flash.

- HMAC Message[63:0] = (OpCode[7:0], CmdType[7:0]. CounterAddr[7:0]. Reserved[7:0], CounterData[31:0])
- ➤ HMAC Key[255:0] = HMAC\_Key\_Register [Counter\_Addreess][255:0]

If the received transaction is error free SPI Flash device successfully executes the command and posts "successful completion" extended status. If the received transaction has errors the SPI Flash does not execute the transaction and posts the corresponding error in extended status.

Table 15. Expected Extended Status [7:0] results

| Extended                                                   | Applicable | Description                                                     |  |  |
|------------------------------------------------------------|------------|-----------------------------------------------------------------|--|--|
| Status[7:0]                                                | CmdType(s) |                                                                 |  |  |
| 10000000                                                   | 02         | This status is set on successful completion (no errors) of OP1  |  |  |
|                                                            |            | command.                                                        |  |  |
| 0xxxxxx1                                                   | 02         | This bit is set to 1, when device is busy executing OP1         |  |  |
|                                                            |            | command. It is reset to 0 when OP1 command execution is         |  |  |
|                                                            |            | done.                                                           |  |  |
| 0xxxx1xx 02 This bit is set on Signature Mismatch, Counter |            |                                                                 |  |  |
|                                                            |            | range when correct payload size is received; or incorrect       |  |  |
|                                                            |            | payload size is received.                                       |  |  |
| 0xxx1xxx                                                   | 02         | This bit is set only when the correct payload size is received. |  |  |
|                                                            |            | This bit must be set on HMAC Key Register or Monotonic          |  |  |
|                                                            |            | Counter is uninitialized on previous OP1 command.               |  |  |
| 0xx1xxxx                                                   | 02         | This bit is set only when the correct payload size is received. |  |  |
|                                                            |            | The bit must be set when the received counter data filed does   |  |  |
|                                                            |            | not match the actual counter value read from the SPI Flash      |  |  |
|                                                            |            | device.                                                         |  |  |

## 8.4 Command: Request Monotonic Counter

This command is used by the SPI Flash Controller to request the Monotonic counter value inside the SPI Flash Device.

Figure 36. Request Monotonic Counter Sequence Diagram

The requested Signature matches the HMAC-SHA-256 based signature computed based on received input parameters.

- HMAC Message[127:0] = (OpCode[7:0], CmdType[7:0]. CounterAddr[7:0]. Reserved[7:0], Tag[95:0])
- ► HMAC Key[255:0] = HMAC\_Key\_Register[Counter\_Addreess][255:0]

If the received transaction is error free SPI Flash device successfully executes the command and posts "successful completion" extended status. If the received transaction has errors the SPI Flash does not execute the transaction and posts the corresponding error in extended status.

Table 16. Expected Extended Status [7:0] results

| Extended    | Applicable | Description                                                                                                                                                                   |
|-------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status[7:0] | CmdType(s) |                                                                                                                                                                               |
| 10000000    | 03         | This status is set on successful completion (no errors) of OP1 command.                                                                                                       |
| 0xxxxx1     | 03         | This bit is set to 1, when device is busy executing OP1 command. It is reset to 0 when OP1 command execution is done.                                                         |
| 0xxxx1xx    | 03         | This bit is set on Signature Mismatch, Counter Address out of range when correct payload size is received; or Cmdtype is out of range; or incorrect payload size is received. |
| 0xxx1xxx    | 03         | This bit is set only when the correct payload size is received.  This bit must be set on HMAC Key Register or Monotonic  Counter is uninitialized on previous OP1 command.    |

#### 8.5 Command: Read Data

This command is used by the SPI Flash Controller to read extended status from any previously issued OP1 command. In addition if previous OP1 command is Request Monotonic Counter and if SPI Flash returns successful completion extended status then it returns valid values in the Tag, Counter Data and Signature field. Otherwise the values returned in Tag, Counter and Signature field are invalid. The controller may abort the read prematurely prior to completely reading the entire payload. This may occur when the controller wants to simply read the extended status or when is observes an error being returned in the extended status field. The controller may also continue reading past the defined payload size of 49 bytes. Since this is an error condition, the SPI Flash may return any data past the defined payload size. The controller must ignore the data.

CS# 10 12 14 18 **SCLK** Command 8-bit Dummy SI OP2 00H **MSB** Extended Status SO High-Z MSB CS# Tag[95:0] Counter Data[31:0] Signature[255:0] SO  $\langle 0 \rangle$ (31 **MSB** 

Figure 37. Read Data Sequence Diagram



If previous OP1 command is Request Monotonic Counter and if SPI Flash returns successful completion extended status then it returns valid values in the Tag, Counter Data and Signature field. It calculates HMAC-SHA-256 signatures based on following parameters.

- HMAC Message[127:0] = Tag [95:0], Counter\_Data\_Read[31:0]
- HMAC Key[255:0] = HMAC\_Key\_Register[Counter\_Address][255:0]

**Table 17. Extended Status Register Definition** 

| Extended      | Applicable     | Description                                                                                                                                                                                                                                                                                                              |
|---------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status[7:0]   | CmdType(s)     |                                                                                                                                                                                                                                                                                                                          |
| 00000000      | -              | Power On State (OP2 issued directly after power-up).                                                                                                                                                                                                                                                                     |
| 10000000      | 00, 01, 02, 03 | This status is set on successful completion (no errors) of OP1 command.                                                                                                                                                                                                                                                  |
| 0xxxxxx1      | 00, 01, 02, 03 | This bit is set to 1, when device is busy executing OP1 command. It is reset to 0 when OP1 command execution is done.                                                                                                                                                                                                    |
| 0xxxxx1x      | 00, 01         | This bit is set only when the correct payload size is received. When cmdtype = 0, this error bit must be set on Root Key Register Overwrite or Counter Address out of range or Truncated Signature mis-match error.  For remaining cmdtype = 1 this bit is set when the corresponding monotonic counter is uninitialized |
| 0xxxx1xx      | 01, 02, 03     | This bit is set on Signature Mismatch, Counter Address out of range when correct payload size is received; or Cmdtype is out of range; or incorrect payload size is received.                                                                                                                                            |
| 0xxx1xxx      | 02, 03         | This bit is set on HMAC Key Register or Monotonic Counter uninitialized on previous OP1 command when correct payload size is received                                                                                                                                                                                    |
| 0xx1xxxx      | 02             | This bit is set on Counter Data Mismatch on previous increment when correct payload size is received                                                                                                                                                                                                                     |
| 0x1xxxxx      | -              | Fatal Error. It is set when no valid counter is found after initialization.                                                                                                                                                                                                                                              |
| Current value | -              | Extended status register will not be updated until first 8 bits of OP1 is received. The correct error type is reflected for any OP1 operation that exceeds a minimum of 16 clocks with active chipselect.                                                                                                                |

## 8.6 Operations Allowed/Disallowed During RPMC Operation

In the deep power down state OP1, OP2 commands are ignored until the part comes out of deep power down state. WREN state does not affect the OP1 command execution inside the SPI Flash.

Suspend operation can be used to execute high-priority reads from the flash device while a long-latency operation is underway. However, OP1 is not recommended when the flash device is in WIP or suspended state.

In the table below, OP1 state is defined as the time starting with a transaction with OP1 op-code sent to the device and ending when the device clears the extended status busy bit. During OP1 state if a suspend transaction is received, the SPI Flash will ignore the suspend command and continue with the execution of the current OP1 command as described in the table below. P/E state is defined as the time starting with a transaction with write or erase op-code sent to the device and ending when the device clears

**GD25R32C** 

the status busy bit. P/E Suspended State starts when the device sets the program suspend status done bit after receiving a program suspend op-code. During P/E State and P/E Suspended State, OP1 is also allowed but not recommended.

The table below shows all operation support in each state.

**Table 18. RPMC Operation** 

| Operation         | OP1 state                   | P/E state                             | P/E Suspended State         |
|-------------------|-----------------------------|---------------------------------------|-----------------------------|
| Suspend           | Ignored                     | Yes-> P/E Suspended State(not         | No                          |
|                   |                             | chip erase or write status operation) |                             |
|                   |                             | No ->remain P/E state ( chip erase    |                             |
|                   |                             | or write status operation)            |                             |
| Resume            | Ignored                     | No                                    | Yes -> P/E state            |
| All reads except  | Yes                         | No                                    | Yes                         |
| Read status       |                             |                                       |                             |
| All writes/erases | Yes                         | No                                    | No                          |
| OP1               | No                          | Yes but not recommended               | Yes but not recommended     |
| Write status      | Yes                         | No                                    | No                          |
| OP2               | Yes->OP1 busy state (when   | Yes. Will indicate the status         | Yes. Will indicate the      |
|                   | extended status busy is 1)  | associated with the OP1 operation.    | status associated with the  |
|                   | ->OP1 done state (when      |                                       | OP1 operation               |
|                   | extended status busy is 0)  |                                       |                             |
| Read status       | Yes. Will indicate the busy | Yes. Will indicate the busy state     | Yes. Will indicate the busy |
|                   | state associated with the   | associated with the subsequent        | state associated with the   |
|                   | subsequent transaction      | transaction issued to the SPI Flash.  | subsequent transaction      |
|                   | issued to the SPI Flash.    |                                       | issued to the SPI Flash.    |
|                   |                             |                                       |                             |



## 9 ELECTRICAL CHARACTERISTICS

## 9.1 Power-On Timing

Figure 38. Power-On Timing Sequence Diagram



Table 19. Power-Up Timing and Write Inhibit Threshold

| Symbol | Parameter                      | Min. | Max. | Unit |
|--------|--------------------------------|------|------|------|
| tVSL   | VCC (min.) to device operation | 1.8  |      | ms   |
| VWI    | Write Inhibit Voltage          | 1.5  | 2.5  | V    |

## 9.2 Initial Delivery State

The device is delivered with the memory array erased: all bits are set to 1 (each Byte contains FFH). The Status Register contains 00H, except that DRV0 bit (S21) and QE bit (S9) are set to 1.

## 9.3 Absolute Maximum Ratings

| Parameter                                        | Value           | Unit       |
|--------------------------------------------------|-----------------|------------|
| Ambient Operating Temperature (T <sub>A</sub> )  | -40 to 85       | $^{\circ}$ |
| Storage Temperature                              | -65 to 150      | $^{\circ}$ |
| Transient Input/Output Voltage (note: overshoot) | -2.0 to VCC+2.0 | V          |
| Applied Input/Output Voltage                     | -0.6 to VCC+0.4 | V          |
| VCC                                              | -0.6 to 4.2     | V          |

Figure 39. Input Test Waveform and Measurement Level

# Maximum Negative Overshoot Waveform Vss 20ns 20ns

Vss-2.0V ----



# 9.4 Capacitance Measurement Conditions

| Symbol | Parameter                       | Min.             | Тур.       | Max. | Unit | Conditions |
|--------|---------------------------------|------------------|------------|------|------|------------|
| CIN    | Input Capacitance               |                  |            | 12   | pF   | VIN=0V     |
| COUT   | Output Capacitance              |                  |            | 16   | pF   | VOUT=0V    |
| CL     | Load Capacitance                |                  | 30         |      | pF   |            |
|        | Input Rise And Fall time        |                  |            | 5    | ns   |            |
|        | Input Pulse Voltage             | 0.1              | VCC to 0.8 | BVCC | V    |            |
|        | Input Timing Reference Voltage  | 0.2VCC to 0.7VCC |            | V    |      |            |
|        | Output Timing Reference Voltage |                  | 0.5VCC     |      | V    |            |

Figure 40. Absolute Maximum Ratings Diagram



## 9.5 DC Characteristics

 $(T_A = -40^{\circ}C \sim 85^{\circ}C, VCC = 2.7 \sim 3.6V)$ 

| Symbol           | Parameter                | Test Condition          | Min.    | Тур. | Max.    | Unit. |
|------------------|--------------------------|-------------------------|---------|------|---------|-------|
| lμ               | Input Leakage Current    |                         |         |      | ±4      | μA    |
| ILO              | Output Leakage Current   |                         |         |      | ±4      | μA    |
| I <sub>CC1</sub> | Standby Current          | CS#=VCC,                |         | 2    | 15      | μA    |
| ICC1             | Standby Current          | VIN=VCC or VSS          |         | 2    | 15      | μΑ    |
| lcc2             | Deep Power-Down Current  | CS#=VCC,                |         | 2    | 15      | μA    |
| ICC2             | Deep Fower-Down Current  | VIN=VCC or VSS          |         | 2    | 15      | μΑ    |
|                  |                          | CLK=0.1VCC / 0.9VCC     |         |      |         |       |
|                  | Operating Current (Read) | at 104MHz,              |         | 15   | 20      | mA    |
| laas             |                          | Q=Open(x4 I/O)          |         |      |         |       |
| Іссз             |                          | CLK=0.1VCC / 0.9VCC     |         |      |         |       |
|                  |                          | at 80MHz,               |         | 13   | 18      | mA    |
|                  |                          | Q=Open(x4 I/O)          |         |      |         |       |
| I <sub>CC4</sub> | Operating Current (PP)   | CS#=VCC                 |         |      | 25      | mA    |
| I <sub>CC5</sub> | Operating Current (WRSR) | CS#=VCC                 |         |      | 25      | mA    |
| Icc6             | Operating Current (SE)   | CS#=VCC                 |         |      | 25      | mA    |
| Icc7             | Operating Current (BE)   | CS#=VCC                 |         |      | 25      | mA    |
| Icc8             | Operating Current (CE)   | CS#=VCC                 |         |      | 25      | mA    |
| Icc <sub>9</sub> | High Performance Current |                         |         | 0.6  | 1.2     | mA    |
| VIL              | Input Low Voltage        |                         | -0.5    |      | 0.2VCC  | V     |
| VIH              | Input High Voltage       |                         | 0.7VCC  |      | VCC+0.4 | V     |
| Vol              | Output Low Voltage       | I <sub>OL</sub> = 100μA |         |      | 0.2     | V     |
| Voн              | Output High Voltage      | Іон = -100μΑ            | VCC-0.2 |      |         | V     |

- 2. Value guaranteed by design and/or characterization, not 100% tested in production.



# 9.6 AC Characteristics

 $(T_A = -40^{\circ}C \sim 85^{\circ}C, VCC = 2.7 \sim 3.6V)$ 

| Symbol            | Parameter                                          | Min. | Тур. | Max. | Unit.   |
|-------------------|----------------------------------------------------|------|------|------|---------|
|                   | Serial Clock Frequency For: Dual I/O(BBH), Quad    |      |      |      |         |
| <b>f</b>          | I/O(EBH), Quad Output(6BH) (Dual I/O & Quad I/O    |      |      | 104  | MHz     |
| f <sub>C1</sub>   | With High Performance Mode), on 2.7V-3.6V power    |      |      | 104  | IVITZ   |
|                   | supply                                             |      |      |      |         |
|                   | Serial Clock Frequency For: Dual I/O(BBH), Quad    |      |      |      |         |
| f <sub>C2</sub>   | I/O(EBH), Quad I/O Word Fast Read (E7h) (Dual I/O  |      |      | 104  | MHz     |
| 102               | & Quad I/O Without High Performance Mode), on      |      |      | 104  | IVII IZ |
|                   | 3.0V-3.6V power supply                             |      |      |      |         |
|                   | Serial Clock Frequency For: Dual I/O(BBH), Quad    |      |      |      |         |
| f <sub>C3</sub>   | I/O(EBH), Quad I/O Word Fast Read (E7h) (Dual I/O  |      |      | 80   | MHz     |
| 103               | & Quad I/O Without High Performance Mode), on      |      |      | 00   | 1711 12 |
|                   | 2.7V-3.0V power supply                             |      |      |      |         |
|                   | Serial Clock Frequency For: Read(03H) Read ID      |      |      |      |         |
| $f_R$             | (90H, 9FH and ABH), Read Status Register (05H and  |      |      | 80   | MHz     |
|                   | 35H)                                               |      |      |      |         |
| t <sub>CLH1</sub> | Serial Clock High Time                             | 4    |      |      | ns      |
| t <sub>CLL1</sub> | Serial Clock Low Time                              | 4    |      |      | ns      |
| t <sub>CLCH</sub> | Serial Clock Rise Time (Slew Rate)                 | 0.1  |      |      | V/ns    |
| t <sub>CHCL</sub> | Serial Clock Fall Time (Slew Rate)                 | 0.1  |      |      | V/ns    |
| tslch             | CS# Active Setup Time                              | 5    |      |      | ns      |
| tcнsн             | CS# Active Hold Time                               | 5    |      |      | ns      |
| tshch             | CS# Not Active Setup Time                          | 5    |      |      | ns      |
| t <sub>CHSL</sub> | CS# Not Active Hold Time                           | 5    |      |      | ns      |
| t <sub>SHSL</sub> | CS# High Time (Read/Write)                         | 20   |      |      | ns      |
| tsHQZ             | Output Disable Time                                |      |      | 6    | ns      |
| tclqx             | Output Hold Time                                   | 1.2  |      |      | ns      |
| tovch             | Data In Setup Time                                 | 2    |      |      | ns      |
| tchdx             | Data In Hold Time                                  | 2    |      |      | ns      |
| tclqv             | Clock Low To Output Valid                          |      |      | 7    | ns      |
| t <sub>DP</sub>   | CS# High To Deep Power-Down Mode                   |      |      | 20   | μs      |
|                   | CS# High To Standby Mode Without Electronic        |      |      | 00   |         |
| t <sub>RES1</sub> | Signature Read                                     |      |      | 20   | μs      |
| 4                 | CS# High To Standby Mode With Electronic Signature |      |      | 20   |         |
| t <sub>RES2</sub> | Read                                               |      |      | 20   | μs      |
| tsus              | CS# High To Next Command After Suspend             |      |      | 20   | μs      |
| t <sub>RS</sub>   | Latency Between Resume And Next Suspend            | 100  |      |      | μs      |
| <b>1</b>          | CS# High To Next Command After Reset (Except       |      |      | 20   |         |
| trst              | From Erase)                                        |      |      | 30   | μs      |

## **GD25R32C**

| t <sub>RST_E</sub> | CS# High To Next Command After Reset (From      |      | 12   | ms |  |
|--------------------|-------------------------------------------------|------|------|----|--|
|                    | Erase)                                          |      |      |    |  |
| tw                 | Write Status Register Cycle Time                | 5    | 30   | ms |  |
| t <sub>BP1</sub>   | Byte Program Time (First Byte)                  | 30   | 50   | μs |  |
| t <sub>BP2</sub>   | Additional Byte Program Time (After First Byte) | 2.5  | 12   | μs |  |
| tpp                | Page Programming Time                           | 0.6  | 2.4  | ms |  |
| tse                | Sector Erase Time                               | 50   | 300  | ms |  |
| t <sub>BE1</sub>   | Block Erase Time (32K Bytes)                    | 0.15 | 1.6  | S  |  |
| t <sub>BE2</sub>   | Block Erase Time (64K Bytes)                    | 0.25 | 2.0  | S  |  |
| tce                | Chip Erase Time (GD25R32C)                      | 15   | 30   | S  |  |
| twrkr              | Write Root key register                         | 3    | 5.5  | ms |  |
| tuhkr              | Update HMAC Key Register                        | 120  |      | μs |  |
| timc               | Increment Monotonic Counter                     | 20   | 300  | ms |  |
| t <sub>RMC</sub>   | Request Monotonic Counter                       | 100  | 1200 | μs |  |

- 1. Typical value at  $T_A = 25^{\circ}C$ .
- 2. Value guaranteed by design and/or characterization, not 100% tested in production.

Figure 41. Input Timing



Figure 42. Output Timing



Figure 43. Resume to Suspend Timing Diagram



## 10 ORDERING INFORMATION



## 10.1 Valid Part Numbers

Please contact GigaDevice regional sales for the latest product selection and available form factors.

# Temperature Range I: Industrial (-40°C to +85°C)

| Product Number | Density | Package Type  | Packing<br>Options |  |
|----------------|---------|---------------|--------------------|--|
| GD25R32CSIG    | 32Mbit  | SOP8 208mil   | T/Y/R              |  |
| GD25R32CWIG    | 32Mbit  | WSON8 (6x5mm) | Y/R                |  |

# 11 PACKAGE INFORMATION

# 11.1 Package SOP8 208MIL









## **Dimensions**

| Syı | mbol | Α.   |      |      | A.1  | 42   | <b>L</b> |      | 2    | _    | E4   |      | ,  | 1.4 | 0 |
|-----|------|------|------|------|------|------|----------|------|------|------|------|------|----|-----|---|
| U   | Init | Α    | A1   | A2   | b    | С    | D        | E    | E1   | е    | L    | L1   | 8  |     |   |
|     | Min  | -    | 0.05 | 1.70 | 0.31 | 0.15 | 5.13     | 7.70 | 5.18 |      | 0.50 |      | 0° |     |   |
| mm  | Nom  | -    | 0.15 | 1.80 | 0.41 | 0.20 | 5.23     | 7.90 | 5.28 | 1.27 | -    | 1.31 | -  |     |   |
|     | Max  | 2.16 | 0.25 | 1.90 | 0.51 | 0.25 | 5.33     | 8.10 | 5.38 |      | 0.85 |      | 8° |     |   |

- 1. Both the package length and width do not include the mold flash.
- 2. Seating plane: Max. 0.1mm.

# 11.2 Package WSON8 (6x5mm)





Top View

Side View



**Bottom View** 

## **Dimensions**

| Symbol |      |      | A1   | _     | h    | D    | D2   | Е    | E2   | _    |      |
|--------|------|------|------|-------|------|------|------|------|------|------|------|
| U      | Jnit | Α    | AI   | С     | b    | ן    | DZ   |      | EZ   | е    | _    |
|        | Min  | 0.70 | 0.00 | 0.180 | 0.35 | 5.90 | 3.30 | 4.90 | 3.90 |      | 0.50 |
| mm     | Nom  | 0.75 | 0.02 | 0.203 | 0.40 | 6.00 | 3.40 | 5.00 | 4.00 | 1.27 | 0.60 |
|        | Max  | 0.80 | 0.05 | 0.250 | 0.50 | 6.10 | 3.50 | 5.10 | 4.10 |      | 0.75 |

- 1. Both the package length and width do not include the mold flash.
- 2. The exposed metal pad area on the bottom of the package is floating.
- 3. Coplanarity  $\leq$ 0.08mm. Package edge tolerance  $\leq$ 0.10mm.
- 4. The lead shape may be of little difference according to different package lead frames. These lead shapes are compatible with each other.



**GD25R32C** 

# **12 REVISION HISTORY**

| Version No | Description     | Page | Date       |
|------------|-----------------|------|------------|
| 1.0        | Initial release | All  | 2020-10-12 |

## **Important Notice**

This document is the property of GigaDevice Semiconductor (Beijing) Inc. and its subsidiaries (the "Company"). This document, including any product of the Company described in this document (the "Product"), is owned by the Company according to the laws of the People's Republic of China and other applicable laws. The Company reserves all rights under such laws and no Intellectual Property Rights are transferred (either wholly or partially) or licensed (either expressly or impliedly). The names and brands of third party referred thereto (if any) are the property of their respective owner and referred to for identification purposes only.

The Company does not assume any warranty or condition, express or implied, with regard to this document or any Product, including, but not limited to, the implied warranties of merchantability, fitness for any particular purpose, noninfringement, or any warranty arising out of the application or use of any Product described in this document. Any information provided in this document is provided only for reference purposes. It is the responsibility of the user of this document to properly design, program, and test the functionality and safety of any application and any product produced. Except for customized products which has been expressly identified in the applicable agreement, the Products are designed, developed, and/or manufactured for ordinary business, industrial, personal, and/or household applications only. The Products are not designed or intended for use in, and no warranty is made respect to, any applications designed or intended for the operation of weaponry, nuclear equipment, atomic energy control instruments, combustion control instruments, airplane or spaceship instruments, traffic signal instruments, life-support devices or systems, other medical devices or systems (including resuscitation equipment and surgical implants etc.), pollution control or hazardous substances management, or other uses where failure to perform can reasonably be expected to result in personal injury, death, property or environmental damage ("Unintended Uses"). Customers shall take any and all actions to ensure using and selling the Products in accordance with the applicable laws and regulations. The Company is not liable, in whole or in part, and customers shall and hereby do release the Company as well as it's suppliers and/or distributors from any claim, damage, or other liability arising from or related to all Unintended Uses of the Products. Customers shall indemnify and hold the Company as well as it's suppliers and/or distributors harmless from and against all claims, costs, damages, and other liabilities, including claims for personal injury or death, arising from or related to any Unintended Uses of the Products. Customers shall discard the device according to the local environmental law.

Information in this document is provided solely in connection with the Products. The Company reserves the right to make changes, corrections, modifications or improvements to this document and the Products and services described herein at any time, without notice. And the company shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.

# 单击下面可查看定价,库存,交付和生命周期等信息

>>GigaDevice(兆易创新)