US5603056A - Disk drive control computer and method for rewriting control program in flash EEPROM with serial communication using unassigned pins of SCSI or ATA connector - Google Patents

Disk drive control computer and method for rewriting control program in flash EEPROM with serial communication using unassigned pins of SCSI or ATA connector Download PDF

Info

Publication number
US5603056A
US5603056A US08/302,014 US30201494A US5603056A US 5603056 A US5603056 A US 5603056A US 30201494 A US30201494 A US 30201494A US 5603056 A US5603056 A US 5603056A
Authority
US
United States
Prior art keywords
control program
program
nonvolatile
rewrite
host computer
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
US08/302,014
Inventor
Tokuyuki Totani
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Toshiba Corp
Original Assignee
Toshiba Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Toshiba Corp filed Critical Toshiba Corp
Assigned to KABUSHIKI KAISHA TOSHIBA reassignment KABUSHIKI KAISHA TOSHIBA ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: TOTANI, TOKUYUKI
Application granted granted Critical
Publication of US5603056A publication Critical patent/US5603056A/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates

Definitions

  • the present invention relates to a control computer used in a hard disk drive, for example.
  • a hard disk drive includes a microcomputer serving as a control computer for controlling various circuits constituting the HDD such as a servo circuit, a read/write circuit of a head and a motor driver/motor controller.
  • the control computer is a dedicated computer for executing predetermined control operations under the control of a control program.
  • control program is fixedly stored in a read only memory (ROM) comprised of an IC memory.
  • ROM read only memory
  • the control program must be changed depending on the product specification.
  • the hard disk drive must be customized depending on a customer's needs.
  • the ROM is mounted on an IC socket. The use of IC socket permits the replacement of the ROM, to thereby change the control program.
  • the contact failure is apt to be caused when the ROM is inserted into the IC socket. Further, the cost is increased by the addition of the IC socket. Furthermore, a space for mounting the IC socket must be secured on the print circuit board. On the other hand, if the ROM is welded to the print circuit board without the IC socket, the ROM is not replaceable, which is impractical.
  • EEPROM electrically erasable programmable read only memory
  • the EEPROM is a nonvolatile and rewritable ROM which permits erase and rewrite operations.
  • the EEPROMs are classified into a type in which the erase operation is performed in units of words, a type in which the erase operation is performed in units of blocks or rows, and a type in which erase operation is performed over the entire memory array, which is referred to as bulk erase.
  • the EEPROM of bulk erase type is referred to as a flash EEPROM. Because of low cost, the flash EEPROM is used in place of the above described ROM.
  • the use of the flash EEPROM permits the change of the control program without changing the memory itself. More specifically, the control program stored in the flash EEPROM may be replaced with a new control program supplied from a host computer, for example.
  • An object of the present invention is to provide a control computer and a method for rewriting a control program which permit both the control program and a rewrite program to be stored in a same EEPROM and the replacement of the control program, without increasing the cost and the number of components.
  • a control computer comprises: a nonvolatile and rewritable memory storing a control program for controlling a drive of a storage device and a rewrite program for rewriting the control program; a volatile memory for temporarily storing the rewrite program and an externally supplied new control program; and a central processing unit (CPU) performing the following operations of: saving the rewrite program stored in the nonvolatile and rewritable memory in the volatile memory, erasing the nonvolatile and rewritable memory, restoring the rewrite program stored in the volatile memory in the erased nonvolatile and rewritable memory, receiving the new control program supplied externally and storing in the volatile memory, loading the new control program stored in the volatile memory in the nonvolatile and rewritable memory, and executing the new control program in the nonvolatile and rewritable memory.
  • CPU central processing unit
  • a control computer comprises: a nonvolatile and rewritable memory having a control program area storing a control program for controlling a drive of a storage device and a rewrite program area storing a rewrite program for rewriting the control program; volatile memory for temporarily storing the rewrite program and an externally supplied new control program; and a central processing unit (CPU) for performing the following operations of: loading the rewrite program stored in the rewrite program area in the nonvolatile and rewritable memory into the volatile memory to thereby execute the rewrite program in the volatile memory, receiving a new control program supplied externally, erasing the control program area in the nonvolatile and rewritable memory, loading the received new control program into the erased control program area in the nonvolatile and rewritable memory and executing the new control program loaded in the control program area in the nonvolatile and rewritable memory.
  • CPU central processing unit
  • a control program and a rewrite program are stored together in a flash EEPROM or an EEPROM.
  • the rewrite program is first saved in the RAM.
  • the CPU executes the rewrite program in the RAM to thereby erase entire memory array of the flash EEPROM and restore the rewrite program in the erased flash EEPROM.
  • the CPU receives a new control program from a host unit and stores in the RAM.
  • the CPU loads the new control program stored in the RAM into the flash EEPROM. Thereafter, the CPU controls the hard disk drive in accordance with the new control program stored in the flash EEPROM.
  • the CPU when the control program and the rewrite program are stored together in the EEPROM, the CPU loads the rewrite program in the EEPROM into the RAM to thereby execute the rewrite program. Then, the CPU receives a new control program supplied from a host computer and stores in the RAM. Further, the CPU erases only an area storing the control program in the EEPROM and loads the new control program stored in the RAM into the erased area in the EEPROM. Then, the CPU controls the hard disk drive in accordance with the new control program stored in the EEPROM.
  • FIG. 1 is a block diagram showing a main portion of a control microcomputer according to an embodiment of the present invention
  • FIG. 2 is a block diagram showing a main portion of an HDD using the control microcomputer in FIG. 1;
  • FIG. 3 is a memory map of the flash EEPROM (or EEPROM) in FIGS. 1 and 2;
  • FIG. 4 is a memory map of the RAM shown in FIGS. 1 and 2;
  • FIG. 5 is a flowchart of a rewrite operation when the flash EEPROM is used in which all the memory array are erased.
  • FIG. 6 is a flowchart of a rewrite operation when the EEPROM is used in which the erase operation is performed in units of blocks.
  • FIG. 1 is a block diagram showing a main portion of a control computer according to the embodiment of the present invention, and more particularly to a control microcomputer for controlling a hard disk drive (HDD).
  • HDD hard disk drive
  • control microcomputer 1 comprises a central processing unit (CPU) 2, a random access memory (RAM) 3 in which a rewrite program is temporarily stored for rewriting a control program for controlling the HDD, an I/O interface 4, and a flash EEPROM (or EEPROM) 5 storing the control program for controlling the HDD.
  • CPU central processing unit
  • RAM random access memory
  • flash EEPROM or EEPROM
  • the CPU 2 executes the control program stored in the flash EEPROM (or EEPROM) 5 to control various circuits of the HDD shown in FIG. 2.
  • the flash EEPROM (or EEPROM) 5 comprises an control program area 5a and a rewrite program area 5b.
  • the control program area 5a has a capacity of 128K bytes for example, and stores the control program for controlling the HDD.
  • the rewrite program area 5b has a capacity of 1K bytes for example and stores the rewrite program for rewriting the control program in the control program area 5a.
  • the rewrite program area 5b also stores a jump vector which indicates a start address of the rewrite program.
  • the CPU 2 has two operation modes, namely a control mode and a rewrite mode.
  • the CPU 2 controls the HDD in accordance with the control program stored in the flash EEPROM (or EEPROM) 5.
  • the CPU 2 rewrites the control program stored in the flash EEPROM (EEPROM) 5 to a new control program supplied from a host computer in accordance with the control program temporarily stored in the RAM 3.
  • the designation of the control mode or the rewrite mode is performed by inputting a corresponding command from the host computer. More specifically, the rewrite program comprises two parts, namely a mode switching routine and a rewrite routine.
  • the CPU 2 jumps to an address designated by the jump vector, namely a start address of the mode switching routine.
  • the CPU 2 jumps directly to the start address of the rewrite routine.
  • the RAM 3 comprises a rewrite program area 3a, a new control program area 3b, a stack area 3c, other program and data area 3d and a register bank area 3e.
  • the rewrite program area 3a has a capacity of 1K bytes and temporarily stores the rewrite program read out from the flash EEPROM (or EEPROM) 5.
  • the I/O interface 4 connects the control microcomputer 1 to the host computer 7 to receive a new control program or a new rewrite program from the host computer and to permit exchange of other programs and data therebetween. More specifically, the I/O interface 4 is implemented by a universal asynchronous receiver/transmitter (UART).
  • the I/O interface 4 is based on Small Computer Systems Interface (SCSI) or ATA (AT attachment), for example and uses unassigned two pins (one for receiving data and the other for transmitting data) of a SCSI connector or an ATA connector to perform serial transmission between the CPU 2 and the host computer 7.
  • the stack area 3c stores various parameters such as a return address of a subroutine or temporarily stores contents of registers.
  • the other program/data area 3d temporarily stores programs other than the control program and the rewrite program and data supplied from the host computer 7.
  • the register bank area 3e are memory mapped registers.
  • FIG. 2 shows a block diagram of the HDD using the control microcomputer 1.
  • the HDD is provided with an head 10 for reading data from or writing data into a disk serving as a recording medium 15, a spindle motor 16 for rotating the disk 15 and a voice coil motor (VCM) 17 for seeking the disk radially.
  • the spindle motor 16 and the VCM 17 are each driven by a motor drive/motor control unit 18.
  • the unit 18 drives the spindle motor 16 using control signals from the control microcomputer 1.
  • the unit 18 drives the VCM 17 using control signals from a servo circuit 19.
  • the control microcomputer 1 controls a read/write (R/W) circuit 12 to supply a write signal to the head 10 through a head IC 11, and reproduces a read signal from the head 10.
  • the servo circuit 19 supplies a control signal to the unit 18 in order to position the head 10 in the center of the target cylinder.
  • a hard disk controller (HDC) 13 serves as an interface between a host computer 7 and the HDD to exchange data and interface signals therebetween.
  • the HDC 13 accesses a buffer RAM 14 for temporarily storing the read and write data.
  • the CPU 2 controls various circuits shown in FIG. 2 in accordance with the control program stored in the control program area 5a of the EEPROM 5.
  • an operator inputs a command instructing the rewrite operation such as "LM" (Loader Mode) from the host computer 7 to set the CPU in the rewrite mode.
  • a command instructing the rewrite operation such as "LM" (Loader Mode) from the host computer 7 to set the CPU in the rewrite mode.
  • the CPU 2 in the HDD directly jumps to the start address of the rewrite routine stored in the rewrite program area 5b in the flash EEPROM 5. Then, the CPU 2 executes the rewrite routine in the rewrite program area 5b.
  • FIG. 5 shows the operation of the rewrite routine. In FIG.
  • the CPU 2 saves the rewrite program (the jump vector, the mode switching routine, and the rewrite routine) stored in the rewrite program area 5b in the flash EEPROM 5 into the rewrite program area 3a in the RAM 3 (step S1) so as not to be erased by the erase operation to be described later.
  • the rewrite program stored in the rewrite program area 5b in the flash EEPROM 5 is saved in the rewrite routine area 3a in the RAM 3
  • the rewrite program in the rewrite program area 5b switches a program counter (not shown) of the CPU 2 to the start address of the rewrite program saved in the rewrite program area 3a in the RAM 3.
  • the CPU 2 executes the rewrite routine saved in the RAM 3 (step S3).
  • the CPU 2 erases the entire memory array of the flash EEPROM 5 (step S5). After the flash EEPROM 5 is erased, the CPU 2 restores the rewrite program saved in the area 3a of the RAM 3 into the area 5b of the flash memory 5 (step S7). Then, the CPU 2 receives a new control program by one block (64 bytes or 128 bytes) from the host computer 7 through the UART 4 (step S9). Then, the CPU 2 stores the received one block of new control program into the new control program area 3b of the RAM 3. In step S13, the CPU 2 loads the one block of new control program stored in the area 3b of the RAM 3 into the control program area 5a of the flash EEPROM 5.
  • the first block of the new control program supplied from the host computer 7 is a control block which indicates whether or not the new control program has been correctly written.
  • the control block is filled with a null code.
  • the CPU 2 writes, in the control block, data indicating the validity of the new control program.
  • the CPU 2 verifies whether or not the one block of new control program has been correctly written in the area 5a (step S15).
  • step S17 the CPU 2 checks whether or not all the blocks of new control program have been written in the area 5a. If not, the CPU 2 returns to the step S9 and repetitively executes steps S9 to S17 until all the blocks of new control program have been written in the area 5a.
  • the CPU 2 If it is determined that all the blocks of new control program have been written in the area 5a in step S17, the CPU 2 writes into the control block in the area 5a data indicating the validity of the new control program, and informs the completion of the rewrite operation to the host computer 7, and switches the program counter of the CPU 2 to a predetermined address of the rewrite program in the area 5b. Then, an operator inputs a command such as "MA" designating the control mode from the host computer 7. In response to this command, the CPU 2 is set in the control mode. More specifically, the CPU 2 first jumps to the jump vector in the area 5b. The jump vector indicates a start address of the mode switching routine in the area 5b. Accordingly, the CPU 2 executes the mode switching routine.
  • the mode switching routine checks the control block in the area 5a to determine the validity of the new control program. Since the control block indicates that the new control program has been correctly written, the CPU 2 jumps to the start address of the new control program in the area 5a to thereby execute the new control program to control the HDD (step S19).
  • the rewrite operation of the rewrite program stored in the EEPROM 5 which permits erase operation in units of blocks will now be described with reference to the flowchart shown in FIG. 6.
  • the process for which the CPU enters into the rewrite mode is the same as that in the case of FIG. 5 and therefore the description thereof will be omitted.
  • the rewrite program stored in the rewrite program area 5b is not erased by the erase operation.
  • the rewrite program in the area 5b cannot be read out while writing the new control program into the area 5a. Therefore, the CPU 2 loads the rewrite program in the area 5b into the rewrite program area 3a of the RAM 3 (step S21).
  • the rewrite program in the area 5b switches a program counter of the CPU 2 to the start address of the rewrite program loaded in the area 3a.
  • the CPU 2 executes the rewrite program loaded in the area 3a (step S23).
  • the CPU 2 receives the new control program by one block (64 bytes or 128 bytes) from the host computer 7 through the UART 4.
  • the CPU 2 stores the received one block of new control program in the area 3b of the RAM 3.
  • the CPU 2 loads the one block of new control program stored in the area 3b into the area 5b.
  • the EEPROM 5 itself performs the erase operation by one block in a hardware manner before writing the one block of new control program (step S27).
  • step S31 the CPU 2 verifies whether or not the one block of new control program has been correctly written in the area 5a (step S31).
  • step S33 the CPU 2 checks whether or not all the blocks of new control program have been written in the area 5a. If not, the CPU 2 returns to step S25 and repetitively executes steps S25 to S33 until all the blocks of new control program have been written in the area 5a.
  • step S33 If it is determined in step S33 that all the blocks of new control program have been written in the area 5athe CPU 2 writes into the control block in area 5a data indicating the validity of the new control program, and informs, the completion of the rewrite operation is informed to the host computer 7, and switches the program counter of the CPU 2 to a predetermined address of the rewrite program in the area 5b . Then, an operator inputs a command such as "MA" designating the control mode from the host computer 7. In response to this command, the CPU 2 is set in the control mode. More specifically, the CPU 2 first jumps to the jump vector in the area 5b. The jump vector indicates a start address of the mode switching routine in the area 5b. Accordingly, the CPU 2 executes the mode switching routine.
  • a command such as "MA" designating the control mode from the host computer 7.
  • the mode switching routine checks the control block in the area 5a to determine the validity of the new control program. Since control block indicates that the new control program has been correctly written, the CPU 2 jumps to the start address of the new control program in the area 5a to thereby execute the new control program to control the HDD (step S35).
  • the rewrite program is stored together with the control program in the flash EEPROM (or EEPROM) 5. Then, the rewrite program is saved or loaded in the RAM 3 to execute the rewrite program. Accordingly, the CPU 2 can write the new control program supplied from the host computer 7 in the flash EEPROM or the EEPROM 5 while reading the rewrite program in the RAM 3. As a result, the ROM 6 storing the rewrite program which has been built in the conventional HDD can be eliminated.
  • control program stored in the flash EEPROM or the EEPROM 5 is replaced with the new control program supplied from the host computer 7.
  • the present invention is not limited to the above embodiment.
  • the rewrite program stored in the flash EEPROM or the EEPROM may be replaced with a new rewrite program supplied from the host computer 7.
  • the replacement of the rewrite program is performed in the same manner as the replacement of the control program and therefore, the description thereof will be omitted.
  • control program for controlling the HDD has been exemplified.
  • the present invention can be applied to other drives of storage devices such as a floppy disk, a flexible disk, an optical disk, a magnet-optical disk, a CD-ROM, and a video disk, and also to other I/O controllers including a control CPU such as a keyboard controller, a printer controller, and a display controller.

Abstract

A control program for controlling an HDD and a rewrite program for rewriting the control program are stored together in a flash EEPROM. Upon entering the rewrite mode, a CPU in the HDD saves the control program in the flash EEPROM into the RAM. The CPU erases the flash EEPROM and restores the rewrite program of the RAM into the EEPROM. The CPU receives a new control program from a host computer and loads it in the flash EEPROM. The erasing of the flash EEPROM and the loading of the new control program are performed by the CPU in accordance with the rewrite program saved in the RAM.

Description

BACKGROUND OF THE INVENTION
1. Field of the Invention
The present invention relates to a control computer used in a hard disk drive, for example.
2. Description of the Related Art
Conventionally, a hard disk drive (HDD) includes a microcomputer serving as a control computer for controlling various circuits constituting the HDD such as a servo circuit, a read/write circuit of a head and a motor driver/motor controller. The control computer is a dedicated computer for executing predetermined control operations under the control of a control program.
Normally, the control program is fixedly stored in a read only memory (ROM) comprised of an IC memory. However, the control program must be changed depending on the product specification. For example, the hard disk drive must be customized depending on a customer's needs. For this reason, when the control computer is built in the HDD, the ROM is mounted on an IC socket. The use of IC socket permits the replacement of the ROM, to thereby change the control program.
However, the contact failure is apt to be caused when the ROM is inserted into the IC socket. Further, the cost is increased by the addition of the IC socket. Furthermore, a space for mounting the IC socket must be secured on the print circuit board. On the other hand, if the ROM is welded to the print circuit board without the IC socket, the ROM is not replaceable, which is impractical.
In order to solve the above problem, a method has been developed in which an electrically erasable programmable read only memory (EEPROM) is used in place of the ROM for storing the control program. The EEPROM is a nonvolatile and rewritable ROM which permits erase and rewrite operations. The EEPROMs are classified into a type in which the erase operation is performed in units of words, a type in which the erase operation is performed in units of blocks or rows, and a type in which erase operation is performed over the entire memory array, which is referred to as bulk erase. The EEPROM of bulk erase type is referred to as a flash EEPROM. Because of low cost, the flash EEPROM is used in place of the above described ROM. The use of the flash EEPROM permits the change of the control program without changing the memory itself. More specifically, the control program stored in the flash EEPROM may be replaced with a new control program supplied from a host computer, for example.
However, in order to rewrite the control program stored in the flash EEPROM, a dedicated program for rewriting the control program stored in the EEPROM to the new control program must be prepared. However, the rewrite program cannot be stored together with the control program in the flash EEPROM or in the EEPROMs other than the flash EEPROM. Because if the rewrite program is stored in the flash EEPROM together with the control program, the rewrite program will be erased when the erase operation is performed for replacing the control program with a new control program. Even if the EEPROMs other than the flash EEPROM are used, the rewrite program cannot be stored together with the control program because the rewrite program cannot be read out while writing the new control program in the same memory. For this reason, an additional ROM for storing the rewrite program is built in the HDD. However, such additional ROM for storing the rewrite program increases the cost and complicates the circuit arrangement.
SUMMARY OF THE INVENTION
An object of the present invention is to provide a control computer and a method for rewriting a control program which permit both the control program and a rewrite program to be stored in a same EEPROM and the replacement of the control program, without increasing the cost and the number of components.
According to a first aspect of the present invention, a control computer comprises: a nonvolatile and rewritable memory storing a control program for controlling a drive of a storage device and a rewrite program for rewriting the control program; a volatile memory for temporarily storing the rewrite program and an externally supplied new control program; and a central processing unit (CPU) performing the following operations of: saving the rewrite program stored in the nonvolatile and rewritable memory in the volatile memory, erasing the nonvolatile and rewritable memory, restoring the rewrite program stored in the volatile memory in the erased nonvolatile and rewritable memory, receiving the new control program supplied externally and storing in the volatile memory, loading the new control program stored in the volatile memory in the nonvolatile and rewritable memory, and executing the new control program in the nonvolatile and rewritable memory.
According to a second aspect of the present invention, a control computer comprises: a nonvolatile and rewritable memory having a control program area storing a control program for controlling a drive of a storage device and a rewrite program area storing a rewrite program for rewriting the control program; volatile memory for temporarily storing the rewrite program and an externally supplied new control program; and a central processing unit (CPU) for performing the following operations of: loading the rewrite program stored in the rewrite program area in the nonvolatile and rewritable memory into the volatile memory to thereby execute the rewrite program in the volatile memory, receiving a new control program supplied externally, erasing the control program area in the nonvolatile and rewritable memory, loading the received new control program into the erased control program area in the nonvolatile and rewritable memory and executing the new control program loaded in the control program area in the nonvolatile and rewritable memory.
According to the present invention, a control program and a rewrite program are stored together in a flash EEPROM or an EEPROM. When the control program stored in the flash EEPROM is to be replaced with a new control program supplied from a host computer, the rewrite program is first saved in the RAM. Then, the CPU executes the rewrite program in the RAM to thereby erase entire memory array of the flash EEPROM and restore the rewrite program in the erased flash EEPROM. Further, the CPU receives a new control program from a host unit and stores in the RAM. Then, the CPU loads the new control program stored in the RAM into the flash EEPROM. Thereafter, the CPU controls the hard disk drive in accordance with the new control program stored in the flash EEPROM.
According to a second aspect of the present invention, when the control program and the rewrite program are stored together in the EEPROM, the CPU loads the rewrite program in the EEPROM into the RAM to thereby execute the rewrite program. Then, the CPU receives a new control program supplied from a host computer and stores in the RAM. Further, the CPU erases only an area storing the control program in the EEPROM and loads the new control program stored in the RAM into the erased area in the EEPROM. Then, the CPU controls the hard disk drive in accordance with the new control program stored in the EEPROM.
Additional objects and advantages of the invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. The objects and advantages of the invention may be realized and obtained by means of the instrumentalities and combinations particularly pointed out in the appended claims.
BRIEF DESCRIPTION OF THE DRAWINGS
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate presently preferred embodiments of the invention, and together with the general description given above and the detailed description of the preferred embodiments given below, serve to explain the principles of the invention.
FIG. 1 is a block diagram showing a main portion of a control microcomputer according to an embodiment of the present invention;
FIG. 2 is a block diagram showing a main portion of an HDD using the control microcomputer in FIG. 1;
FIG. 3 is a memory map of the flash EEPROM (or EEPROM) in FIGS. 1 and 2;
FIG. 4 is a memory map of the RAM shown in FIGS. 1 and 2;
FIG. 5 is a flowchart of a rewrite operation when the flash EEPROM is used in which all the memory array are erased; and
FIG. 6 is a flowchart of a rewrite operation when the EEPROM is used in which the erase operation is performed in units of blocks.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
An embodiment of the present invention will now be described with reference to the drawings.
FIG. 1 is a block diagram showing a main portion of a control computer according to the embodiment of the present invention, and more particularly to a control microcomputer for controlling a hard disk drive (HDD).
As shown in FIG. 1, the control microcomputer 1 comprises a central processing unit (CPU) 2, a random access memory (RAM) 3 in which a rewrite program is temporarily stored for rewriting a control program for controlling the HDD, an I/O interface 4, and a flash EEPROM (or EEPROM) 5 storing the control program for controlling the HDD.
The CPU 2 executes the control program stored in the flash EEPROM (or EEPROM) 5 to control various circuits of the HDD shown in FIG. 2. As shown in FIG. 3, the flash EEPROM (or EEPROM) 5 comprises an control program area 5a and a rewrite program area 5b. The control program area 5a has a capacity of 128K bytes for example, and stores the control program for controlling the HDD. The rewrite program area 5b has a capacity of 1K bytes for example and stores the rewrite program for rewriting the control program in the control program area 5a. The rewrite program area 5b also stores a jump vector which indicates a start address of the rewrite program. The CPU 2 has two operation modes, namely a control mode and a rewrite mode. In the control mode, the CPU 2 controls the HDD in accordance with the control program stored in the flash EEPROM (or EEPROM) 5. In the rewrite mode, the CPU 2 rewrites the control program stored in the flash EEPROM (EEPROM) 5 to a new control program supplied from a host computer in accordance with the control program temporarily stored in the RAM 3. The designation of the control mode or the rewrite mode is performed by inputting a corresponding command from the host computer. More specifically, the rewrite program comprises two parts, namely a mode switching routine and a rewrite routine. In response to a command designating the control mode, the CPU 2 jumps to an address designated by the jump vector, namely a start address of the mode switching routine. On the other hand, in response to a command designating the rewrite mode, the CPU 2 jumps directly to the start address of the rewrite routine.
As shown in FIG. 4, the RAM 3 comprises a rewrite program area 3a, a new control program area 3b, a stack area 3c, other program and data area 3d and a register bank area 3e. The rewrite program area 3a has a capacity of 1K bytes and temporarily stores the rewrite program read out from the flash EEPROM (or EEPROM) 5.
The I/O interface 4 connects the control microcomputer 1 to the host computer 7 to receive a new control program or a new rewrite program from the host computer and to permit exchange of other programs and data therebetween. More specifically, the I/O interface 4 is implemented by a universal asynchronous receiver/transmitter (UART). The I/O interface 4 is based on Small Computer Systems Interface (SCSI) or ATA (AT attachment), for example and uses unassigned two pins (one for receiving data and the other for transmitting data) of a SCSI connector or an ATA connector to perform serial transmission between the CPU 2 and the host computer 7. The stack area 3c stores various parameters such as a return address of a subroutine or temporarily stores contents of registers. The other program/data area 3d temporarily stores programs other than the control program and the rewrite program and data supplied from the host computer 7. The register bank area 3e are memory mapped registers.
FIG. 2 shows a block diagram of the HDD using the control microcomputer 1. The HDD is provided with an head 10 for reading data from or writing data into a disk serving as a recording medium 15, a spindle motor 16 for rotating the disk 15 and a voice coil motor (VCM) 17 for seeking the disk radially. The spindle motor 16 and the VCM 17 are each driven by a motor drive/motor control unit 18. The unit 18 drives the spindle motor 16 using control signals from the control microcomputer 1. Furthermore, the unit 18 drives the VCM 17 using control signals from a servo circuit 19.
The control microcomputer 1 controls a read/write (R/W) circuit 12 to supply a write signal to the head 10 through a head IC 11, and reproduces a read signal from the head 10. In response to the servo signals (a position signal and a target cylinder address) reproduced by the R/W circuit 12, the servo circuit 19 supplies a control signal to the unit 18 in order to position the head 10 in the center of the target cylinder. A hard disk controller (HDC) 13 serves as an interface between a host computer 7 and the HDD to exchange data and interface signals therebetween. The HDC 13 accesses a buffer RAM 14 for temporarily storing the read and write data. The CPU 2 controls various circuits shown in FIG. 2 in accordance with the control program stored in the control program area 5a of the EEPROM 5.
An operation of the above embodiment will now be described with reference to the flowcharts shown in FIGS. 5 and 6.
First, the rewrite operation of the control program stored in the flash EEPROM 5 will now be described with reference to the flowchart shown in FIG. 5. As described above, in the case of the flash EEPROM 5, the entire memory array of the flush EEPROM 5 is erased.
First, an operator inputs a command instructing the rewrite operation such as "LM" (Loader Mode) from the host computer 7 to set the CPU in the rewrite mode. In response to the rewrite operation command, the CPU 2 in the HDD directly jumps to the start address of the rewrite routine stored in the rewrite program area 5b in the flash EEPROM 5. Then, the CPU 2 executes the rewrite routine in the rewrite program area 5b. FIG. 5 shows the operation of the rewrite routine. In FIG. 5, the CPU 2 saves the rewrite program (the jump vector, the mode switching routine, and the rewrite routine) stored in the rewrite program area 5b in the flash EEPROM 5 into the rewrite program area 3a in the RAM 3 (step S1) so as not to be erased by the erase operation to be described later. After the rewrite program stored in the rewrite program area 5b in the flash EEPROM 5 is saved in the rewrite routine area 3a in the RAM 3, the rewrite program in the rewrite program area 5b switches a program counter (not shown) of the CPU 2 to the start address of the rewrite program saved in the rewrite program area 3a in the RAM 3. Then, the CPU 2 executes the rewrite routine saved in the RAM 3 (step S3). Then, the CPU 2 erases the entire memory array of the flash EEPROM 5 (step S5). After the flash EEPROM 5 is erased, the CPU 2 restores the rewrite program saved in the area 3a of the RAM 3 into the area 5b of the flash memory 5 (step S7). Then, the CPU 2 receives a new control program by one block (64 bytes or 128 bytes) from the host computer 7 through the UART 4 (step S9). Then, the CPU 2 stores the received one block of new control program into the new control program area 3b of the RAM 3. In step S13, the CPU 2 loads the one block of new control program stored in the area 3b of the RAM 3 into the control program area 5a of the flash EEPROM 5. Note that in this embodiment, the first block of the new control program supplied from the host computer 7 is a control block which indicates whether or not the new control program has been correctly written. In the initial state, the control block is filled with a null code. After all the blocks of the new control program have been correctly written, the CPU 2 writes, in the control block, data indicating the validity of the new control program. Then, the CPU 2 verifies whether or not the one block of new control program has been correctly written in the area 5a (step S15). In step S17, the CPU 2 checks whether or not all the blocks of new control program have been written in the area 5a. If not, the CPU 2 returns to the step S9 and repetitively executes steps S9 to S17 until all the blocks of new control program have been written in the area 5a. If it is determined that all the blocks of new control program have been written in the area 5a in step S17, the CPU 2 writes into the control block in the area 5a data indicating the validity of the new control program, and informs the completion of the rewrite operation to the host computer 7, and switches the program counter of the CPU 2 to a predetermined address of the rewrite program in the area 5b. Then, an operator inputs a command such as "MA" designating the control mode from the host computer 7. In response to this command, the CPU 2 is set in the control mode. More specifically, the CPU 2 first jumps to the jump vector in the area 5b. The jump vector indicates a start address of the mode switching routine in the area 5b. Accordingly, the CPU 2 executes the mode switching routine. The mode switching routine checks the control block in the area 5a to determine the validity of the new control program. Since the control block indicates that the new control program has been correctly written, the CPU 2 jumps to the start address of the new control program in the area 5a to thereby execute the new control program to control the HDD (step S19).
The rewrite operation of the rewrite program stored in the EEPROM 5 which permits erase operation in units of blocks will now be described with reference to the flowchart shown in FIG. 6. The process for which the CPU enters into the rewrite mode is the same as that in the case of FIG. 5 and therefore the description thereof will be omitted. In this case, the rewrite program stored in the rewrite program area 5b is not erased by the erase operation. However, the rewrite program in the area 5b cannot be read out while writing the new control program into the area 5a. Therefore, the CPU 2 loads the rewrite program in the area 5b into the rewrite program area 3a of the RAM 3 (step S21). The rewrite program in the area 5b switches a program counter of the CPU 2 to the start address of the rewrite program loaded in the area 3a. As a result, the CPU 2 executes the rewrite program loaded in the area 3a (step S23). Then, the CPU 2 receives the new control program by one block (64 bytes or 128 bytes) from the host computer 7 through the UART 4. Then, the CPU 2 stores the received one block of new control program in the area 3b of the RAM 3. Then, the CPU 2 loads the one block of new control program stored in the area 3b into the area 5b. In this case, the EEPROM 5 itself performs the erase operation by one block in a hardware manner before writing the one block of new control program (step S27). Then, the CPU 2 verifies whether or not the one block of new control program has been correctly written in the area 5a (step S31). In step S33, the CPU 2 checks whether or not all the blocks of new control program have been written in the area 5a. If not, the CPU 2 returns to step S25 and repetitively executes steps S25 to S33 until all the blocks of new control program have been written in the area 5a. If it is determined in step S33 that all the blocks of new control program have been written in the area 5athe CPU 2 writes into the control block in area 5a data indicating the validity of the new control program, and informs, the completion of the rewrite operation is informed to the host computer 7, and switches the program counter of the CPU 2 to a predetermined address of the rewrite program in the area 5b . Then, an operator inputs a command such as "MA" designating the control mode from the host computer 7. In response to this command, the CPU 2 is set in the control mode. More specifically, the CPU 2 first jumps to the jump vector in the area 5b. The jump vector indicates a start address of the mode switching routine in the area 5b. Accordingly, the CPU 2 executes the mode switching routine. The mode switching routine checks the control block in the area 5a to determine the validity of the new control program. Since control block indicates that the new control program has been correctly written, the CPU 2 jumps to the start address of the new control program in the area 5a to thereby execute the new control program to control the HDD (step S35).
As described above, the rewrite program is stored together with the control program in the flash EEPROM (or EEPROM) 5. Then, the rewrite program is saved or loaded in the RAM 3 to execute the rewrite program. Accordingly, the CPU 2 can write the new control program supplied from the host computer 7 in the flash EEPROM or the EEPROM 5 while reading the rewrite program in the RAM 3. As a result, the ROM 6 storing the rewrite program which has been built in the conventional HDD can be eliminated.
In the above embodiments, the control program stored in the flash EEPROM or the EEPROM 5 is replaced with the new control program supplied from the host computer 7. The present invention is not limited to the above embodiment. For example, the rewrite program stored in the flash EEPROM or the EEPROM may be replaced with a new rewrite program supplied from the host computer 7. The replacement of the rewrite program is performed in the same manner as the replacement of the control program and therefore, the description thereof will be omitted.
Further, in the above embodiment, the control program for controlling the HDD has been exemplified. However, the present invention can be applied to other drives of storage devices such as a floppy disk, a flexible disk, an optical disk, a magnet-optical disk, a CD-ROM, and a video disk, and also to other I/O controllers including a control CPU such as a keyboard controller, a printer controller, and a display controller.
Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the invention in its broader aspects is not limited to the specific details, representative devices, and illustrated examples shown and described herein. Accordingly, various modifications may be made without departing from the spirit or scope of the general inventive concept as defined by the appended claims and their equivalents.

Claims (20)

What is claimed is:
1. A control computer, comprising:
a nonvolatile and rewritable memory storing a control program for controlling a drive of a storage device and a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and a new control program supplied from a host computer;
a central processing unit (CPU) performing the following operations of:
saving the rewrite program stored in the nonvolatile and rewritable memory in the volatile memory,
erasing the nonvolatile and rewritable memory, restoring the rewrite program stored in the volatile memory in the erased nonvolatile and rewritable memory,
receiving the new control program supplied from the host computer and storing it in the volatile memory,
loading the new control program stored in the volatile memory in the nonvolatile and rewritable memory, and
executing the new control program in the nonvolatile and rewritable memory;
an I/O interface for communicating with the host computer to receive the new control program from the host computer; and
an SCSI connected wherein the I/O interface performs a serial communication with the host computer by using unassigned pins of the SCSI connector.
2. The control computer according to claim 1, wherein the CPU has a rewrite mode for replacing the control program stored in the nonvolatile and rewritable memory with the new control program and a control mode for controlling the drive in accordance with the control program stored in the nonvolatile and rewritable memory, and the modes are switched in response to an externally supplied command.
3. The control computer according to claim 1, wherein the drive of the storage device is a hard disk drive.
4. The control computer according to claim 1, wherein the I/O interface comprises a Universal Asynchronous Transmitter Receiver (UART).
5. A control computer, comprising:
a nonvolatile and rewritable memory having a control program area storing a control program for controlling a drive of a storage device and a rewrite program area storing a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and a new control program supplied from a host computer;
a central processing unit (CPU) for performing the following operations of:
loading the rewrite program stored in the rewrite program area in the nonvolatile and rewritable memory into the volatile memory to thereby execute the rewrite program in the volatile memory,
receiving a new control program supplied from the host computer,
erasing the control program area in the non-volatile and rewritable memory,
loading the received new control program into the erased control program area in the nonvolatile and rewritable memory, and
executing the new control program loaded in the control program area in the nonvolatile and rewritable memory;
an I/O interface for communicating with the host computer to receive the new control program from the host computer; and
an SCSI connector wherein the I/O interface performs a serial communication with the host computer by using unassigned pins of the SCSI connector.
6. The control computer according to claim 5, wherein the CPU has a rewrite mode for replacing the control program stored in the nonvolatile and rewritable memory with the new control program and a control mode for controlling the drive in accordance with the control program stored in the nonvolatile and rewritable memory, and the modes are switched in response to an externally supplied command.
7. The control computer according to claim 5, wherein the drive of the storage device is a hard disk drive.
8. The control computer according to claim 5, wherein the I/O interface comprises a Universal Asynchronous Transmitter Receiver (UART).
9. A control computer, comprising:
a nonvolatile and rewritable memory storing a control program for controlling a drive of a storage device and a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and a new rewrite program supplied from a host computer;
a central processing unit (CPU) performing the following operations of:
saving the rewrite program stored in the non-volatile and rewritable memory in the volatile memory,
erasing the nonvolatile and rewritable memory,
receiving the new rewrite program supplied from the host computer and storing it in the volatile memory,
loading the new rewrite program stored in the volatile memory in the nonvolatile and rewritable memory, and
executing the new rewrite program in the nonvolatile and rewritable memory;
an I/O interface for communicating with the host computer to receive the new control program from the host computer; and
an SCSI connector wherein the interface performs a serial communication with the host computer by using unassigned pins of the SCSI connector.
10. The control computer according to claim 9, wherein the I/O interface comprises a Universal Asynchronous Transmitter Receiver (UART).
11. In a control computer for controlling a drive unit of a storage device and provided with a CPU, an EEPROM storing the control program and a rewrite program for rewriting the control program, a RAM for temporarily storing the rewrite program, and an I/O interface for communicating with a host computer, a method for rewriting the control program comprising the computer steps of:
transferring, by the CPU, the rewrite program of the EEPROM into the RAM;
erasing the EEPROM, by the CPU, under the control of the rewrite program in the RAM;
loading the rewrite program in the RAM into the EEPROM;
receiving, by the CPU under the control of the rewrite program in the RAM, a new control program supplied from the host computer through an I/O interface through which the CPU serially communicates with the host computer using unassigned pins of an SCSI connector to receive the new control program from the host computer;
temporarily storing, by the CPU under the control of the rewrite program in the RAM, the received new control program in the RAM;
loading, by the CPU under the control of the rewrite program in the RAM, the received new control program into the EEPROM; and
switching the execution of the CPU to the new control program loaded in the EEPROM in accordance with the rewrite program in the RAM.
12. The method of claim 11, wherein the receiving step includes step of providing the I/O interface to include a Universal Asynchronous Transmitter Receiver (UART).
13. A control computer, comprising:
a nonvolatile and rewritable memory storing a control program for controlling a drive of a storage device and a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and a new control program supplied from a host computer;
a central processing unit (CPU) performing the following operations of:
saving the rewrite program stored in the nonvolatile and rewritable memory in the volatile memory,
erasing the nonvolatile and rewritable memory, restoring the rewrite program stored in the volatile memory in the erased nonvolatile and rewritable memory,
receiving the new control program supplied from the host computer and storing it in the volatile memory,
loading the new control program stored in the volatile memory in the nonvolatile and rewritable memory, and
executing the new control program in the nonvolatile and rewritable memory;
an I/O interface for communicating with the host computer to receive the new control program from the host computer; and
an ATA connector wherein the I/O interface performs a serial communication with the host computer by using unassigned pins of the ATA connector.
14. The control computer according to claim 13, wherein the I/O interface comprises a Universal Asynchronous Transmitter Receiver (UART).
15. A control computer, comprising:
a nonvolatile and rewritable memory having a control program area storing a control program for controlling a drive of a storage device and a rewrite program area storing a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and a new control program supplied from a host computer;
a central processing unit (CPU) for performing the following operations of:
loading the rewrite program stored in the rewrite program area in the nonvolatile and rewritable memory into the volatile memory to thereby execute the rewrite program in the volatile memory,
receiving a new control program supplied from the host computer,
erasing the control program area in the non-volatile and rewritable memory,
loading the received new control program into the erased control program area in the nonvolatile and rewritable memory, and
executing the new control program loaded in the control program area in the nonvolatile and rewritable memory;
an I/O interface for communicating with the host computer to receive the new control program from the host computer; and
an ATA connector wherein the I/O interface performs a serial communication with the host computer by using unassigned pins of the ATA connector.
16. The control computer according to claim 15, wherein the I/O interface comprises a Universal Asynchronous Transmitter Receiver (UART).
17. A control computer, comprising:
a nonvolatile and rewritable memory storing a control program for controlling a drive of a storage device and a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and an externally supplied new control program;
a central processing unit (CPU) performing the following operations of:
saving the rewrite program stored in the nonvolatile and rewritable memory in the volatile memory,
erasing the nonvolatile and rewritable memory,
restoring the rewrite program stored in the volatile memory in the erased nonvolatile and rewritable memory,
receiving the new control program supplied externally and storing it in the volatile memory,
loading the new control program stored in the volatile memory in the nonvolatile and rewritable memory,
executing the new control program in the nonvolatile and rewritable memory;
a SCSI connector; and
an I/O interface for communicating with a host computer to receive the new control program from the host computer, the I/O interface comprising a Universal Asynchronous Transmitter Receiver (UART) and performing a serial communication with the host computer by using unassigned pins of the SCSI connector.
18. A control computer, comprising:
a nonvolatile and rewritable memory storing a control program for controlling a drive of a storage device and a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and an externally supplied new control program;
a central processing unit (CPU) performing the following operations of:
saving the rewrite program stored in the nonvolatile and rewritable memory in the volatile memory,
erasing the nonvolatile and rewritable memory,
restoring the rewrite program stored in the volatile memory in the erased nonvolatile and rewritable memory,
receiving the new control program supplied externally and storing it in the volatile memory,
loading the new control program stored in the volatile memory in the nonvolatile and rewritable memory,
executing the new control program in the nonvolatile and rewritable memory;
an ATA connector; and
an I/O interface for communicating with a host computer to receive the new control program from the host computer, the I/O interface comprising a Universal Asynchronous Transmitter Receiver (UART) and performing a serial communication with the host computer by using unassigned pins of the ATA connector.
19. A control computer, comprising:
a nonvolatile and rewritable memory having a control program area storing a control program for controlling a drive of a storage device and a rewrite program area storing a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and an externally supplied new control program;
a central processing unit (CPU) for performing the following operations of:
loading the rewrite program stored in the rewrite program area in the nonvolatile and rewritable memory into the volatile memory to thereby execute the rewrite program in the volatile memory,
receiving a new control program externally supplied,
erasing the control program area in the nonvolatile and rewritable memory,
loading the received new control program into the erased control program area in the nonvolatile and rewritable memory, and
executing the new control program loaded in the control program area in the nonvolatile and rewritable memory;
a SCSI connector; and
an I/O interface communicating with a host computer to receive the new control program from the host computer, the I/O interface comprising a Universal Asynchronous Transmitter Receiver (UART) and performing a serial-communication with the host computer by using unassigned pins of the SCSI connector.
20. A control computer, comprising:
a nonvolatile and rewritable memory having a control program area storing a control program for controlling a drive of a storage device and a rewrite program area storing a rewrite program for rewriting the control program;
a volatile memory for temporarily storing the rewrite program and an externally supplied new control program;
a central processing unit (CPU) for performing the following operations of:
loading the rewrite program stored in the rewrite program area in the nonvolatile and rewritable memory into the volatile memory to thereby execute the rewrite program in the volatile memory,
receiving a new control program externally supplied,
erasing the control program area in the nonvolatile and rewritable memory,
loading the received new control program into the erased control program area in the nonvolatile and rewritable memory, and
executing the new control program loaded in the control program area in the nonvolatile and rewritable memory;
an ATA connector; and
an I/O interface communicating with a host computer to receive the new control program from the host computer, the I/O interface comprising a Universal Asynchronous Transmitter Receiver (UART) and performing a serial-communication with the host computer by using unassigned pins of the ATA connector.
US08/302,014 1993-09-13 1994-09-09 Disk drive control computer and method for rewriting control program in flash EEPROM with serial communication using unassigned pins of SCSI or ATA connector Expired - Lifetime US5603056A (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP5-227425 1993-09-13
JP22742593A JP3310060B2 (en) 1993-09-13 1993-09-13 Storage device and control program rewriting method for the same

Publications (1)

Publication Number Publication Date
US5603056A true US5603056A (en) 1997-02-11

Family

ID=16860653

Family Applications (1)

Application Number Title Priority Date Filing Date
US08/302,014 Expired - Lifetime US5603056A (en) 1993-09-13 1994-09-09 Disk drive control computer and method for rewriting control program in flash EEPROM with serial communication using unassigned pins of SCSI or ATA connector

Country Status (2)

Country Link
US (1) US5603056A (en)
JP (1) JP3310060B2 (en)

Cited By (66)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1997023829A1 (en) * 1995-12-26 1997-07-03 Intel Corporation Memory manager allowing flash memory to supplement main memory
EP0825530A2 (en) * 1996-06-20 1998-02-25 Sharp Kabushiki Kaisha Computer apparatus having electrically rewritable nonvolatile memory, and nonvolatile semiconductor memory
WO1998012662A1 (en) * 1996-09-17 1998-03-26 Cummins-Allison Corp. Software loading system for a currency scanner
GB2319365A (en) * 1996-09-25 1998-05-20 Eastman Kodak Co Reprogramming a microprocessor through a serial port
WO1998040818A1 (en) * 1997-03-13 1998-09-17 Macronix International Co., Ltd. In-circuit programming architecture with rom and flash memory
US5937198A (en) * 1996-08-28 1999-08-10 Extended Systems, Inc. Field configurable embedded computer system
US5937434A (en) * 1997-02-14 1999-08-10 Intel Corporation Method of managing a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US5940623A (en) 1997-08-01 1999-08-17 Cummins-Allison Corp. Software loading system for a coin wrapper
US6039645A (en) 1997-06-24 2000-03-21 Cummins-Allison Corp. Software loading system for a coin sorter
US6068194A (en) * 1998-02-12 2000-05-30 Cummins-Allison Corporation Software loading system for an automatic funds processing system
US6088759A (en) * 1997-04-06 2000-07-11 Intel Corporation Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US6128675A (en) * 1997-04-10 2000-10-03 Samsung Electronics Co., Ltd. Memory device having plurality of flash memories with a flash memory controlling circuit
US6151657A (en) * 1996-10-28 2000-11-21 Macronix International Co., Ltd. Processor with embedded in-circuit programming structures
US6175919B1 (en) 1997-05-02 2001-01-16 Samsung Electronics Co., Ltd. Method and apparatus for upgrading BIOS using a serial communication
US6182188B1 (en) 1997-04-06 2001-01-30 Intel Corporation Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
GB2355326A (en) * 1996-09-25 2001-04-18 Eastman Kodak Co Reprogramming a microprocessor through a serial port
US6311290B1 (en) 1997-02-14 2001-10-30 Intel Corporation Methods of reliably allocating, de-allocating, re-allocating, and reclaiming objects in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US20010052048A1 (en) * 2000-06-08 2001-12-13 Kaneo Watanabe Controller and data processing system
US6356942B1 (en) 1998-05-13 2002-03-12 Axis Ab Integrated circuit and method for bringing an integrated circuit to execute instructions
US6363463B1 (en) * 1996-06-28 2002-03-26 Intel Corporation Method and apparatus for protecting flash memory
US6401140B1 (en) 1999-01-12 2002-06-04 Dell Usa, L.P. Apparatus and method for booting a computer operation system from an intelligent input/output device having no option ROM with a virtual option ROM stored in computer
US20020114457A1 (en) * 2001-01-26 2002-08-22 Takahiro Sato LSI having interpreter function and information recording/reproducing apparatus using the same
US20020166027A1 (en) * 2001-04-20 2002-11-07 Hitachi, Ltd. Updating method of firmware of hard disk unit mounted on disk array device and disk array device with function for performing updating method
US6493788B1 (en) 1996-10-28 2002-12-10 Macronix International Co., Ltd. Processor with embedded in-circuit programming structures
US6507881B1 (en) * 1999-06-10 2003-01-14 Mediatek Inc. Method and system for programming a peripheral flash memory via an IDE bus
US6523083B1 (en) * 1999-12-09 2003-02-18 Via Technologies, Inc. System and method for updating flash memory of peripheral device
US20030070029A1 (en) * 2001-10-04 2003-04-10 Alps Electric Co., Ltd. Data transmission transceiver unit and program updating method therefor
US6604185B1 (en) 2000-07-20 2003-08-05 Silicon Graphics, Inc. Distribution of address-translation-purge requests to multiple processors
US20030189811A1 (en) * 2001-06-29 2003-10-09 Peeke Douglas E. Advanced technology attachment disk drive module with fibre channel system characteristics
US6681293B1 (en) 2000-08-25 2004-01-20 Silicon Graphics, Inc. Method and cache-coherence system allowing purging of mid-level cache entries without purging lower-level cache entries
US6684290B2 (en) * 2001-10-18 2004-01-27 Kabushiki Kaisha Toshiba Memory rewriting apparatus and method for memory mapping rewriting program to same address space
US20040030953A1 (en) * 1996-10-28 2004-02-12 Macronix International Co., Ltd. Fault-tolerant architecture for in-circuit programming
US20040068591A1 (en) * 2002-10-03 2004-04-08 Workman Michael Lee Systems and methods of multiple access paths to single ported storage devices
US20040117541A1 (en) * 2002-09-05 2004-06-17 Yung-Chun Lei System and method for updating firmware in a non-volatile memory without using a processor
US20040117545A1 (en) * 2002-12-16 2004-06-17 Matthew Borsini Using request and grant signals to read revision information from an adapter board that interfaces a disk drive
US20040123027A1 (en) * 2002-10-03 2004-06-24 Workman Michael Lee Systems and methods of multiple access paths to single ported storage devices
EP1439528A1 (en) * 2003-01-16 2004-07-21 Samsung Electronics Co., Ltd. Method of marking and updating optimal unlatch profile for hard disk drive
US20040153685A1 (en) * 2002-12-20 2004-08-05 Tuttle James M. Detecting intermittent losses of synchronization in a fibre channel loop
US6779072B1 (en) * 2000-07-20 2004-08-17 Silicon Graphics, Inc. Method and apparatus for accessing MMR registers distributed across a large asic
US20040193791A1 (en) * 2003-03-28 2004-09-30 Felton Mickey S. Midplane-independent implementations of data storage system enclosures
US6829658B2 (en) 2002-12-16 2004-12-07 Emc Corporation Compatible signal-to-pin connector assignments for usage with fibre channel and advanced technology attachment disk drives
US6831924B1 (en) 2000-07-20 2004-12-14 Silicon Graphics, Inc. Variable mode bi-directional and uni-directional computer communication system
US6834331B1 (en) 2000-10-24 2004-12-21 Starfish Software, Inc. System and method for improving flash memory data integrity
US6839856B1 (en) 2000-07-20 2005-01-04 Silicon Graphics, Inc. Method and circuit for reliable data capture in the presence of bus-master changeovers
US6842820B2 (en) 1997-10-03 2005-01-11 Macronix International Co., Ltd. Processor with embedded in-circuit programming structures
US6854000B2 (en) * 1997-12-27 2005-02-08 Canon Kabushiki Kaisha Image forming apparatus and control method for the same
US20050135060A1 (en) * 2003-12-22 2005-06-23 Emc Corporation Fan assembly for installing and removing fans individually and collectively
US20050135069A1 (en) * 2003-12-22 2005-06-23 Emc Corporation Midplane-less data storage enclosure
US20050265266A1 (en) * 2004-05-25 2005-12-01 Chih-Chiang Wen Optical disc drive that downloads operational firmware from an external host
US20050268029A1 (en) * 2004-05-25 2005-12-01 Chih-Chiang Wen Optical Disc Drive that Downloads Operational Firmware from an External Host
US7028174B1 (en) 2002-09-30 2006-04-11 Western Digital Technologies, Inc. Disk drive employing a non-volatile serial semiconductor memory for storing a control program for a microprocessor
US7047283B1 (en) * 1999-06-09 2006-05-16 Samsung Electronics Co., Ltd. Apparatus and method of upgrading program of firmware board
US20060224821A1 (en) * 2005-04-01 2006-10-05 Mediatek Incorporation System for parallel updating flash memory and method for the same
US7228536B2 (en) * 1999-12-15 2007-06-05 Sanden, Corporation System for rewriting control program in vending machine
US7248635B1 (en) 2000-07-20 2007-07-24 Silicon Graphics, Inc. Method and apparatus for communicating computer data from one point to another over a communications medium
EP0967551A3 (en) * 1998-06-26 2007-08-08 Denso Corporation Electronic control unit having user breakable function
CN100337223C (en) * 2004-07-16 2007-09-12 英业达股份有限公司 Structure capable of making burning program directly on the mainboard
CN100339823C (en) * 2002-10-08 2007-09-26 松下电器产业株式会社 Program updating method and terminal device
US7333516B1 (en) 2000-07-20 2008-02-19 Silicon Graphics, Inc. Interface for synchronous data transfer between domains clocked at different frequencies
US20080301358A1 (en) * 2004-05-25 2008-12-04 Chih-Chiang Wen Electronic device that Downloads Operational Firmware from an External Host
US20090083475A1 (en) * 2007-09-24 2009-03-26 Mediatek Inc. Apparatus and method for updating firmware stored in a memory
US20100131698A1 (en) * 2008-11-24 2010-05-27 Tsai Chien-Liang Memory sharing method for flash driver
US8937854B2 (en) 2001-01-25 2015-01-20 Optical Devices, Llc Servo processor receiving photodetector signals
US9069488B2 (en) 2010-08-27 2015-06-30 Fxi Technologies As Electronic devices
US20180011803A1 (en) * 2016-07-07 2018-01-11 Gowin Semiconductor Corporation, Ltd Secrecy System And Decryption Method Of On-Chip Data Stream Of Nonvolatile FPGA
US10521150B2 (en) * 2018-05-23 2019-12-31 Gowin Semiconductor Corporation Data processing method and device for nonvolatile memory and storage medium

Families Citing this family (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6308325B1 (en) 1996-04-09 2001-10-23 International Business Machines Corporation Apparatus and method for downloading data to electronic device
JPH1027097A (en) * 1996-07-11 1998-01-27 Anritsu Corp Method and device for rewriting data of flash rom
KR100247951B1 (en) 1997-04-11 2000-03-15 윤종용 Program modification method of PDA
JPH11102294A (en) * 1997-09-26 1999-04-13 Mitsubishi Electric Corp Controller for elevator
TW460858B (en) * 1999-02-19 2001-10-21 Wacom Engineering Co Ltd Operator's input processing unit and method thereof
JP2001331319A (en) * 2000-05-19 2001-11-30 Juki Corp Equipment control system
JP4854995B2 (en) * 2005-06-28 2012-01-18 株式会社日立製作所 Elevator control device
JP2007039206A (en) * 2005-08-03 2007-02-15 Hitachi Building Systems Co Ltd Elevator control system
JP4734096B2 (en) * 2005-11-22 2011-07-27 株式会社日立ビルシステム Elevator control system
KR100734303B1 (en) 2006-01-14 2007-07-02 삼성전자주식회사 Method for down-loading a system program
JP2007249645A (en) * 2006-03-16 2007-09-27 Sanmei Electric Co Ltd Program change method
KR100880379B1 (en) 2006-05-25 2009-01-23 삼성전자주식회사 Information Processing System being boosted by boot code from external

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4430727A (en) * 1981-11-10 1984-02-07 International Business Machines Corp. Storage element reconfiguration
JPH0365727A (en) * 1989-08-02 1991-03-20 Shikoku Nippon Denki Software Kk Microprogram storage system
US5388267A (en) * 1991-05-29 1995-02-07 Dell Usa, L.P. Method and apparatus for updating and restoring system BIOS functions while maintaining BIOS integrity

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4430727A (en) * 1981-11-10 1984-02-07 International Business Machines Corp. Storage element reconfiguration
JPH0365727A (en) * 1989-08-02 1991-03-20 Shikoku Nippon Denki Software Kk Microprogram storage system
US5388267A (en) * 1991-05-29 1995-02-07 Dell Usa, L.P. Method and apparatus for updating and restoring system BIOS functions while maintaining BIOS integrity

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
Jerry Jex, "Flash Memory BIOS for PC and Notebook Comuters", Communications, Computers, and Signal Processing, IEEE 1991.
Jerry Jex, Flash Memory BIOS for PC and Notebook Comuters , Communications, Computers, and Signal Processing, IEEE 1991. *

Cited By (112)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6243789B1 (en) 1995-12-26 2001-06-05 Intel Corporation Method and apparatus for executing a program stored in nonvolatile memory
GB2323690B (en) * 1995-12-26 2000-05-10 Intel Corp Memory manager allowing flash memory to supplement main memory
WO1997023829A1 (en) * 1995-12-26 1997-07-03 Intel Corporation Memory manager allowing flash memory to supplement main memory
GB2323690A (en) * 1995-12-26 1998-09-30 Intel Corp Memory manager allowing flash memory to supplement main memory
US5829013A (en) * 1995-12-26 1998-10-27 Intel Corporation Memory manager to allow non-volatile memory to be used to supplement main memory
US5933595A (en) * 1996-06-20 1999-08-03 Sharp Kabushiki Kaisha Computer apparatus having electrically rewritable nonvolatile memory, and nonvolatile semiconductor memory
EP0825530A2 (en) * 1996-06-20 1998-02-25 Sharp Kabushiki Kaisha Computer apparatus having electrically rewritable nonvolatile memory, and nonvolatile semiconductor memory
EP0825530A3 (en) * 1996-06-20 2004-06-02 Sharp Kabushiki Kaisha Computer apparatus having electrically rewritable nonvolatile memory, and nonvolatile semiconductor memory
US6363463B1 (en) * 1996-06-28 2002-03-26 Intel Corporation Method and apparatus for protecting flash memory
US5937198A (en) * 1996-08-28 1999-08-10 Extended Systems, Inc. Field configurable embedded computer system
US6473899B1 (en) 1996-08-28 2002-10-29 Extended Systems, Inc. Field configurable embedded computer system
US5909502A (en) * 1996-09-17 1999-06-01 Cummins-Allison Corp. Software loading system for a currency scanner
WO1998012662A1 (en) * 1996-09-17 1998-03-26 Cummins-Allison Corp. Software loading system for a currency scanner
GB2355326A (en) * 1996-09-25 2001-04-18 Eastman Kodak Co Reprogramming a microprocessor through a serial port
GB2355326B (en) * 1996-09-25 2001-07-11 Eastman Kodak Co Method and apparatus for reprogramming a microprocessor
GB2319365B (en) * 1996-09-25 2001-07-11 Eastman Kodak Co Remote programming of microprocessor equipment over a standard serial port
GB2319365A (en) * 1996-09-25 1998-05-20 Eastman Kodak Co Reprogramming a microprocessor through a serial port
GB2355325B (en) * 1996-09-25 2001-07-11 Eastman Kodak Co A method of programming a microprocessor
GB2355325A (en) * 1996-09-25 2001-04-18 Eastman Kodak Co Reprogramming a microprocessor through a serial port
US7237145B2 (en) 1996-10-28 2007-06-26 Macronix International Co., Ltd. Fault-tolerant architecture for in-circuit programming
US6151657A (en) * 1996-10-28 2000-11-21 Macronix International Co., Ltd. Processor with embedded in-circuit programming structures
US20040030953A1 (en) * 1996-10-28 2004-02-12 Macronix International Co., Ltd. Fault-tolerant architecture for in-circuit programming
US6493788B1 (en) 1996-10-28 2002-12-10 Macronix International Co., Ltd. Processor with embedded in-circuit programming structures
US5937434A (en) * 1997-02-14 1999-08-10 Intel Corporation Method of managing a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US6311290B1 (en) 1997-02-14 2001-10-30 Intel Corporation Methods of reliably allocating, de-allocating, re-allocating, and reclaiming objects in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
EP0974089A4 (en) * 1997-03-13 2004-04-28 Macronix Int Co Ltd In-circuit programming architecture with rom and flash memory
WO1998040818A1 (en) * 1997-03-13 1998-09-17 Macronix International Co., Ltd. In-circuit programming architecture with rom and flash memory
US5901330A (en) * 1997-03-13 1999-05-04 Macronix International Co., Ltd. In-circuit programming architecture with ROM and flash memory
EP0974089A1 (en) * 1997-03-13 2000-01-26 Macronix International Co., Ltd. In-circuit programming architecture with rom and flash memory
US7174416B2 (en) 1997-04-06 2007-02-06 Intel Corporation Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US6182188B1 (en) 1997-04-06 2001-01-30 Intel Corporation Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US20040044837A1 (en) * 1997-04-06 2004-03-04 Hasbun Robert N. Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US6412040B2 (en) 1997-04-06 2002-06-25 Intel Corporation Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US6088759A (en) * 1997-04-06 2000-07-11 Intel Corporation Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture
US6128675A (en) * 1997-04-10 2000-10-03 Samsung Electronics Co., Ltd. Memory device having plurality of flash memories with a flash memory controlling circuit
US6175919B1 (en) 1997-05-02 2001-01-16 Samsung Electronics Co., Ltd. Method and apparatus for upgrading BIOS using a serial communication
US6039645A (en) 1997-06-24 2000-03-21 Cummins-Allison Corp. Software loading system for a coin sorter
US5940623A (en) 1997-08-01 1999-08-17 Cummins-Allison Corp. Software loading system for a coin wrapper
US6842820B2 (en) 1997-10-03 2005-01-11 Macronix International Co., Ltd. Processor with embedded in-circuit programming structures
US20050062984A1 (en) * 1997-12-27 2005-03-24 Canon Kabushiki Kaisha Image forming apparatus and control method for the same
US7403957B2 (en) 1997-12-27 2008-07-22 Canon Kabushiki Kaisha Image forming apparatus having control codes and rewrite control method for the same
US6854000B2 (en) * 1997-12-27 2005-02-08 Canon Kabushiki Kaisha Image forming apparatus and control method for the same
US6068194A (en) * 1998-02-12 2000-05-30 Cummins-Allison Corporation Software loading system for an automatic funds processing system
US6356942B1 (en) 1998-05-13 2002-03-12 Axis Ab Integrated circuit and method for bringing an integrated circuit to execute instructions
EP0967551A3 (en) * 1998-06-26 2007-08-08 Denso Corporation Electronic control unit having user breakable function
US6401140B1 (en) 1999-01-12 2002-06-04 Dell Usa, L.P. Apparatus and method for booting a computer operation system from an intelligent input/output device having no option ROM with a virtual option ROM stored in computer
US7047283B1 (en) * 1999-06-09 2006-05-16 Samsung Electronics Co., Ltd. Apparatus and method of upgrading program of firmware board
US6507881B1 (en) * 1999-06-10 2003-01-14 Mediatek Inc. Method and system for programming a peripheral flash memory via an IDE bus
US6523083B1 (en) * 1999-12-09 2003-02-18 Via Technologies, Inc. System and method for updating flash memory of peripheral device
US7228536B2 (en) * 1999-12-15 2007-06-05 Sanden, Corporation System for rewriting control program in vending machine
US7024513B2 (en) * 2000-06-08 2006-04-04 Sanyo Electric Co., Ltd. Controller and data processing system
US20010052048A1 (en) * 2000-06-08 2001-12-13 Kaneo Watanabe Controller and data processing system
US7333516B1 (en) 2000-07-20 2008-02-19 Silicon Graphics, Inc. Interface for synchronous data transfer between domains clocked at different frequencies
US7248635B1 (en) 2000-07-20 2007-07-24 Silicon Graphics, Inc. Method and apparatus for communicating computer data from one point to another over a communications medium
US6604185B1 (en) 2000-07-20 2003-08-05 Silicon Graphics, Inc. Distribution of address-translation-purge requests to multiple processors
US6779072B1 (en) * 2000-07-20 2004-08-17 Silicon Graphics, Inc. Method and apparatus for accessing MMR registers distributed across a large asic
US6839856B1 (en) 2000-07-20 2005-01-04 Silicon Graphics, Inc. Method and circuit for reliable data capture in the presence of bus-master changeovers
US6831924B1 (en) 2000-07-20 2004-12-14 Silicon Graphics, Inc. Variable mode bi-directional and uni-directional computer communication system
US6681293B1 (en) 2000-08-25 2004-01-20 Silicon Graphics, Inc. Method and cache-coherence system allowing purging of mid-level cache entries without purging lower-level cache entries
US6834331B1 (en) 2000-10-24 2004-12-21 Starfish Software, Inc. System and method for improving flash memory data integrity
US9105281B2 (en) 2001-01-25 2015-08-11 Optical Devices, Llc Servo processor receiving photodetector signals
US8937854B2 (en) 2001-01-25 2015-01-20 Optical Devices, Llc Servo processor receiving photodetector signals
US9514777B2 (en) 2001-01-25 2016-12-06 Optical Devices, Llc Servo processor receiving photodetector signals
US9245569B1 (en) 2001-01-25 2016-01-26 Optical Devices, Llc Servo processor receiving photodetector signals
US20020114457A1 (en) * 2001-01-26 2002-08-22 Takahiro Sato LSI having interpreter function and information recording/reproducing apparatus using the same
US7032218B2 (en) * 2001-04-20 2006-04-18 Hitachi, Ltd. Updating method of firmware of hard disk unit mounted on disk array device and disk array device with function for performing updating method
US20020166027A1 (en) * 2001-04-20 2002-11-07 Hitachi, Ltd. Updating method of firmware of hard disk unit mounted on disk array device and disk array device with function for performing updating method
US20030189811A1 (en) * 2001-06-29 2003-10-09 Peeke Douglas E. Advanced technology attachment disk drive module with fibre channel system characteristics
US6850410B2 (en) 2001-06-29 2005-02-01 Emc Corporation Advanced technology attachment disk drive module with fibre channel system characteristics
US20030070029A1 (en) * 2001-10-04 2003-04-10 Alps Electric Co., Ltd. Data transmission transceiver unit and program updating method therefor
US6684290B2 (en) * 2001-10-18 2004-01-27 Kabushiki Kaisha Toshiba Memory rewriting apparatus and method for memory mapping rewriting program to same address space
US7251706B2 (en) * 2002-09-05 2007-07-31 Mediatek Inc. System and method for updating firmware in a non-volatile memory without using a processor
US20060184763A1 (en) * 2002-09-05 2006-08-17 Yung-Chun Lei System and method for updating firmware in a non-volatile memory without using a processor
US7490194B2 (en) 2002-09-05 2009-02-10 Mediatek Inc. System and method for updating firmware in a non-volatile memory without using a processor
US7043597B2 (en) * 2002-09-05 2006-05-09 Mediatek Inc. System and method for updating firmware in a non-volatile memory without using a processor
US20080016268A1 (en) * 2002-09-05 2008-01-17 Yung-Chun Lei System and method for updating firmware in a non-volatile memory without using a processor
US20040117541A1 (en) * 2002-09-05 2004-06-17 Yung-Chun Lei System and method for updating firmware in a non-volatile memory without using a processor
US7028174B1 (en) 2002-09-30 2006-04-11 Western Digital Technologies, Inc. Disk drive employing a non-volatile serial semiconductor memory for storing a control program for a microprocessor
US20050149641A1 (en) * 2002-10-03 2005-07-07 Workman Michael L. Methods and data storage subsystems of controlling serial ATA storage devices
US20040123027A1 (en) * 2002-10-03 2004-06-24 Workman Michael Lee Systems and methods of multiple access paths to single ported storage devices
US20040068591A1 (en) * 2002-10-03 2004-04-08 Workman Michael Lee Systems and methods of multiple access paths to single ported storage devices
US20050149650A1 (en) * 2002-10-03 2005-07-07 Workman Michael L. Data storage systems for assigning control of serial ATA storage devices
CN100339823C (en) * 2002-10-08 2007-09-26 松下电器产业株式会社 Program updating method and terminal device
US7065661B2 (en) 2002-12-16 2006-06-20 Emc Corporation Using request and grant signals to read revision information from an adapter board that interfaces a disk drive
US20040117545A1 (en) * 2002-12-16 2004-06-17 Matthew Borsini Using request and grant signals to read revision information from an adapter board that interfaces a disk drive
US6829658B2 (en) 2002-12-16 2004-12-07 Emc Corporation Compatible signal-to-pin connector assignments for usage with fibre channel and advanced technology attachment disk drives
US7194673B2 (en) 2002-12-20 2007-03-20 Emc Corporation Detecting intermittent losses of synchronization in a fibre channel loop
US20040153685A1 (en) * 2002-12-20 2004-08-05 Tuttle James M. Detecting intermittent losses of synchronization in a fibre channel loop
US20040150907A1 (en) * 2003-01-16 2004-08-05 Samsung Electronics Co., Ltd Method of making and updating optimal unlatch profile for hard disk drive
EP1439528A1 (en) * 2003-01-16 2004-07-21 Samsung Electronics Co., Ltd. Method of marking and updating optimal unlatch profile for hard disk drive
US7516272B2 (en) 2003-03-28 2009-04-07 Emc Corporation Midplane-independent implementations of data storage system enclosures
US20040193791A1 (en) * 2003-03-28 2004-09-30 Felton Mickey S. Midplane-independent implementations of data storage system enclosures
US7603515B1 (en) 2003-03-28 2009-10-13 Emc Corporation Midplane-independent implementations of data storage system enclosures
US7145776B2 (en) 2003-12-22 2006-12-05 Emc Corporation Midplane-less data storage enclosure
US20050135060A1 (en) * 2003-12-22 2005-06-23 Emc Corporation Fan assembly for installing and removing fans individually and collectively
US7236361B2 (en) 2003-12-22 2007-06-26 Emc Corporation Fan assembly for installing and removing fans individually and collectively
US20050135069A1 (en) * 2003-12-22 2005-06-23 Emc Corporation Midplane-less data storage enclosure
US20050265266A1 (en) * 2004-05-25 2005-12-01 Chih-Chiang Wen Optical disc drive that downloads operational firmware from an external host
US20080301358A1 (en) * 2004-05-25 2008-12-04 Chih-Chiang Wen Electronic device that Downloads Operational Firmware from an External Host
US20050268029A1 (en) * 2004-05-25 2005-12-01 Chih-Chiang Wen Optical Disc Drive that Downloads Operational Firmware from an External Host
CN100337223C (en) * 2004-07-16 2007-09-12 英业达股份有限公司 Structure capable of making burning program directly on the mainboard
US20060224821A1 (en) * 2005-04-01 2006-10-05 Mediatek Incorporation System for parallel updating flash memory and method for the same
US20090083475A1 (en) * 2007-09-24 2009-03-26 Mediatek Inc. Apparatus and method for updating firmware stored in a memory
US20100131698A1 (en) * 2008-11-24 2010-05-27 Tsai Chien-Liang Memory sharing method for flash driver
US9069488B2 (en) 2010-08-27 2015-06-30 Fxi Technologies As Electronic devices
US9134923B2 (en) 2010-08-27 2015-09-15 Fxi Technologies As Electronics device
US9451026B2 (en) 2010-08-27 2016-09-20 Millennium Enterprise Corporation Electronic devices
US9479590B2 (en) 2010-08-27 2016-10-25 Millennium Enterprise Corporation Master storage device for controlling slave functions of a host electronic device
US9781211B2 (en) 2010-08-27 2017-10-03 Millennium Enterprise Corporation Storage device having master and slave storage device modes
US20180011803A1 (en) * 2016-07-07 2018-01-11 Gowin Semiconductor Corporation, Ltd Secrecy System And Decryption Method Of On-Chip Data Stream Of Nonvolatile FPGA
US10997088B2 (en) * 2016-07-07 2021-05-04 Gowin Semiconductor Corporation, Ltd. Secrecy system and decryption method of on-chip data stream of nonvolatile FPGA
US10521150B2 (en) * 2018-05-23 2019-12-31 Gowin Semiconductor Corporation Data processing method and device for nonvolatile memory and storage medium

Also Published As

Publication number Publication date
JP3310060B2 (en) 2002-07-29
JPH0784776A (en) 1995-03-31

Similar Documents

Publication Publication Date Title
US5603056A (en) Disk drive control computer and method for rewriting control program in flash EEPROM with serial communication using unassigned pins of SCSI or ATA connector
EP0548564B1 (en) Storage device employing a flash memory
EP0392895B1 (en) Flash EEprom system
US7123519B2 (en) Storage device employing a flash memory
US6601132B2 (en) Nonvolatile memory and method of writing data thereto
US5854937A (en) Method for reprogramming flash ROM in a personal computer implementing an EISA bus system
KR100507884B1 (en) System for controlling rewrite in memory, method for controlling rewrite in memory, and information recording media for storing programs which excute each steps in method for controlling rewrite in memory
US8185705B2 (en) Information recording medium, information recording medium accessing apparatus and accessing method
US5724544A (en) IC memory card utilizing dual eeproms for image and management data
US5657301A (en) Automatic changer system capable of rewriting a control program for controlling the system
US5428755A (en) Method for automatically modifying program in a flash memory of a magnetic tape unit
JPH08263229A (en) Semiconductor memory device
JP2003114807A (en) Electronics device and method for rewriting main body control program
JPH07141479A (en) Ic memory card and file control system using ic memory card

Legal Events

Date Code Title Description
AS Assignment

Owner name: KABUSHIKI KAISHA TOSHIBA, JAPAN

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:TOTANI, TOKUYUKI;REEL/FRAME:007200/0859

Effective date: 19941012

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

FPAY Fee payment

Year of fee payment: 12