# M.2 2280 640-C Datasheet (SQF-SM8xx-xxxGCSBx) ## **CONTENTS** | 1. Overview | 4 | |----------------------------------------|----| | 2. Features | | | 3. Specification Table | | | 4. General Description | | | 5. Pin Assignment and Description | | | 5.1 M.2 2280 Interface Pin Assignments | | | 6. Identify Device Data | | | 7. ATA Command Set | 17 | | 8. System Power Consumption | 23 | | 8.1 Supply Voltage | 23 | | 8.2 Power Consumption | 23 | | 9. Physical Dimension | | | Appendix: Part Number Table | | ### **Revision History** | Rev. | Date | History | |------|-----------|------------------------------------------------------| | 1.0 | 2021/1/22 | 1. Preliminary | | 1.1 | 2021/1/29 | Update power consumption | | 1.2 | 2021/4/9 | 1. Add 3D sTLC solution | | 1.3 | 2021/5/2 | Add temperature information | | 1.4 | 2021/9/8 | Update description of Hardware write protect support | | | | | | | | | | | | | Advantech reserves the right to make changes without further notice to any products or data herein to improve reliability, function, or design. Information furnished by Advantech is believed to be accurate and reliable. However, Advantech does not assure any liability arising out of the application or use of this information, nor the application or use of any product or circuit described herein, neither does it convey any license under its patent rights nor the rights of others. Copyright © 1983-2021 Advantech Co., Ltd. All rights reserved. ### 1. Overview Advantech SQFlash 640-C series M.2 2280 (SQF-SM8 640-C) delivers all the advantages of flash disk technology with the Serial ATA I/II/III interface and are fully compliant with MO-300 M.2 2280 specification. The SQF-SM8 640-C is designed to operate at a maximum operating frequency of 200MHz with 30MHz external crystal. Its capacity could provide a wide range up to 1TB. Moreover, it can reach up to 550MB/s read as well as 490MB/s write high performance based on 3D TLC/sTLC flash (with 32MB SDR enabled and measured by CrystalDiskMark v5.0). The power consumption of SQF-SM8 640-C is much lower than traditional hard drives, making it the best embedded solution for new platforms. ### 2. Features #### Standard SATA interface - Support SATA 1.5/3.0/6.0 Gbps interface - SATA Revision 3.2 compliant - Operating Voltage: 3.3V - TRIM · AHCI supported - Temperature Ranges - Commercial Temperature - 0°C to 70°C for operating - -40°C to 85°C for storage - Industrial Temperature - -40°C to 85°C for operating - -40°C to 85°C for storage #### Mechanical Specification Shock: 1,500G / 0.5ms Vibration: 20G / 80~2,000Hz #### Humidty Humidity: 5% ~ 95% under 55°C ■ Acquired RoHS \ WHQL \ CE \ FCC Certificate ■ Acoustic: 0 dB ■ Dimension: 80.0 mm x 22.0 mm x 3.8 mm ## 3. Specification Table ### **■** Performance | | | Sequential Performance<br>(MB/sec) | | Random Performance<br>(IOPS @4K) | | |--------------------|--------|------------------------------------|--------|----------------------------------|--------| | | | Read | Write | Read | Write | | | 32 GB | 304.30 | 138.10 | 21,047 | 34,249 | | | 64 GB | 554.60 | 286.50 | 40,671 | 69,890 | | 3D TLC | 128 GB | 557.70 | 466.70 | 65,899 | 83,107 | | (BiCS4) | 256 GB | 556.70 | 501.70 | 77,969 | 85,584 | | | 512 GB | 553.30 | 508.80 | 79,248 | 87,487 | | | 1 TB | 554.30 | 509.20 | 78,935 | 88,178 | | | 16 GB | 558.10 | 300.50 | 41,718 | 69,407 | | 0D TI 0 | 32 GB | 559.40 | 459.50 | 64,406 | 81,331 | | 3D sTLC<br>(BiCS4) | 64 GB | 560.80 | 495.60 | 71,955 | 84,973 | | (5,004) | 128 GB | 560.60 | 497.10 | 72,105 | 84,738 | | | 256 GB | 548.00 | 506.60 | 70,467 | 87,032 | <sup>\*</sup> All performance above are tested with AHCI mode. <sup>\*</sup> Tested by CrystalDiskMark 1GB workload. #### Endurance JEDEC defined an endurance rating TBW (TeraByte Written), following by the equation below, for indicating the number of terabytes a SSD can be written which is a measurement of SSDs' expected lifespan, represents the amount of data written to the device. ### TBW = [(NAND Endurance) x (SSD Capacity)] / WAF • NAND Endurance: Program / Erase cycle of a NAND flash. SLC: 100,000 cyclesUltra MLC: 30,000 cycles o MLC: 3,000 cycles 3D TLC (BiCS3/BiCS4): 3,000 cycles 3D sTLC (BiCS4): 30,000 cycles • SSD Capacity: SSD physical capacity in total of a SSD. • **WAF**: Write Amplification Factor (WAF), as the equation shown below, is a numerical value representing the ratio between the amount of data that a SSD controller needs to write and the amount of data that the host's flash controller writes. A better WAF, which is near to 1, guarantees better endurance and lower frequency of data written to flash memory. #### WAF = (Lifetime write to flash) / (Lifetime write to host) Endurance measurement is based on New JEDEC 219 Client Workload and verified with following workload conditions. Test duration: over 168hrs (=7 days) File Size: Follow by JEDEC 219 | 3D TLC<br>(BiCS4) | WAF | TBW | DWPD* | |-------------------|------|------|-------| | 32 GB | 3.84 | 25 | 0.71 | | 64 GB | 2.91 | 66 | 0.94 | | 128 GB | 3.15 | 122 | 0.87 | | 256 GB | 2.98 | 258 | 0.92 | | 512 GB | 2.52 | 609 | 1.08 | | 1 TB | 2.54 | 1208 | 1.07 | | 3D sTLC<br>(BiCS4) | WAF | TBW | DWPD* | |--------------------|-----|------|-------| | 16 GB | 2.2 | 213 | 12.15 | | 32 GB | 1.8 | 520 | 14.84 | | 64 GB | 1.8 | 1041 | 14.85 | | 128 GB | 1.8 | 2083 | 14.86 | | 256 GB | 1.8 | 5000 | 17.83 | <sup>\*</sup> The endura nce of SSD could be estimated based on users' behaviors, NAND endurance cycles, and write amplification factor. It is not guaranteed by the flash vendor. TBW may vary from flash configuration and platform. <sup>\*</sup> Endurance of 1 drive writes per day (DWPD) for 3 years ### 4. **General Description** #### **■** Error Correction Code (ECC) Flash memory cells will deteriorate with use, which might generate random bit errors in the stored data. Thus, SQFlash 640-C series M.2 2280 applies the LDPC (Low Density Parity Check) of ECC algorithm, which can detect and correct errors occur during read process, ensure data been read correctly, as well as protect data from corruption. #### Wear Leveling NAND flash devices can only undergo a limited number of program/erase cycles, and in most cases, the flash media are not used evenly. If some areas get updated more frequently than others, the lifetime of the device would be reduced significantly. Thus, Wear Leveling is applied to extend the lifespan of NAND Flash by evenly distributing write and erase cycles across the media. SQFlash provides advanced Wear Leveling algorithm, which can efficiently spread out the flash usage through the whole flash media area. Moreover, by implementing both dynamic and static Wear Leveling algorithms, the life expectancy of the NAND flash is greatly improved. #### ■ Bad Block Management Bad blocks are blocks that include one or more invalid bits, and their reliability is not guaranteed. Blocks that are identified and marked as bad by the manufacturer are referred to as "Initial Bad Blocks". Bad blocks that are developed during the lifespan of the flash are named "Later Bad Blocks". SQFlash implements an efficient bad block management algorithm to detect the factory-produced bad blocks and manages any bad blocks that appear with use. This practice further prevents data being stored into bad blocks and improves the data reliability. #### ■ Power Loss Protection: Flush Manager Power Loss Protection is a mechanism to prevent data loss during unexpected power failure. DRAM is a volatile memory and frequently used as temporary cache or buffer between the controller and the NAND flash to improve the SSD performance. However, one major concern of the DRAM is that it is not able to keep data during power failure. Accordingly, SQFlash SSD applies the Flush Manager technology, only when the data is fully committed to the NAND flash will the controller send acknowledgement (ACK) to the host. Such implementation can prevent false-positive performance and the risk of power cycling issues. In addition, it is critical for a controller to shorten the time the in-flight data stays in the controller internal cache. Thus, SQFlash applies an algorithm to reduce the amount of data resides in the cache to provide a better performance. With Flush Manager, incoming data would only have a "pit stop" in the cache and then move to NAND flash directly. Also, the onboard DDR will be treated as an "organizer" to consolidate incoming data into groups before written into the flash to improve write amplification. #### ■ TRIM TRIM is a feature which helps improve the read/write performance and speed of solid-state drives (SSD). Unlike hard disk drives (HDD), SSDs are not able to overwrite existing data, so the available space gradually becomes smaller with each use. With the TRIM command, the operating system can inform the SSD which blocks of data are no longer in use and can be removed permanently. Thus, the SSD will perform the erase action, which prevents unused data from occupying blocks all the time. #### ■ SMART SMART, an acronym for Self-Monitoring, Analysis and Reporting Technology, is an open standard that allows a hard disk drive to automatically detect its health and report potential failures. When a failure is recorded by SMART, users can choose to replace the drive to prevent unexpected outage or data loss. Moreover, SMART can inform users of impending failures while there is still time to perform proactive actions, such as copy data to another device. #### ■ Over-Provision Over Provisioning refers to the inclusion of extra NAND capacity in a SSD, which is not visible and cannot be used by users. With Over Provisioning, the performance and IOPS (Input/Output Operations per Second) are improved by providing the controller additional space to manage P/E cycles, which enhances the reliability and endurance as well. Moreover, the write amplification of the SSD becomes lower when the controller writes data to the flash. #### Hardware Write Protect Pin A 2-pin header is mounted and connected to controller reserved GPIO for the drive write protection. When the pins are opened, all of the write command will be carried to a buffer area without real programming to the Flash IC. So the data won't be saved in this mode and will be totally discarded upon power shutting down. The GPIO pin is reserved on the PCB and default set to Write Protect function. **On-board GPIO for Write Protection** ### ■ Thermal Throttling (3D TLC/sTLC only) Thermal Throttling function is for protecting the drive and reducing the possibility of read / write error due to overheat. The temperature is monitored by the thermal sensor. As the operating temperature continues to increase to threshold temperature, the Thermal Throttling mechanism is activated. At this time, the performance of the drive will be significantly decreased to avoid continuous heating. When the operating temperature falls below threshold temperature, the drive can resume to normal operation. REV 1.4 Page 9 of 25 Sep. 8, 2021 ### **Block Diagram** #### ■ LBA value | Density | LBA | |---------|---------------| | 16 GB | 31,277,232 | | 32 GB | 62,533,296 | | 64 GB | 125,045,424 | | 128 GB | 250,069,680 | | 256 GB | 500,118,192 | | 512 GB | 1,000,215,216 | | 1 TB | 2,000,409,264 | ## 5. Pin Assignment and Description ### 5.1 M.2 2280 Interface Pin Assignments | Pin# | SATA Pin | Description | |------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | CONFIG_3 = GND | Ground | | 2 | 3.3V | Supply pin | | 3 | GND | Ground | | 4 | 3.3V | Supply pin | | 5 | N/C | No Connect | | 6 | N/C | No Connect | | 7 | N/C | No Connect | | 8 | N/C | No Connect | | 9 | N/C or GND Note | No Connect or Ground | | 10 | DAS/DSS# (O) (OD) | Status indicators via LED devices that will be provided by the system Active Low. A pulled-up LED with series current limiting resistor should allow for 9mA when On. | | 11 | N/C | No Connect | | 12 | Module Key | | | 13 | Module Key | | | 14 | Module Key | | | 15 | Module Key | | | 16 | Module Key | | | 17 | Module Key | | | 18 | Module Key | | | 19 | Module Key | | | 20 | N/C | No Connect | | 21 | CONFIG_0 = GND | Ground | | 22 | N/C | No Connect | | 23 | N/C | No Connect | | 24 | N/C | No Connect | | 25 | N/C | No Connect | | 26 | N/C | No Connect | | 27 | GND | Ground | | 28 | N/C | No Connect | | 29 | N/C | No Connect | | 30 | GPIO_WP | Write Protection GPIO (optional) | | 31 | N/C | No Connect | | 32 | N/C | No Connect | | 33 | GND | Ground | | 34 | N/C | No Connect | | 35 | N/C | No Connect | | 36 | N/C | No Connect | | |----|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--| | 37 | N/C | No Connect | | | 38 | DEVSLP (I) (0/3.3V) | Device Sleep, Input. When driven high the host is informing the SSD to enter a low power state (default NC, DEVSLP disable) | | | 39 | GND | Ground | | | 40 | N/C | No Connect | | | 41 | SATA-B+ | SATA differential signals in the SATA specification | | | 42 | N/C | No Connect | | | 43 | SATA-B- | SATA differential signals in the SATA specification | | | 44 | N/C | No Connect | | | 45 | GND | Ground | | | 46 | N/C | No Connect | | | 47 | SATA-A- | SATA differential signals in the SATA specification | | | 48 | N/C | No Connect | | | 49 | SATA-A+ | SATA differential signals in the SATA specification | | | 50 | N/C | No Connect | | | 51 | GND | Ground | | | 52 | N/C | No Connect | | | 53 | N/C | No Connect | | | 54 | N/C | No Connect | | | 55 | N/C | No Connect | | | 56 | Reserved for MFG<br>Data | Manufacturing Data line. Used for SSD manufacturing only. Not used in normal operation. Pins should be left N/C in platform Socket. | | | 57 | GND | Ground | | | 58 | Reserved for MFG<br>Clock | Manufacturing Clock line. Used for SSD manufacturing only. Not used in normal operation. Pins should be left N/C in platform Socket | | | 59 | Module Key | | | | 60 | Module Key | | | | 61 | Module Key | | | | 62 | Module Key | | | | 63 | Module Key | | | | 64 | Module Key | | | | 65 | Module Key | | | | 66 | Module Key | | | | 67 | GPIO_QE | Quick Erase GPIO (optional) | | | 68 | SUSCLK (I) (0/3.3V) | 32 kHz clock supply input that is provided by PCH to reduce power and cost for the module. (default NC) | | | 69 | CONFIG_1 = GND | Defines module type | | | 70 | 3.3V | Supply pin | | | 71 | GND | Ground | | | 72 | 3.3V | Supply pin | |----|----------------|------------| | 73 | GND | Ground | | 74 | 3.3V | Supply pin | | 75 | CONFIG_2 = GND | Ground | ### 6. Identify Device Data The Identity Device Data enables Host to receive parameter information from the device. The parameter words in the buffer have the arrangement and meanings defined in below table. All reserve bits or words are zero | Word | ATA Identify Parameter | Value | |-------|-------------------------------------------------------------------------------|-------------------| | 0 | General configuration bit-significant information | 0040h | | 1 | Obsolete | *1 | | 2 | Specific configuration | C837h | | 3 | Obsolete | 0010h | | 4-5 | Retired | 0000000h | | 6 | Obsolete | 003Fh | | 7-8 | Reserved for assignment by the Compact Flash Association | 0000000h | | 9 | Retired | 0000h | | 10-19 | Serial number (20 ASCII characters) | Varies | | 20-21 | Retired | 00000000h | | 22 | Obsolete | 0000h | | 23-26 | Firmware revision (8 ASCII characters) | Varies | | 27-46 | Model number (xxxxxxxx) | Varies | | 47 | 7:0- Maximum number of sectors transferred per interrupt on MULTIPLE commands | 8010h | | 48 | Trusted Computing feature set options(not support) | 4000h | | 49 | Capabilities | 2F00h | | 50 | Capabilities | 4000h | | 51-52 | Obsolete | 00000000h | | 53 | Words 88 and 70:64 valid | 0007h | | 54 | Obsolete | *1 | | 55 | Obsolete | 0010h | | 56 | Obsolete | 003Fh | | 57-58 | Obsolete | *2 | | 59 | Sanitize and Number of sectors transferred per interrupt on MULTIPLE commands | 5D10h | | 60-61 | Maximum number of sector ( 28bit LBA mode) | *3 | | 62 | Obsolete | 0000h | | 63 | Multi-word DMA modes supported/selected | 0407h | | 64 | PIO modes supported | 0003h | | 65 | Minimum Multiword DMA transfer cycle time per word | 0078h | | 66 | Manufacturer's recommended Multiword DMA transfer cycle time | 0078h | | 67 | Minimum PIO transfer cycle time without flow control | 0078h | | 68 | Minimum PIO transfer cycle time with IORDY flow control | 0078h | | 69 | Additional Supported (support download microcode DMA) | 0D00h | | 70 | Reserved | 0000h | | 71-74 | Reserved for the IDENTIFY PACKET DEVICE command | 0000000000000000h | | 75 | Queue depth | 001Fh | | 76 | Serial SATA capabilities | E70Eh | | 77 | Serial ATA Additional Capabilities | 0086h | | 78 | Serial ATA features supported | 014Ch | | <b>l</b> 79 | Serial ATA features enabled | 0040h | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | 80 | | 0040ff<br>0FF8h | | | Major Version Number | + | | 81 | Minor Version Number | 0000h | | 82 | Command set supported | 706Bh | | 83 | Command set supported | 7409h | | 84 | Command set/feature supported extension | 6163h | | 85 | Command set/feature enabled | 7069h | | 86 | Command set/feature enabled | B401h | | 87 | Command set/feature default | 6163h | | 88 | Ultra DMA Modes | 007Fh | | 89 | Time required for security erase unit completion | 0001h | | 90 | Time required for Enhanced security erase completion | 001Eh | | 91 | Current advanced power management value | 0000h | | 92 | Master Password Revision Code | FFFEh | | 02 | Hardware reset result. For SATA devices, word 93 shall be set to the | 2020 | | 93 | value 0000h. | 0000h | | 94 | Obsolete | 0000h | | 95 | Stream Minimum Request Size | 0000h | | 96 | Streaming Transfer Time – DMA | 0000h | | 97 | Streaming Access Latency – DMA and PIO | 0000h | | 98-99 | Streaming Performance Granularity | 0000h | | 100-103 | Maximum user LBA for 48 bit Address feature set | *4 | | 104 | Streaming Transfer Time – PIO | 0000h | | 105 | Maximum number of 512-byte blocks per DATA SET MANAGEMENT command | 0008h | | 106 | Physical sector size/Logical sector size | 4000h | | 107 | Inter-seek delay for ISO-7779 acoustic testing in microseconds | 0000h | | 108-111 | World Wide Name | Varies | | | <u> </u> | 1 201100 | | 112-115 | Reserved | 000000000000000h | | 116 | Reserved | 0000h | | 117-118 | Words per logical Sector | 0000000h | | 119 | Supported settings | 411Ch | | 120 | Command set/Feature Enabled/Supported | 401Ch | | 121-126 | Reserved | 0h | | 127 | Obsolete | 0h | | 128 | Security status | 0021h | | 129-140 | Vendor specific | Varies | | 141 | Vendor specific | Varies | | 142-159 | Vendor specific | Varies | | 160 | Reserved for CFA | 0h | | 161-167 | Reserved for CFA | 0h | | 168 | Device Nominal Form Factor | Varies | | 169 | DATA SET MANAGEMENT command is supported | 0001h | | 170-173 | Additional Product Identifier | 0h | | 174-175 | Reserved | 0h | | 176-205 | Current media serial number | 0h | | 206 | SCT Command Transport | 0h | | | Telegraphic contracts and the second | | | 207-208 | Reserved | 0h | |---------|------------------------------------------------------------------------------------|-------| | 209 | Alignment of logical blocks within a physical block | 4000h | | 210-211 | Write-Read-Verify Sector Count Mode 3 (not support) | 0000h | | 212-213 | Write-Read-Verify Sector Count Mode 2 (not support) | 0000h | | 214-216 | Obsolete | 0000h | | 217 | Non-rotating media device | 0001h | | 218 | Reserved | 0h | | 219 | NV Cache relate (not support) | 0h | | 220 | Write read verify feature set current mode | 0h | | 221 | Reserved | 0h | | 222 | Transport major version number | 10FFh | | 223 | Transport minor version number | 0000h | | 224-229 | Reserved | 0h | | 230-233 | Extend number of user addressable sectors | 0h | | 234 | Minimum number of 512-byte data blocks per DOWNLOAD MICROCODE command for mode 03h | 0001h | | 235 | Maximum number of 512-byte data blocks per DOWNLOAD MICROCODE command for mode 03h | FFFEh | | 236-254 | Reserved | 0h | | 255 | Integrity word (Checksum and Signature) | XXA5h | | Capacity | *1 | *2 | *3 | *4 | |----------|------------------|----------------|----------------|------------------| | (GB) | (Word 1/Word 54) | (Word 57 – 58) | (Word 60 – 61) | (Word 100 – 103) | | 16 | 3FFFh | FBFC10h | 1DD40B0h | 1DD40B0h | | 32 | 3FFFh | FBFC10h | 3BA2EB0h | 3BA2EB0h | | 64 | 3FFFh | FBFC10h | 7740AB0h | 7740AB0h | | 128 | 3FFFh | FBFC10h | EE7C2B0h | EE7C2B0h | | 256 | 3FFFh | FBFC10h | FFFFFFFh | 1DCF32B0h | | 512 | 3FFFh | FBFC10h | FFFFFFFh | 3B9E12B0h | | 1024 | 3FFFh | FBFC10h | FFFFFFFh | 773BD2B0h | ## 7. <u>ATA Command Set</u> [Command Set List] | Op-Code | Command Description | Op-Code | Command Description | |---------|--------------------------------------|---------|------------------------------| | 00h | NOP | 91h | Initialize Device Parameters | | 06h | Data Set Management | 92h | Download Microcode | | 10h-1Fh | Recalibrate | 93h | Download Microcode DMA | | 20h | Read Sectors | B0h | SMART | | 21h | Read Sectors without Retry | B4h | Sanitize | | 24h | Read Sectors EXT | C4h | Read Multiple | | 25h | Read DMA EXT | C5h | Write Multiple | | 29h | Read Multiple EXT | C6h | Set Multiple Mode | | 2Fh | Read Log EXT | C8h | Read DMA | | 30h | Write Sectors | C9h | Read DMA without Retry | | 31h | Write Sectors without Retry | CAh | Write DMA | | 34h | Write Sectors EXT | CBh | Write DMA without Retry | | 35h | Write DMA EXT | CEh | Write Multiple FUA EXT | | 38h | CFA Write Sectors Without Erase | E0h | Standby Immediate | | 39h | Write Multiple EXT | E1h | Idle Immediate | | 3Dh | Write DMA FUA EXT | E2h | Standby | | 3Fh | Write Long EXT | E3h | Idle | | 40h | Read Verify Sectors | E4h | Read Buffer | | 41h | Read Verify Sectors without Retry | E5h | Check Power Mode | | 42h | Read Verify Sectors EXT | E6h | Sleep | | 44h | Zero EXT | E7h | Flush Cache | | 45h | Write Uncorrectable EXT | E8h | Write Buffer | | 47h | Read Log DMA EXT | EAh | Flush Cache EXT | | 57h | Write Log DMA EXT | ECh | Identify Device | | 60h | Read FPDMA Queued | EFh | Set Features | | 61h | Write FPDMA Queued | F1h | Security Set Password | | 70h-76h | Seek | F2h | Security Unlock | | 77h | Set Date & Time EXT | F3h | Security Erase Prepare | | 78h | Accessible Max Address configuration | F4h | Security Erase Unit | | 79h-7Fh | Seek | F5h | Security Freeze Lock | | 90h | Execute Device Diagnostic | F6h | Security Disable Password | Note: ND = Non-Data Command PI = PIO Data-In Command PO = PIO Data-Out Command DM = DMA Command DD = Execute Diagnostic Command #### [Command Set Descriptions] #### 1. CHECK POWER MODE (code: E5h); This command allow host to determine the current power mode of the device. #### 2. DOWNLOAD MICROCODE (code: 92h); This command enables the host to alter the device's microcode. The data transferred using the DOWNLOAD MICROCODE command is vendor specific. All transfers shall be an integer multiple of the sector size. The size of the data transfer is determined by the content of the LBA Low register and the Sector Count register. This allows transfer sizes from 0 bytes to 33,553,920 bytes, in 512bytes increments. #### 3. EXECUTE DEVICE DIAGNOSTIC (code: 90h); This command performs the internal diagnostic tests implemented by the module. #### 4. FLUSH CACHE (code: E7h); This command used by the host to request the device to flush the write cache. #### 5. FLUSH CACHE EXT (code: EAh); This command is used by the host to request the device to flush the write cache. If there is data in the write cache, that data shall be written to the media. #### 6. IDENTIFY DEVICE (code: ECh); The IDENTIFY DEVICE command enables the host to receive parameter information from the module. #### 7. IDLE (code: 97h or E3h); This command allows the host to place the module in the IDLE mode and also set the Standby timer. INTRQ may be asserted even through the module may not have fully transitioned to IDLE mode. If the Sector Count register is non-"0", then the Standby timer shall be enabled. The value in the Sector Count register shall be used to determine the time programmed into the Standby timer. If the Sector Count register is "0" then the Standby timer is disabled. #### 8. IDLE IMMEDIATE (code: E1h); This command causes the module to set BSY, enter the Idle (Read) mode, clear BSY and generate an interrupt. #### 9. INITIALIZE DEVICE PARAMETERS (code: 91h); This command enables the host to set the number of sectors per track and the number of heads per cylinder. #### 10. NOP (code: 00h); If this command is issued, the module respond with command aborted. ### 11. READ BUFFER (code: E4h); This command enables the host to read the current contents of the module's sector buffer. #### 12. READ DMA (code: C8h or C9h); This command reads from "1" to "256" sectors as specified in the Sector Count register using the DMA data transfer protocol. A sector count of "0" requests "256" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 13. READ DMA Ext (code: 25h); This command allows the host to read data using the DMA data transfer protocol. #### 14. READ MULTIPLE (code: C4h); This command performs similarly to the READ SECTORS command. Interrupts are not generated on each sector, but on the transfer of a block which contains the number of sector per block is defined by the content of word 59 in the IDENTIFY DEVICE response. #### 15. READ MULTIPLE EXT (code: 29h); This command performs similarly to the READ SECTORS command. The number of sectors per block is defined by a successful SET MULTIPLE command. If no successful SET MULTIPLE command has been issued, the block is defined by the device's default value for number of sectors per block as defined in bits (7:0) in word 47 in the IDENTIFY DEVICE information. #### 16. READ NATIVE MAX ADDRESS (code: F8h); This command returns the native maximum address. The native maximum address is the highest address accepted by the device in the factory default condition. #### 17. READ NATIVE MAX ADDRESS EXT (code: 27h); This command returns the native maximum address. #### 18. READ SECTOR(S) (code: 20h or 21h); This command reads from "1" to "256" sectors as specified in the Sector Count register. A sector count of "0" requests "256" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 19. READ SECTOR(S) EXT (code: 24h); This command reads from "1" to "65536" sectors as specified in the Sector Count register. A sector count of "0" requests "65536" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 20. READ VERIFY SECTOR(S) (code: 40h or 41h); This command is identical to the READ SECTORS command, except that DRQ is never set and no data is transferred to the host. #### 21. READ VERIFY SECTOR(S) EXT (code: 42h); This command is identical to the READ SECTORS command, except that DRQ is never set and no data is transferred to the host. #### 22. RECALIBRATE (code: 1Xh); This command return value is select address mode by the host request. #### 23. SECURITY DISABLE PASSWORD (code: F6h); This command transfers 512 bytes of data from the host. Table defines the content of this information. If the password selected by word 0 match the password previously saved by the device, the device shall disable the Lock mode. This command shall not change the Master password. The Master password shall be reactivated when a User password is set. #### 24. SECURITY ERASE PREPARE (code: F3h); This command shall be issued immediately before the SECURITY ERASE UNIT command to enable device eraseing and unlocking. #### 25. SECURITY ERASE UNIT (code: F4h); This command transfer 512 bytes of data from the host. Table## defines the content of this information. If the password does not match the password previously saved by the device, the device shall reject the command with command aborted. The SECURITY ERASE PREPARE command shall be completed immediately prior to the SECURITY ERASE UNIT command. Specifications subject to change without notice, contact your sales representatives for the most update information. REV 1.4 Page 19 of 25 Sep. 8, 2021 #### 26. SECURITY FREEZE LOCK (code: F5h); This command shall set the device to frozen mode. After command completion any other commands that update the device Lock mode shall be command aborted. Frozen shall be disabled by power-off or hardware reset. If SECURITY FREEZE LOCK is issued when the drive is in frozen mode, the drive executes the command and remains in frozen mode. #### 27. SECURITY SET PASSWORD (code: F1h); This command transfer 512 bytes of data from the host. Table defines the content of this information. The data transferred controls the function of this command. Table defines the interaction of the identifier and security level bits. #### 28. SECURITY UNLOCK (code: F2h); This command transfer 512 bytes of data from the host. Table (as Disable Password) defines the content of this information. If the Identifier bit is set to Master and the device is in high security level, then the password supplied shall be compared with the stored Master password. If the device is in maximum security level then the unlock shall be rejected. If the identifier bit is set to user then the device shall compare the supplied password with the stored User password. If the password compare fails then the device shall return command aborted to the host and decrements the unlock counter. This counter shall be initially set to five and shall be decremented for each password mismatch when SECURITY UNLOCK is issued and the device is locked. When this counter reachs zero then SECURITY UNLOCK and SECURITY ERASE UNIT command shall be aborted unitl a power-on or a hardware reset. #### 29. SEEK (code: 7Xh); This command performs address range check. #### 30. SET MAX ADDRESS (code: F9h); After successful command completion, all read and write access attempts to address greater than specified by the successful SET MAX ADDRESS command shall be rejected with an IDNF error. IDENTIFY DEVICE response words (61:60) shall reflect the maximum address set with this command. #### 31. SET MAX ADDRESS EXT (code: 37h); After successful command completion, all read and write access attempts to address greater than specified by the successful SET MAX ADDRESS command shall be rejected with an IDNF error. IDENTIFY DEVICE response words (61:60) shall reflect the maximum address set with this command. #### 32. SET FEATURE (code: EFh); This command is used by the host to establish parameters that affect the execution of certain device features. #### 33. SET MULTIPLE MODE (code: C6h); This command enables the device to perform READ and Write Multiple operations and establishes the block count for these commands. #### 34. SLEEP (code: 99h or E6h); This command causes the module to set BSY, enter the Sleep mode, clear BSY and generate an interrupt. #### SMART READ DATA (code: B0h with Feature register value of D0h); This command returns the Device SMART data structure to the host. Specifications subject to change without notice, contact your sales representatives for the most update information. REV 1.4 Page 20 of 25 Sep. 8, 2021 #### 36. SMART ENABLE/DISABLE AUTO SAVE (code: B0h with Feature register value of D2h); This command enables and disables the optional attribute autosave feature of the device. #### 37. SMART EXECUTE OFF\_LINE (code: B0h with Feature register value of D4h); This command causes the device to immediately initiate the optional set of activities that collect SMART data in an off-line mode and then save this data to the device's non-volatile memory, or execute a self-diagnostic test routine in either captive or off-line mode. #### 38. SMART READ LOG (code: B0h with Feature register value of D5h); This command returns the specified log data to the host. #### 39. SMART ENABLE OPERATION (code: B0h with Feature register value of D8h); This command enables access to all SMART capabilities within the device. Prior to receipt of this command SMART data are neither monitored nor saved by the device. #### 40. SMART DISABLE OPERATION (code: B0h with Feature register value of D9h); This command disables all SMART capabilities within the device including any and all timer and event count functions related exclusively to this feature. After command acceptance the device shall disable all SMART operations. After receipt of this command by the device, all other SMART commands including SMART DISABLE OPERATION commands, with exception of SMART ENABLE OPERATIONS, are disabled and invalid and shall be command aborted by the device. #### 41. SMART RETURN STATUS (code: B0h with Feature register value of DAh); This command causes the device to communicate the reliability status of the device to the host. #### 42. STANDBY (code: E2h); This command causes the module to set BSY, enter the Standby mode, clear BSY and return the interrupt immediately. #### 43. STANDBY IMMEDIATE (code: E0h); This command causes the module to set BSY, enter the Standby mode, clear BSY and return the interrupt immediately. #### 44. WRITE BUFFER (code: E8h); This command enables the host to overwrite contents of the module's sector buffer with any data pattern desired. #### 45. WRITR DMA (code: CAh or CBh); This command writes from "1" to "256" sectors as specified in the Sector Count register using the DMA data transfer protocol. A sector count of "0" requests "256" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 46. WRITR DMA EXT (code: 35h); This command writes from "1" to "65536" sectors as specified in the Sector Count register using the DMA data transfer protocol. A sector count of "0" requests "65536" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 47. WRITE MULTIPLE (code: C5h); This command is similar to the WRITE SECTORS command. Interrupts are not presented on each sector, but on the transfer of a block which contains the number of sectors defined by Set Multiple command. #### 48. WRITE MULTIPLE EXT (code: 39h); This command is similar to the WRITE SECTORS command. Interrupts are not presented on each sector, but on the transfer of a block which contains the number of sectors defined by Set Multiple command. #### 49. WRITE SECTOR(S) (code: 30h); This command writes from "1" to "256" sectors as specified in the Sector Count register. A sector count of "0" requests "256" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 50. WRITE SECTOR(S) EXT (code: 34h); This command writes from "1" to "65536" sectors as specified in the Sector Count register. A sector count of "0" requests "65536" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 51. WRITE SECTOR(S) W/O ERASE (code: 38h); This command writes from "1" to "256" sectors as specified in the Sector Count register. A sector count of "0" requests "256" sectors transfer. The transfer begins at the sector specified in the Sector Number register. #### 52. WRITE VERIFY (code: 3Ch); This command is similar to the WRITE SECTOR(S) command, except that each sector is verified before the command is completed. ## System Power Consumption Supply Voltage | Parameter | Rating | | |-------------------|--------|--| | Operating Voltage | 3.3V | | ### 8.2 Power Consumption | (mV | V) | Read | Write | Idle | Slumber | |--------------------|--------|-------|-------|------|---------| | 3D TLC<br>(BiCS4) | 32 GB | 950 | 800 | 225 | 15 | | | 64 GB | 1,250 | 1,100 | 225 | 15 | | | 128 GB | 1,350 | 1,300 | 250 | 15 | | | 256 GB | 1,380 | 1,400 | 250 | 15 | | | 512 GB | 1,400 | 1,380 | 250 | 15 | | | 1 TB | 1,800 | 1,600 | 250 | 15 | | 3D sTLC<br>(BiCS4) | 16 GB | 1,250 | 1,100 | 225 | 15 | | | 32 GB | 1,350 | 1,300 | 250 | 15 | | | 64 GB | 1,380 | 1,400 | 250 | 15 | | | 128 GB | 1,400 | 1,380 | 250 | 15 | | | 256 GB | 1,800 | 1,600 | 250 | 15 | ## 9. Physical Dimension M.2 2280 (Unit: mm) ## **Appendix: Part Number Table** | Product | Advantech PN | |----------------------------------------------------|--------------------| | SQF M.2 2280 640-C 32G 3D TLC (BiCS4) (0~70°C) | SQF-SM8V1-32GCSBC | | SQF M.2 2280 640-C 64G 3D TLC (BiCS4) (0~70°C) | SQF-SM8V2-64GCSBC | | SQF M.2 2280 640-C 128G 3D TLC (BiCS4) (0~70°C) | SQF-SM8V2-128GCSBC | | SQF M.2 2280 640-C 256G 3D TLC (BiCS4) (0~70°C) | SQF-SM8V2-256GCSBC | | SQF M.2 2280 640-C 512G 3D TLC (BiCS4) (0~70°C) | SQF-SM8V4-512GCSBC | | SQF M.2 2280 640-C 1T 3D TLC (BiCS4) (0~70°C) | SQF-SM8V4-1TCSBC | | SQF M.2 2280 640-C 16G 3D sTLC (BiCS4) (0~70°C) | SQF-SM8Z2-16GCSBC | | SQF M.2 2280 640-C 32G 3D sTLC (BiCS4) (0~70°C) | SQF-SM8Z2-32GCSBC | | SQF M.2 2280 640-C 64G 3D sTLC (BiCS4) (0~70°C) | SQF-SM8Z2-64GCSBC | | SQF M.2 2280 640-C 128G 3D sTLC (BiCS4) (0~70°C) | SQF-SM8Z4-128GCSBC | | SQF M.2 2280 640-C 256G 3D sTLC (BiCS4) (0~70°C) | SQF-SM8Z4-256GCSBC | | SQF M.2 2280 640-C 16G 3D sTLC (BiCS4) (-40~85°C) | SQF-SM8Z2-16GCSBE | | SQF M.2 2280 640-C 32G 3D sTLC (BiCS4) (-40~85°C) | SQF-SM8Z2-32GCSBE | | SQF M.2 2280 640-C 64G 3D sTLC (BiCS4) (-40~85°C) | SQF-SM8Z2-64GCSBE | | SQF M.2 2280 640-C 128G 3D sTLC (BiCS4) (-40~85°C) | SQF-SM8Z4-128GCSBE | | SQF M.2 2280 640-C 256G 3D sTLC (BiCS4) (-40~85°C) | SQF-SM8Z4-256GCSBE |