# High-Volume Programming of NAND Flash Kelly Hirsch Chief Technologist Data I/O Corporation # Programming NAND - What is Programming? - Why NAND? - Programming and Time-to-Market - Two stories---NOR and NAND - Avoiding Pitfalls in Programming NAND - Further Information # What is programming? - "Programming" a device is the process of writing content to the non-volatile memory - Flash (NAND and NOR) - Flash cards (MMC, SD) - Flash based microcontrollers - Logic (FPGAs, CPLDs, etc.) - Programming methods: - In-System Programming (ISP) - In socket - Manual - Automated - Off-line - On-line # Typical Programming Process - Insertion test - ID Check - Blank check (erase if not blank) - Write content (gang mode) - Write dynamic data (serial number, etc.) - Verify content against original image - Apply sector protection (if any) # **Image Creation Tool** #### **Desktop Automated Programming** # **Programming Methods** Engineering, R&D **FlashPAK** Just in time **Programming** **Road Runner Series** Off-line **Programming** **PS Series** In-System **Programming** **Image Writer** # Why do I care about programming? - Time from design to production is critical for short "life time" products: - 1 month delay = 15% of potential revenue - 3 month delay = 50% of potential revenue - Sub-standard programming methods cost semiconductor companies millions of dollars per line (due to RMAs) # Why use NAND (vs. NOR)? - NAND is less expensive than NOR - NAND can program faster than NOR - NAND has more endurance than NOR - MLC NAND is available in large densities # Cell Phone Internal Memory Forecast Internal Storage = NAND (only) shadowed into LP DRAM # So what's wrong with NAND? - NAND has to be "shadowed" into volatile memory (pSRAM, LPDRAM, etc.) before you can use it in an eXecute-in-Place (XiP) application. - NAND can have defective memory cells; typically NAND is delivered from the factory with entire blocks of memory marked as "bad". - You will permanently damage a NAND device if you erase the entire device. - Writing and erasing NAND can cause a block to go bad at any time; statistically significant at over 1000 cycles; ECC required. - MLC can have more "bit-flips" than SLC; more ECC bits required. - Programming NAND flash is much more complicated! # Flash Memory What's needed to program NAND? to identify defective blocks of memory and know what to do when they are found. ## ✓ ■ Error Detection/Correction Code (EDC, ECC) to verify the data each time you read it, detect corrupted bits and recover the original data. ### X ■ Wear leveling where frequent read/writes are required, a program is used to keep track of the used locations and move this activity around to different physical locations. ### ★ ■ Garbage collection where previous versions of data (that have been updated and placed somewhere else) are erased so that a complete erase block is available to the system for more storage. # Memory Bad-block Scheme Example #### Data #### **NAND** BAD # emory But there are many schemes... Logical Block Skip 4 Block Skip File System Map **GSL Skip** MODE2, MODE3 Pantech BBM Qualcomm MSM6100 MSM6100 EFS Reserved Block Area Samsung GBBM SAM GBBM DWSwap Samsung WinCE Skip Bad Blocks **Thales Navigation** Datalight Flash FX Unistore V1.8 Why? # Matching the Application ### Two stories on time-to-market The following stories are true---names have been removed to protect the "innocent". # First...programming NOR | NOR Process | Elapsed Time | |---------------------------------------------------------------------------------|--------------| | <ul> <li>Manufacturing manager orders<br/>adapters and algorithm for</li> </ul> | Day 0 | | programming equipment. | | | <ul> <li>Receive adapter and algorithm.</li> </ul> | Day 14 | | <ul> <li>Receive binary image from design team.</li> </ul> | Day 15 | | <ul> <li>Pilot run to validate set-up.</li> </ul> | Day 16 | | <ul> <li>Ready for full-rate production.</li> </ul> | Day 17 | # Memory Second...programming NAND | | • | |---------------------------------------|-------| | Manufacturing manager orders adapters | | | and algorithm for programming | Day 0 | | equipment. | | | Data I/O informs manager that NAND | | | requires bad-block scheme. Asks for | Day 1 | | contact from design team. | | | Manager contacts design team and | Day 2 | | asks them to contact Data I/O. | Day Z | they have to contact Data I/O. No action for a week. Design team doesn't understand why NAND Process Day 9 Elapsed Time # FlashMemory Programming NAND (cont.) | NAND Process (cont.) | Elapsed Time | |----------------------------------------------------------------------------------------------------------------------------------|---------------| | <ul> <li>Design lead informs Data I/O that<br/>file-system is supplied by third party;<br/>sends contact information.</li> </ul> | Day 11 | | <ul> <li>Data I/O contacts file system vendor;<br/>explains problem.</li> </ul> | Day 14 | | <ul> <li>File system vendor requires NDA;<br/>executes NDA.</li> </ul> | <i>Day 19</i> | | <ul> <li>Data I/O interviews file system<br/>vendor; documents bad-block<br/>scheme requirements.</li> </ul> | Day 22 | | <ul> <li>Data I/O writes code for bad-block<br/>scheme and sends beta to design<br/>lead.</li> </ul> | Day 27 | # Flash Memory Programming NAND (cont.) | NAND Process (cont.) | Elapsed Time | |----------------------------------------------------------------------------------------------------------------------------|--------------| | <ul> <li>Design team tests algorithm but phone<br/>won't boot. Begin troubleshooting.</li> </ul> | Day 29 | | <ul> <li>Design team asks file system vendor for help.</li> </ul> | Day 31 | | <ul> <li>File system vendor informs design team<br/>of change in driver; updates bad-block<br/>scheme document.</li> </ul> | Day 33 | | <ul> <li>Data I/O modifies scheme and sends<br/>new algorithm to design team.</li> </ul> | Day 35 | | <ul> <li>Design team tests algorithm; phone<br/>boots OK! Design team informs<br/>production manager.</li> </ul> | Day 37 | # Programming NAND (cont.) | | NAND Process (cont.) | Elapsed Time | |---|------------------------------------------------------------------------------------------------------------------|--------------| | • | Production manager receives adapter and validated algorithm from Data I/O. | Day 39 | | • | Receives binary image from design team. | Day 40 | | • | Pilot run to validate set-up. | Day 42 | | • | Pilot run fails due to checksum problem. | Day 43 | | • | Data I/O helps to troubleshoot problem; ECC data is added to image. Manufacturing updates process documentation. | Day 45 | | • | Now pilot run is successful! | Day 46 | | • | Ready for full-rate production. | Day 47 | # What went wrong? Neither the design team nor the manufacturing team realized that, with NAND devices, the programming algorithm must comprehend more than just the device characteristics; it also needs to "know" how the NAND device is accessed in the application. # Programming NAND vs. NOR ### **Avoid Common Pitfalls** - If you use ECC (in the spare area), the checksum for the image will change. Provide manufacturing with the right checksum in the "version control documentation". - If you create a bad-block scheme that requires several good blocks in certain area, the job yield will decrease. - Is one bit error during verify a failure, or does your application allow this? Define this before pilot run. - Erase NAND; don't blank check. This is much faster (but be sure to use bad-block scheme during erase). - Make sure bad-block scheme documentation is complete: - Mapping tables, partition information, dynamic fields, etc.? - Document all the parameters for manufacturing! #### **Bad Block Handling Type = "Qualcomm MSM6100 EFS"** **Spare Area** = "Enabled" if the image contains the spare area data and that data should be programmed into the device. "Disabled" if the image does not contain the spare area data and only the main array should be programmed. "ECC" Calculates the ECC data and programs it into the spare area. **EFS: Image Start Block** This is the beginning block of the File System. All blocks in the image after this are considered to be in the File System and will be placed after the start block. EFS: Device Start Block This is the block number to place the File System on the device. **EFS: Boot/Code Partition Size** This variable defines the size of the Boot/Code (first) partition size in blocks. Required good block area: Start block = "0" This will require the entered block to be a valid block **Required good block area: Number of blocks = "0"** This will be the total number of blocks required to be valid after the start block. #### **Bad Block Handling Type = "Datalight FlashFX Pro"** **Spare Area** = Always "Enabled", the image contains spare area data and that data must be programmed into the device. Format of the spare area is dependent upon the specific NAND configuration. "ECC" Calculates the ECC data and programs it into the spare area. **Image Start Block** This is the beginning block of the File System. All blocks in the image after this are considered to be in the File System and will be placed after the start block. **Device Start Block** This is the block number to place the File System on the device. Boot/Code Partition Size This variable defines the size of the Boot/Code (first) partition size in blocks. # Include bad-block parameters in your Version Control Document. #### **Version Control Document** **Bad Block Handling Type:**Qualcomm MSM6100 EFS **Spare Area:** ECC EFS: Image Start Block 1023 **EFS: Device Start Block** 1023 **EFS: Boot/Code Partition Size** 950 Required good block area start block: 10 Number of blocks 1 ### Data I/O's Questionnaire #### Bad-Block Scheme Questionnaire This questionnaire must be filled out entirely to assist Data I/O in meeting your NAND needs. Please provide all of the required information. Please attach any documents such as specifications and example source code to this document. - 1. What is the name of your bad-block scheme and how does it handle bad blocks? - 2. Do you use the spare area? (the last 16 bytes of each page, also referred to as "redundant" area) - 3. If you use the spare area, will the data be contained in your data file, or does Data I/O need to calculate the values? - 4. If the spare area information is to be calculated by Data I/O, please provide the structure of the spare area below: | 512 | 513 | 514 | 515 | 516 | 517 | 518 | 519 | |-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | - If you are using ECC calculations, please provide your ECC algorithm code at the end of this document or as an e-mail attachment. - Will you be using a file system? If so, please describe the file system details. - 7. Are there any portions of your image file that must go at fixed locations in the device, regardless of whether any bad blocks are encountered prior to that location? If so, please describe. Also, if a bad block is found at that location, should the device fail? - 8. Are there any special structures that need to be programmed in the device that need to be calculated by Data I/O? Examples of these would be any mapping tables, partition information, etc. If so, please provide the structure in detail at the end of this document. Specify Big Endian or Little Endian format. - 9. Please list any dynamic fields that need to be programmed to the device that must be given to you as a parameter at job creation time. An example would be if you need to program a code version number into the device that is not contained in the data file, or if a particular region of the device needs to be # Flash Memory SDK for NAND Bad Block Scheme - Visual Studio application for simulation of bad-block handling methods - Distributed with source code which integrates into Data I/O algorithms - Can be used with input and output text files to simulate effects of bad blocks during programming of image file - Your code is integrated into algorithm and tested by Data I/O. ### Final Recommendations - Ask semiconductor FAEs to bring in programming solutions vendor - Use Data I/O's SDK to validate bad-block scheme during design process - Create bad-block scheme document as part of design process - Document dynamic fields for each model as part of version control documentation # For further reading... - Optimizing a Flash Media Manager for NAND Flash Imaging (Datalight) - Two Technologies Compared: NOR vs. NAND (M-Systems) - Programming NAND Devices (Data I/O Corporation) ### Data I/O's "NAND Portal" # Thank you! Kelly Hirsch Chief Technologist Data I/O Corporation 425-867-6246 hirschk@dataio.com www.dataio.com