1. Field of the Invention
The present invention is about producing and/or updating flash memory card technology, in particular to a system and method for producing high volume flash memory card, which can be used for updating or repairing flash memory card as well.
2. Description of Related Art
The NAND flash memory cards, such as SD (Secure Digital), MMC (Multi-Media Card), SM (Smart Media), MS (Memory Stick) and CF (Compact Flash) cards are popularly applied in digital camera, mobile phone, PDA, MP3/MP4 player for their small volume, large capacity and high performance/price ratio. The structure of a normal flash memory card includes the following devices:
(1) Interface unit: usually is an interface connector or golden finger complied with the flash memory card's specification.
(2) Controller unit: provides at least one flash memory card signal interface and one storage media interface, completing the functionality of data transfer, card information configuration, card status report, etc.
(3) Storage media: provides the storage space for the memory card in which data as well as the executable program code are stored. The storage media can be NAND flash, NOR flash, EEPROM, EPROM, etc. Typically, as the names is, the storage media of a flash memory card is of NAND flash for its small volume, large capacity and high performance/price ratio.
(4) PCB (Printed Circuit Board): supports the above devices and connection among them for making up a memory card's structure.
With the fast changing market, there appears more and more different electronic consumer product, which also causes more and more compatibility problems to the appertain product, such as flash memory cards. Thus card manufacturer must settle the compatibility problem as fast as they can so that their production can meet the fast changing market's requirement.
To solve these problems, at the present market, most of the flash memory cards are provided with a RAM basing strategy. That is to say, the controller of the flash memory card has hardware architecture, but the main function was realized by software which is stored outside of the controller. This strategy has the advantages that when the flash memory card encounters the compatibility problem, what the card manufacturer needs to do is to just modify the software outside of the controller, without having to modify the controller's hardware.
For the flash memory card having the nonvolatile storage media, the firmware code is usually stored in the nonvolatile storage media. When being powered on, the controller firstly reads out the firmware code from the storage media and then executes the firmware. This strategy is very flexible so that it can meet the fast changing market. On the other hand, card manufacturer can fix an error card by the way of updating card's firmware, so they save the cost as well.
Since the firmware is saved outside storage media, the card manufacturers need to download the firmware code to the outside storage media and check them after they finished assembling the card.
For a NAND flash card, the NAND flash usually has 2% of bad blocks and these bad blocks are randomly distributed in the whole storage area. Therefore, the card manufacturers need to scan and pick out the bad blocks of the flash to avoid the data stored into the bad blocks, so that the product can meet the high reliability of performance.
As above said, after assembling the card, the card manufacturer needs to download the firmware to nonvolatile storage media, scan and pick out the bad blocks of the NAND flash to ensure the storage capacity and functionality. This process is known as “card re-initialization”. To a memory card with any errors, the card manufacturer needs to download the fixed new firmware to replace the old firmware, so that the card can be reusable. This process is known as “card repairing”. It is not advisable for people to complete the card re-initialization or card repairing process manually one by one. This cannot meet the requirement of mass production. Therefore it is desirable to continue improving the volume production methodology for the above flash memory cards.
The objective of the present invention is to provide a system and method for producing high volume flash memory cards, which is completely automatic and applicable for mass production of flash memory card.
According to one aspect, the present invention which achieves the objectives for producing high volume flash memory cards, which includes: a processing unit; a PC interface for connecting to an external PC; a PC drive circuit connected to the PC interface and the processing unit for realizing communication between the PC and the processing unit; at least one card interface for connecting to an external flash memory card; and at least one card drive circuit connected to the card interface and the processing unit for realizing communication between the flash memory card and the processing unit. The processing unit receives command or data from the PC interface, and sends card re-initialization command or data to the flash memory card via the card interface.
According to another aspect, the present invention which achieves the object relates to a method for producing high volume flash memory cards, which includes the steps of: (A) configuring options for card re-initialization on the PC; (B) inserting at least one flash memory card into the card interface; (C) receiving a start command from the PC and checking whether the inserted flash memory card is the same type as what selected in the configured option, and if it is, step (D) is executed; (D) checking whether to erase code area of the flash memory card, and if selected, step (E) is executed, otherwise step (F) is executed; (E) erasing the code area of the flash memory card; (F) initializing the flash memory card by writing card information to the flash memory card; (G) receiving firmware code from the PC interface, and saving the firmware code in the processing unit; (H) writing the firmware code into the flash memory card and checking correction; and (I) scanning and excluding bad blocks of the flash memory card.
Other objectives, advantages, and novel features of the invention will become more apparent from the following detailed description when taken in conjunction with the accompanying drawings.
The invention is about a system and method for mass production of flash memory card, applicable for high volume of card re-initialization and card repairing. The system is made of hardware entity and its corresponding man-machine conversation software. The man-machine conversation software runs on a PC (Personal Computer), providing an operation and configuration platform for customer. The hardware entity includes, as shown in
The processing unit 11, as shown in
The CPU 21 executes the firmware code stored in the memories 22, 23 and 24, receives the command or data from the PC interface, sends the card re-initialization command or data to the external flash memory card 19 via the card interface 17, sends the operation signal to the external manipulator via the PLC interface 16 as well.
The PC interface 15 connects to external PC 18 by cable. In common use, this PC interface 15 may be serial port, parallel port, USB, PCMCIA or a mixed interface as well.
The PC drive circuit 12 realizes the communication between the processing unit 11 and the external PC 18 via the PC interface 15. The PC drive circuit 12 implements function of interface drive circuit and logic control. If PC interface 15 is a serial port, the PC drive circuit 12 implements the function of serial port's drive and logic control. So do other interfaces. The PC drive circuit 12 may be a mixed interface drive circuits as well, that is to say, it can meet multi-interface's specification, and user may select one of them to use.
The PLC interface 16 provides the connection between the processing unit 11 and the external manipulator, completing the fully automatic operation of card re-initialization and/or card repairing.
The PLC drive circuit 13 realizes the communication between the external manipulator and the present system via the PLC interface 16. The PLC drive circuit 13 implements the interface drive circuit and logic control. The operation programs for the external manipulator is compiled and packed with the firmware code. The CPU 21 executes the firmware code, and outputs the driving signals on the PLC interface 16 so that the external manipulator will complete the operation.
The card interface 17 provides the socket of the external flash memory card 19. The external flash memory card 19 may be SD and/or MMC and/or SM and/or MC and/or CF and/or other flash memory card. This card interface 17 can be expanded to n card interfaces, as shown in
The card drive circuit 14 is used as a host of the external flash memory card 19. It completes the communication between the external flash memory card 19 and the processing unit 11. The main function of this card drive circuit 14 is translating the command from the CPU 11 to the type of command to the flash memory card 19 that complies with the flash memory card's specification. Thus the flash memory card 19 can accept the command and do the required operation. These required operation commands include code downloading, parameter setting, scan blocks and backup BBT, formatting card, etc., used for card re-initialization and card repairing. This card drive circuit 14 can also be expanded to m card drive circuits, as shown in
According to
The invention provides a man-machine conversation software interface via the PC interface 15, so that card manufacturer can configure and send command for card re-initialization and/or card repairing, such as selecting the code that needs to be downloaded to the flash memory card 19, whether using encrypt way when downloading code, whether erasing before downloading the code, whether formatting after card re-initialization and/or card repairing. These configuration options can be changed or set to default by the card manufacturer via the man-machine conversation software interface.
With the man-machine conversation software interface, the card manufacturer configures the parameter on the PC 18. The configuration options include selecting the code that need to be downloaded, whether using encrypt way when downloading, whether erasing before downloading the code, whether formatting after card re-initialization and/or card repairing. After the step of configuration, the card manufacturer sends the start command to the system. The processing unit 11 receives the start command from the PC interface 15. Then the CPU 21 sends card re-initialization commands to the flash memory card 19 via the card drive circuit 14 and card interface 17. The card drive circuit 14 translates the commands to the type of commands that comply with the flash memory card's specification. The external flash memory card 19 receives and responds these commands, completing the relative cooperation.
After receiving the start command from the PC, the flash memory card checks the bus status to confirm whether the type of the flash memory card under test is the same as what the card manufacturer selected (S603). If it is not fit, an error is reported to the card manufacturer. If it is, step S604 is executed.
In step S604, it checks whether the card manufacturer selects erase code area. If selected, step S605 is executed; if not, step S606 is executed. For a used card with an old firmware version, step S604 must be set to affirmative, otherwise the new code will be written in error.
In step S605, the firmware code area of the flash memory card is erased.
In step S606, the flash memory card is initialized. Card initialization process is writing card information, such as vendor symbol, card serial number, software version, hardware version, etc., to the external flash memory card.
In step S607, the selected firmware code is received from the PC interface 15, and saved to the storage memory 22, 23 or 24.
In step S608, the firmware code is written into the flash memory card and the correction is checked.
In step S609, it scans and excludes the bad blocks of the flash memory card.
In step S610, it checks whether to format the flash memory card. If so, the flash memory card is formatted (step S611); otherwise, the card re-initialization process is ended, and card re-initialization completion is reported to the card manufacturer.
In the system, the firmware code can be updated by the CPU 21. The firmware code is stored in the nonvolatile storage memory 24. When it needs to be updated, the CPU 21 will write the new firmware code into the code area of the nonvolatile storage memory 24 to replace the old code. Thus when the system is rebooted, the CPU 21 will execute the new firmware code in the nonvolatile storage memory 24.
The system can be used to repair a flash memory card as well. The flow chart of the card repairing is similar to the flow chart of card re-initialization, as shown in
Although the present invention has been explained in relation to its preferred embodiment, it is to be understood that many other possible modifications and variations can be made without departing from the spirit and scope of the invention as hereinafter claimed.
This application is a continuation-in-part (CIP) of U.S. patent application for “High Volume Testing for USB Electronic Data Flash Card”, U.S. application Ser. No. 11/626,347, filed Jan. 23, 2007, which is a continuation-in-part of U.S. patent application for “ELECTRONIC DATA STORAGE MEDIUM WITH FINGERPRINT VERIFICATION CAPABILITY”, U.S. application Ser. No. 09/478,720, filed Jan. 6, 2000, and “Flash Memory Controller For Electronic Data Flash Card”, U.S. application Ser. No. 11/466,759, filed on Aug. 23, 2006, which is a CIP of “System and Method for Controlling Flash Memory”, U.S. application Ser. No. 10/789,333, filed on Feb. 26, 2004, now abandoned. This application is also related to “Integrated circuit card with fingerprint verification capability” application Ser. No. 09/366,976, filed on Aug. 4, 1999, now U.S. Pat. No. 6,547,130, all of which are incorporated herein as though set forth in full.
Number | Date | Country | |
---|---|---|---|
Parent | 11626347 | Jan 2007 | US |
Child | 11979102 | Oct 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09478720 | Jan 2000 | US |
Child | 11979102 | Oct 2007 | US |
Parent | 11466759 | Aug 2006 | US |
Child | 11979102 | Oct 2007 | US |
Parent | 10789333 | Feb 2004 | US |
Child | 11979102 | Oct 2007 | US |