[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

US20010010065A1 - Data processing system, block erasing type memory device and memory medium storing program for controlling memory device - Google Patents

Data processing system, block erasing type memory device and memory medium storing program for controlling memory device Download PDF

Info

Publication number
US20010010065A1
US20010010065A1 US09/816,383 US81638301A US2001010065A1 US 20010010065 A1 US20010010065 A1 US 20010010065A1 US 81638301 A US81638301 A US 81638301A US 2001010065 A1 US2001010065 A1 US 2001010065A1
Authority
US
United States
Prior art keywords
data
block
memory device
erasing
file
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.)
Granted
Application number
US09/816,383
Other versions
US6401166B2 (en
Inventor
Toshihiko Chiba
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.)
Tokyo Electron Device Ltd
Original Assignee
Tokyo Electron Ltd
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 Tokyo Electron Ltd filed Critical Tokyo Electron Ltd
Priority to US09/816,383 priority Critical patent/US6401166B2/en
Assigned to TOKYO ELECTRON LIMITED reassignment TOKYO ELECTRON LIMITED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CHIBA, TOSHIHIKO
Publication of US20010010065A1 publication Critical patent/US20010010065A1/en
Assigned to TOKYO ELECTRON DEVICE LIMITED reassignment TOKYO ELECTRON DEVICE LIMITED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: TOKYO ELECTRON LIMITED
Application granted granted Critical
Publication of US6401166B2 publication Critical patent/US6401166B2/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/061Improving I/O performance
    • G06F3/0613Improving I/O performance in relation to throughput
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/061Improving I/O performance
    • G06F3/0611Improving I/O performance in relation to response time
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/064Management of blocks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0646Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
    • G06F3/0652Erasing, e.g. deleting, data cleaning, moving of data to a wastebasket
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]

Definitions

  • This invention relates to data processing system using block erasing type memory device, block erasing type memory device and computer readable program memory medium storing program for formatting, data erasing and date write for block erasing type memory device.
  • a flash memory has been used as a portable nonvolatile memory medium instead of a floppy disk, particularly as a memory medium for a mobile information terminal.
  • the flash memory mentioned herein refers to a nonvolatile block erasing type memory device comprising a plurality of blocks, in which data stored internally can be electrically erased by each block.
  • the flash memory When the flash memory is used under a control of such a disk operating system as MS-DOS (Microsoft's trademark), it is formatted according to the same format as that used conventionally for the floppy disk so as to handle it in the same way as the floppy disk. According to this format, a memory area is divided to boot area, FAT (file allocation table) area, directory area and data area. The data area is logically divided to clusters according to a definition stored in the boot area and a file to be stored in the flash memory is memorized in units of one cluster.
  • MS-DOS Microsoft's trademark
  • An object of the present invention is to accelerate data access, particularly processing including data erasing in the block erasing type memory device.
  • Another object of the invention is to provide a block erasing type memory device having a format structure capable of achieving data write-in processing rapidly and making the best use of the storage capacity, data processing system using the same memory medium and a program memory medium storing a program for formatting of the block erasing type memory device, data erasing and data write-in.
  • data processing system comprising a block erasing type memory device including a plurality of blocks, capable of erasing stored data collectively in units of one block and data processing means for accessing the block erasing type memory device
  • the data processing means includes a formatting portion connected to the block erasing type memory device for formatting the block erasing type memory device according to formatting information for substantially coinciding the size and position of a cluster as a logical unit of a memory region of the block erasing type memory device with those of integer ones of the blocks, and an access control portion for determining the size and position of the cluster according to the format information and carrying out access control for data erasing, data write-in and data read-out for the block erasing type memory device according to the determined size and position of the cluster.
  • a cluster includes integer ones of the blocks.
  • data erasing and write-in processing can be carried out in units of one block.
  • the necessity of saving other data for data write-in or erasing is eliminated, so that the data erasing and write-in processing can be carried out rapidly.
  • a block erasing type memory device having a format information memory region for storing format information for making integer ones substantially correspond to a cluster serving as a unit of data memory region and capable of erasing stored data collectively in units of one block.
  • the cluster includes integer ones.
  • data erasing and write-in processing can be carried out in units of one block.
  • the necessity of saving other data for data write-in is eliminated, so that the data erasing and write-in processing can be carried out rapidly.
  • the cluster has a single block, it may be formed of a plurality of the blocks.
  • the format information comprises information for corresponding the size of the cluster with the size of the block and a position adjusting region for coinciding a start position and end position of each of the clusters with the start position and end position of the block, for example, an empty region.
  • the block erasing type memory device may store directory information indicating a file name and head memory position and a file allocation table indicating a file position in a single cluster.
  • position information e.g., file allocation table
  • identification name e.g., file name and directory
  • data processing system comprising a connecting portion containing a plurality of blocks and so constructed to be connectable to a block erasing type memory device capable of erasing collectively stored data in units of one block and a formatting portion for formatting the block erasing type memory device by writing format information for substantially coinciding integer ones of the blocks, for example, one block with a cluster into the block erasing type memory device through the connecting portion.
  • the cluster includes integer ones of the blocks.
  • the data erasing and write-in processings can be carried out in units of one block. Therefore, the necessity of saving other data for data write-in processing is eliminated, so that the data erasing and write-in processing can be accelerated.
  • the aforementioned data processing system may further comprise a section for recording directory information indicating a file name and head memory position and a file allocation table indicating a file positioning a cluster.
  • the aforementioned formatting portion may include an erasing portion for physically erasing stored data of blocks other than a block in which the format information is written.
  • the aforementioned data processing system further comprises a format information readout portion for reading out the format information through the connecting portion, a cluster determining portion for determining a size and position of a cluster serving as a minimum unit of a file according to format information read out by the format information readout portion and a control portion for controlling erasing, write-in and readout of data of the block erasing type memory device according to the size and position of a cluster determined by the cluster determining means.
  • a program for making the computer to execute the above described data processing system and function may be stored in a memory medium and distributed, and installed in the computer so as to carry out the above described operation on the computer.
  • FIG. 1 is a block diagram showing a structure of a memory control system of a flash memory according to a first embodiment of the present invention
  • FIG. 2 is a schematic diagram showing a structure of the flash memory
  • FIG. 3 is a diagram showing a structure of a memory cell array
  • FIG. 4 is a diagram showing a relation between a block and cluster in the format of the flash memory according to the first embodiment of the present invention
  • FIG. 5 is a diagram showing a correspondence among directory, file allocation table and cluster in the first embodiment of the present invention.
  • FIG. 6 is a diagram showing an example of a structure of an address conversion table
  • FIG. 7 is a flow chart showing data read-out operation of the first embodiment of the present invention.
  • FIG. 8 is a flow chart showing data write-in operation of the first embodiment of the present invention.
  • FIG. 9 is a flow chart showing data erasing operation of the first embodiment of the present invention.
  • FIG. 10 is a flow chart showing formatting processing of the flash memory according to the first embodiment of the present invention.
  • FIG. 11 is a flow chart showing file erasing in the flash memory according to the first embodiment of the present invention.
  • FIG. 12 is a flow chart showing a processing for writing a file into the flash memory according to the first embodiment of the present invention
  • FIG. 13 is a block diagram showing a structure of a memory device according to a second embodiment of the present invention.
  • FIG. 14 is a formatting diagram of the flash memory according to a third embodiment of the present invention.
  • FIG. 15 is a flow chart showing a processing of formatting the flash memory according to the fourth embodiment of the present invention.
  • FIG. 16 is a diagram showing a particular cluster group for storing data of a file allocation table and directory according to a fifth embodiment of the present invention.
  • FIG. 17 is a diagram showing particular two cluster groups according to the fifth embodiment of the present invention.
  • FIG. 18 is a flow chart of a processing for formatting the flash memory according to the fifth embodiment of the present invention.
  • FIG. 19 is a flow chart showing a processing of erasing a file in the flash memory according to the fifth embodiment of the present invention.
  • FIG. 20 is a flow chart showing a processing of writing a file into the flash memory according to the fifth embodiment of the present invention.
  • FIG. 1 is a block diagram showing a structure of a memory control system of a flash memory according to a first embodiment of the present invention.
  • this memory control system comprises a flash memory 1 , a memory control unit (memory controller) 2 , a computer 3 and I/O bus 4 .
  • the memory control unit 2 is connected to the computer 3 through the I/O bus 4 such as SCSI bus and is removable from the computer 3 .
  • the flash memory 1 is a block erasing type memory device containing a memory cell array 11 , an address register 12 , a column decoder 13 , a low address decoder 14 , a voltage converting circuit (voltage converter) 15 and a high voltage generating circuit (high voltage generator) 16 .
  • the memory cell array 11 is constituted of a plurality of memory regions each having a memory capacity of 1 byte. These memory regions are arranged in matrix of 16384 rows ⁇ 528 columns, and therefore the entire memory cell array has a memory capacity of about 8.65 M byte.
  • Each row of the memory cell array 11 forms a page having a memory capacity of 528 byte as shown in FIG. 2. Respective memory regions contained in each page are supplied with a column address continuously from 1 to 528.
  • Each unit of 16 pages from beginning forms a single block.
  • Each block has a memory capacity of about 8.03 K byte and the entire memory area includes 1024 blocks.
  • Each block is supplied with a block address continuously from 1 to 1024.
  • Every 16 memory regions belonging to the same block contains memory cells arranged in matrix of 16 rows ⁇ 8 columns as shown in FIG. 3. These memory cells are of NAND type, formed on a common substrate.
  • the current path of the memory cell of each column is connected in cascade and the gate of each row is connected to a common row control input terminal (Trcnt).
  • Trcnt row control input terminal
  • Each row control input terminal Trcnt is connected to a gate of each memory cell belonging to other column of the same page.
  • a source of FETs (field effect transistors) 1 - 1 to 1 - 8 is connected to an end of each current path connected in cascade.
  • a drain of each of FETs 1 - 1 to 1 - 8 is connected to data I/O terminal Tdata corresponding to each column and a gate thereof is connected to the common row control input terminal Tccntl.
  • a drain of each of column selection FETs 2 - 1 to 2 - 8 is connected to the other end of each current path a source of each of the FETs 2 - 1 to 2 - 8 is connected to a substrate.
  • a gate of each of the FETs 2 - 1 to 2 - 8 is connected to a common column control input terminal (Tccnt 2 ).
  • the column control input terminals Tccnt 1 and Tccnt 2 are connected to the gates of the row selection FETs 1 - 1 to 1 - 8 and FETs 2 - 1 to 2 - 8 connected to respective memory cells belonging to the same row of the flash memory array 11 .
  • Each memory cell carries out write-in of data on the data I/O terminal Tdata, reading to the data I/O terminal Tdata and erasing of the memory according to a voltage applied to the row control input terminal Trcnt, column control input terminal Tccnt 1 , Tccnt 2 and substrate.
  • data write is carried out in units of one page
  • data read is carried out in units of one byte
  • data erasing is carried out in units of one block.
  • each memory cell is of NAND type, data recording cannot be carried out but in a direction from “1” to “0” in a recorded value.
  • a bit in which a recorded value of the memory cell is “0” keeps a state of “0” until the recording content is reset (erasing in units of one block).
  • the address register 12 is connected to the column decoder 13 , low address decoder 14 and memory control unit 2 .
  • the address register 12 receives 3-byte information indicating column address and page address of the memory cell array 11 from the memory control unit 2 by each byte and stores it. Of the stored information, column address information is outputted to the column decoder 13 and page address information is outputted to the low address decoder 14 .
  • Page address information is inputted from the address register 12 to the low address decoder 14 . According to that information and an instruction of the control circuit 21 , forward bias voltage or reverse bias voltage generated by the high voltage generator 16 is applied to respective column control input terminals Tccnt 1 , Tccnt 2 .
  • the voltage converter 15 receives data to be written into the memory cell array from data register 24 and a voltage indicating each bit of that data is converted to a predetermined write-in voltage. Then, this write-in voltage is applied to the data I/O terminal Tdata according to an instruction of the control circuit 21 .
  • the voltage converter 15 fetches a voltage indicating a content of each memory cell from the data I/O terminal Tdata, amplifies that voltage and then stores it in the data register 24 .
  • the high voltage generator 16 According to an instruction of the control circuit 21 , the high voltage generator 16 generates a write-in voltage to be applied to each row control input terminal Trcnt, write inhibiting voltage to be applied to each data I/O terminal Tdata, erasing voltage to be applied to the substrate and forward bias voltage and reverse bias voltage to be applied to the column control input terminals Tccnt 1 , Tccnt 2 of each column. A generated voltage is supplied to a substrate of the memory cell array 11 , column decoder 13 and low address decoder 14 .
  • the memory control unit (memory controller) 2 shown in FIG. 1 comprises the control circuit 21 , I/O control circuit 22 , operating logic control circuit 23 , command register 24 and data register 25 .
  • the memory control unit 2 transfers data between the flash memory 1 and a main storage unit 32 .
  • the control circuit 21 controls the column decoder 13 , low address decoder 14 , voltage converter 15 and high voltage generator 16 as described later, according to a command stored in a command register 24 and an instruction of the operating logic control circuit 23 .
  • the I/O control circuit 22 is connected to the data bus of the flash memory 1 , I/O bus 4 , operating logic control circuit 23 , command register 24 , address register 12 and status register 28 .
  • the I/O control circuit 22 fetches in data from the data register 25 and I/O bus 4 according to an instruction of the operating logic control circuit 23 and outputs data to the address register 12 , command register 24 , data register 25 and I/O bus 4 .
  • the operating logic control circuit 23 is connected to a CPU 31 which will be described later, I/O control circuit 22 and control circuit 21 .
  • the operating logic control circuit 23 receives a command latch signal, address latch signal, write-in signal and read-out signal from the CPU 31 and according to these signals, controls the control circuit 21 and I/O control circuit 22 as will be described later.
  • the command register 22 stores command information received from the I/O control circuit 22 and outputs to the control circuit 21 .
  • the data register 25 has a memory capacity of 528 bytes and stores data of a write-in object received from the I/O control circuit 22 and outputs to the voltage converter 15 . Further, it fetches data outputted from the voltage converter 15 as a result of read-out from the memory cell array 11 and outputs to the I/O control circuit 22 .
  • the computer 3 comprises a CPU (central processing unit) 31 , main storage unit 32 and IOC (I/O control unit) 33 , each connected through a system bus 34 made of VME bus.
  • the computer 3 is connected to the I/O bus 4 through an IOC 33 .
  • the CPU 31 executes a program stored in the main storage unit 32 .
  • the CPU 31 outputs a command for executing a program shown in a flow chart described later corresponding to an operation of an input device (not shown) like a key board, connected to the computer 3 through the I/O bus 4 . It outputs a command for executing a program shown in a flow chart described later.
  • the main storage unit 32 stores a file to be stored in the flash memory and a file to be read from the flash memory 1 as well as processing program of the CPU 31 .
  • the main storage unit 32 stores master boot record to be recorded in boot region when the flash memory 1 is formatted, partition record and an address conversion table which will be described later.
  • the IOC 33 is an I/O controller for controlling an output of data from the CPU 31 or main storage unit 32 of the computer 3 to the I/O bus 4 and input of the opposite direction processing.
  • the memory cell array 11 is formatted according to an operating system (OS) used by the computer 3 , for example, MS-DOS (Microsoft's trade name) and particularly formatted in such a manner that a block of a physical structure of the memory cell array 11 coincides with a cluster of a logical unit of a file managed by OS.
  • OS operating system
  • MS-DOS Microsoft's trade name
  • Each cluster is supplied with a number beginning with “1” and this number does not always agree with an order of the block from a head address of the memory cell array 11 .
  • the memory region of the memory cell array 11 is divided to master boot memory region (master boot memory region), empty region (empty region), partition boot memory region (partition boot memory region), FAT (file allocation table), directory region and file region.
  • the master boot memory region, empty region, and partition boot memory region are allocated at a head block of the memory cell array 11 .
  • the master boot memory region includes a first page (first sector) of a head and a region for recording information about processing of startup and information of each partition provided on this memory (each virtual memory in a case when this memory is divided to one or more virtual memories).
  • Information about each partition includes information, for example, of whether or not each partition is to be started and further includes following information.
  • the empty region has 14 pages following the master boot memory region.
  • the empty region is provided for coinciding a head and end of the block which is a physical unit with those of a cluster which is a logical unit managed by the OS when the memory region is divided to a plurality of clusters.
  • the partition boot memory region has a page following the empty region.
  • the partition boot memory region stores information about a structure of each partition and information about processing for startup.
  • the information about the structure of each partition has a following content.
  • the cluster is a unit of memory consisting of a specified number of pages which are defined in the partition boot memory region and a minimum unit of memory in which a content of a file managed by the OS is recorded. Therefore, different file contents are never contained in a cluster.
  • each cluster has 16 pages so as to coincide the sizes of the block and cluster with each other.
  • the blocks 2 to 1024 form data region for storing arbitrary data, file and the like.
  • FAT and directory are stored in any of the data regions (block 2 in the initial condition).
  • the FAT is stored in head three pages of 16 pages in a block and the directory is stored in the remaining 13 pages.
  • the FAT is a table indicating an allocation of the file.
  • the directory includes information about a name of a stored file and a number of a cluster in which a head of the file is stored, and the like.
  • FIG. 5 is a diagram showing a relation between FAT, directory and cluster.
  • the number of a cluster in which the FAT and directory are stored is indicated by a pointer in a memory portion 21 a of the control circuit 21 .
  • the directory points out a file name of a file stored in the memory cell array 11 and a cluster in which a head portion of that file is stored with a pointer.
  • the FAT points out a cluster for storing the following portion.
  • a cluster in which the final portion of the file is stored is indicated by an end cord (EC).
  • the address conversion table is a table for storing information indicating the number of a cluster allocated for each block. As described previously, the address conversion table is stored in the main storage unit 32 of the computer 3 and accessed by the CPU 31 and updated.
  • FIG. 6 shows an example of a structure of the address conversion table.
  • the address conversion table comprises a plurality of records. A cluster number beginning with “1” is stored at the head of each record and a block number corresponding to that number is stored.
  • the number “1” is always allocated to a block in which the FAT is stored as a cluster No.
  • the number “I” of the cluster is updated by a processing described later so as to indicate a block in which the FAT is to be newly stored.
  • the command latch signal is on active level and it is started if a write-in signal is inputted to the operating logic control circuit 23 with command “00H” indicating a first readout mode being inputted to the I/O control circuit 22 through the I/O bus 4 (step 101 , a numerical value having “H” at its end expresses hexadecimal number).
  • the operating logic control circuit 23 instructs the I/O control circuit 22 to input a command (step S 102 ) and the I/O control circuit 22 receiving the instruction stores command “00H” in the command register 24 (step S 103 ).
  • control circuit 21 If the control circuit 21 reads a content of the command register 24 (step S 104 ), the control circuit 21 detects a start of the first readout mode.
  • the command latch signal is released and instead, the address latch signal is made to active level.
  • a signal indicating a column address is inputted to the I/O bus 4 . If the write-in signal is inputted again in this condition (step S 105 ), the operating logic control circuit 23 instructs the I/O control circuit 22 to input an address (step S 106 ).
  • the I/O control circuit 22 receiving such an instruction stores a column address in the address register 12 (step S 107 ).
  • a low order page address signal specifying low order 8 bits of the page address is inputted to the I/O bus 4 in the condition that the address latch signal is kept in active level (step S 108 ). If the write-in signal is inputted again in this condition, the operating logic control circuit 23 instructs the I/O control circuit 22 to input an address. The I/O control circuit 22 receiving such an instruction stores a low order page address in the address register 12 (step S 109 ).
  • step S 110 a high order page address specifying a high order 5 bits of the page address is stored in the address register 12 (step S 110 ).
  • the address register in which the column address and page address information items are inputted through above three times inputs the column address to the column decoder 13 and then block address and page address to the low address decoder 14 (step S 111 ).
  • the column decoder 13 and low address decoder 14 specify a memory region at the head of an readout object.
  • step S 112 If the readout object is specified, the address latch signal is released and the readout signal is inputted (step S 112 ).
  • the operating logic control circuit 23 in which the readout signal is inputted instructs the control circuit 21 to start a start of data readout control (step S 113 ).
  • control circuit receiving such an instruction instructs the column decoder 13 , low address decoder 14 and high voltage generator 16 to start an operation for reading data (step S 114 ).
  • the column decoder 13 receiving such an instruction applies a sufficiently deep forward bias to the column control input terminals Tccnt 1 , Tccnt 2 .
  • the low address decoder 14 applies a predetermined readout voltage to the column control input terminal Tccnt connected to a gate of each memory cell forming a memory region of a readout object and a predetermined read-out inhibiting voltage to the other row control input terminal Tccnt (step S 115 ).
  • the second readout mode is started by the write-in signal when the command “01H” indicating the second readout mode is inputted in the I/O control circuit 22 by the I/O bus 4 at the aforementioned step S 101 .
  • the second readout operation is different from the first readout mode in that a head position read out is an address 256 ahead of a position indicated by the column address or page address inputted through the I/O bus 4 .
  • the other operation is the same as the first readout mode.
  • the third readout mode is started by the write-in signal when the command “50H” indicating the second readout mode is inputted to the I/O control circuit 22 by the I/O bus 4 at the aforementioned step S 101 .
  • a head position read out is an address 512 ahead of a position indicated by the low order 4 bits of the column address and page address inputted from the I/O bus 4 . Further, after data of the memory cell of a final column of each page is read, if a readout signal is further inputted, readout from a 513th memory cell of a next page is carried out. Memory cells following 513th one of each page are objects of readout. The other operation is the same as the first readout mode.
  • FIG. 8 An operation for data write-in shown in FIG. 8 is carried out as described below, when an address of a write-in object page is specified, data of a page is written into the data register 25 and then data in the data register is written successively into a specified page.
  • the write-in processing is started when a write-in signal is inputted to the operating logic control circuit 23 in the condition that the command “80H” indicating data output to the data register is inputted to the I/O control circuit 22 while the command latch signal is active level (step S 201 ).
  • the column decoder 13 and low address decoder 14 specify a column address and a page address indicating a position of head of a write-in object page in the same processing as steps S 102 to S 111 in data read-in processing (step S 202 ).
  • step S 203 If the address latch signal is released after the processing of the step S 202 is terminated and then a write-in signal is inputted to the operating logic control circuit 23 , the operating logic control circuit 23 instructs the I/O control circuit 22 to input data (step S 203 ).
  • the I/O control circuit 22 in which such an instruction is inputted stores data outputted to the I/O bus 4 at an address of a head of the data register 25 (step S 204 ).
  • control circuit 21 , I/O control circuit 22 and operating logic control circuit 23 carry out the same processing as steps S 203 to S 204 and stores write-in data at a following address of the data register 25 (step S 205 ).
  • Total amount of data to be written in must be within a single page, namely less than 528 bytes.
  • step S 206 If all write-in object data are stored in the data register 25 , the command latch signal is made to active level and the command “10H” instructing to write the storage content of the data register 25 into a write-in object page is inputted to the I/O bus 4 (step S 206 ).
  • the operating logic control circuit 23 instructs the control circuit 21 to start data write-in control (step S 207 ).
  • a control circuit 221 receiving such an instruction instructs the column decoder 13 , low address decoder 14 , voltage converter 15 , high voltage generator 16 and data register 25 to start data write-in operation (step S 208 ).
  • the high voltage generator 16 receiving such an instruction generates a write-in voltage and supplies it to the low address decoder 14 and then generates a write-in inhibiting voltage and supplies it to the voltage converter 15 (step S 209 ).
  • the voltage converter 15 reads 1 byte data stored at a head address of the low address decoder 14 .
  • the write-in inhibiting voltage inputted from the high voltage generator 16 is applied to the data I/O terminal Tdata corresponding to a bit the logical value of which is “1” and on the other hand, ground voltage is applied to the data I/O terminal Tdata corresponding to a bit the logical value of which is “0” (step S 210 ).
  • the column decoder 13 applies a sufficiently deep forward bias to the column control input terminal Tccntl which is a memory region for a page specified at step S 202 and applies a sufficiently deep reverse bias to the column control terminal Tccnt 2 . Further, the low address decoder 14 applies a write-in voltage inputted from the high voltage generator 16 to the row control input terminal Trcnt which is a page specified at step S 202 (step S 211 ).
  • step S 211 If the processing of step S 211 is terminated, following data stored in the data register 25 is successively written into following memory region specified by step S 202 through the same processing as steps S 209 to S 211 (step S 212 ).
  • An operation for erasing data in a block shown in FIG. 9 is started by inputting a write-in signal into the operating logic control circuit 23 when the command latch signal is on active level and a command“60H” indicating a load of address of an erasing object block is inputted to the I/O control circuit 22 (step S 301 ).
  • the address register 12 inputs an address of high order and low order pages by the same processing as steps S 102 to S 111 in data read-in processing. High order 9 bits of the inputted page address are extracted and a block address indicating a position of the erasing object block is specified (step S 302 ).
  • the command latch signal is made to active level and the command “D0H” instructing to erase the storage content of the erasing object block is inputted to the I/O bus 4 (step S 303 ).
  • the operating logic control circuit 23 instructs the control circuit 21 to start a control for erasing data of the specified block (step S 304 ).
  • the control circuit 21 receiving this instruction instructs the column decoder 13 , low address decoder 14 and high voltage generator 16 to start the processing for erasing data (step S 305 ).
  • the column decoder 13 receiving such an instruction applies a sufficiently deep reverse bias to all row control input terminals Tccntl and Tccnt 2 of the memory cell array 11 .
  • the low address decoder 14 applies ground voltage to the row control input terminals Trcnt of all pages belonging to a block specified by step S 302 (step S 306 ).
  • the high voltage generator 16 generates an erasing voltage and this erasing voltage is applied to a substrate of the memory cell array 11 (step S 307 ).
  • the memory values of all the memory cells belonging to the appropriate block turn to “1”.
  • data stored in the memory cell array 11 is erased in units of one block.
  • the flash memory 1 and memory control unit 2 execute the above described erasing operation, namely the operations of steps S 301 to S 306 in order to erase each block and then erase the storage content of each block (step S 401 ).
  • the commands “60H” and “D0H” outputted to the I/O bus 4 are transmitted from the CPU 31 through the system bus 34 and IOC 33 .
  • the CPU 31 executes the format program so as to generate a master boot record, empty area size and partition boot record having the above described content in order to coincide in the size and position the block and sector of the flash memory 1 with each other.
  • the flash memory 1 and memory control unit 2 execute the above described operation, namely, the operation of steps S 201 to S 211 to write a master boot record having the above described content by each page from the beginning (step S 402 ).
  • the commands “80H” and “10H” and write-in object data are transmitted from the CPU 31 through the system bus 34 and IOC 33 .
  • the memory control unit 2 empties 14 pages and writes a partition boot record into page 16 of block 1 in the same operation (step S 403 ).
  • the CPU 31 generates an address conversion table and stores it in the main storage unit 32 (step S 404 ).
  • each cluster and block values are set so that each block number from a head address of the memory cell array 11 coincides with each cluster. That is, the block 2 is set to coincide with cluster 2 , and the block 3 is set to coincide with the cluster 3 . In the following treatment, matching of the block number or cluster number is performed.
  • the CPU 31 instructs the memory control unit 2 according to a program stored in an internal ROM (not shown) to read information stored in the master boot region and partition boot region of the flash memory 1 by a first readout mode.
  • the master boot record stored in the first page of the first block is read out from the data I/O terminal Tdata.
  • the read out master boot record is supplied to the CPU 31 .
  • the CPU 31 instructs the memory control unit 2 to read a partition boot record on the first readout mode by the same operation based on the read out master boot record.
  • the read out partition boot record is supplied to the CPU 31 .
  • the CPU 31 stores the read out boot information in the main storage unit 32 .
  • the CPU 31 determines a cluster size and a head of the data region according to the readout data.
  • the file access operation is carried out following a definition of these boot information. Therefore, the minimum unit and position of a file at the time of data read-out and write-in become the same size and position of the block of the flash memory 1 .
  • the file erase processing is started by operating such an input device (not shown) as a key board connected to the computer 3 or a necessity of an application program being executed by the CPU 31 .
  • the CPU 31 specifies an erase object file (step S 501 ).
  • the CPU 31 specifies a page having FAT and directory (that is, pages after a head of a block in which cluster number “1” is allocated on the address conversion table).
  • the CPU 31 instructs the memory control unit 2 to read out an appropriate page on the first readout mode through the system bus 34 , IOC 33 and I/O bus 4 .
  • the CPU 31 inputs the storage content of the FAT and directory read out by the memory control unit 2 and stores it in the main storage unit 32 (step S 502 ).
  • the CPU 31 retrieves the FAT and directory stored in the main storage unit 32 and specifies a cluster in which a file specified at step S 501 is stored.
  • the cluster number is temporarily stored in the main storage unit 32 (step S 503 ).
  • the CPU 31 analyzes a content of the FAT stored in the main storage unit 32 and selects an empty cluster (step S 504 ).
  • the CPU 31 allocates a cluster number selected at step S 504 to a block to which the cluster number “1” is currently allocated and on the other hand, allocates a cluster number selected at step S 504 to a block in which FAT is currently stored. According to this change of the allocation, the content of the address conversion table is written (step S 505 ).
  • the CPU 31 erases information indicating an erasing object file specified at step S 501 from the content of the FAT and directory stored in the main storage unit 32 (step S 506 ). As a result, the FAT and directory are updated. Next, the CPU 31 instructs the memory control unit 2 to write the updated FAT and directory into a first empty block. As a result, the memory control unit 2 writes a single page of a head of the updated FAT into a page of a head of an empty block selected at step S 504 according to actions of steps S 201 to S 212 (step S 507 ).
  • the CPU 31 instructs to write in each time when the write-in operation of the memory control unit 2 is terminated until the updated FAT and directory are all written into the empty block selected at step S 504 .
  • the memory control unit 2 writes the FAT and directory successively in each of following pages according to actions of steps S 201 to S 212 each time when an instruction is received (step S 508 ).
  • the CPU 31 specifies a block corresponding to the number of a cluster stored at step S 503 referring to the address conversion table and instructs the memory control unit 2 to erase a storage content of that block.
  • data stored in that block or an erasing object file is erased by actions of steps S 301 to S 306 (step S 509 ).
  • the CPU 31 instructs the memory control unit 2 to erase a storage content of a block in which a FAT and directory before updating exist (step S 510 ). Consequently, the storage content of the block in which the directory and FAT before updating are stored is erased according to actions of steps S 301 to S 306 .
  • step S 502 may be omitted if the content of the FAT and directory has been read in the main storage unit 32 by a processing executed prior to the processing of steps S 501 to S 510 .
  • a processing for writing a file into the flash memory will be described with reference to a flow chart shown in FIG. 12.
  • the processing of this flow chart is executed by user's operating such an input device (not shown) as a keyboard connected to the computer 3 or necessity of a user program.
  • the CPU 31 specifies a file name of a file to be written, a head address and data amount (step S 601 ). Because the CPU 31 is operated according to the aforementioned format information, the data amount is integer times a block.
  • the CPU 31 specifies a block in which the FAT and directory exist by referring to the address conversion table, instructs the memory control unit 2 to read out that block on the first readout mode and then inputs the storage content of the FAT and directory (step S 602 ).
  • the CPU 31 specifies a block in which the FAT and directory exist by referring to the address conversion table, instructs the memory control unit 2 to read out that block on the first readout mode and then inputs the storage content of the FAT and directory (step S 602 ).
  • an empty cluster in the flash memory 1 is retrieved (step S 603 ).
  • step S 604 it is determined whether the number of empty clusters retrieved at step S 603 is sufficient for storing a file of data amount specified at step S 601 , and directory and FAT after updating which will be described later (step S 604 ). If it is determined that the number of empty clusters is not sufficient at step S 604 , the processing proceeds to that of step S 610 described later.
  • step S 604 If it is determined that the number of empty clusters is sufficient at step S 604 , a block necessary for storing a file of data amount specified at step S 601 is specified in order from a head of empty clusters retrieved at step S 603 .
  • the number of each block indicated by each specified cluster is specified by retrieving the address conversion table and a specified block number is temporarily stored in the main storage unit 32 (step S 605 ).
  • the CPU 31 instructs the memory control unit 2 to carry out write-in operation in order to write a file in a block specified at step S 605 .
  • the memory control unit 2 writes a single page of a head of a write-in object file into a page of a head of an empty block retrieved at step S 603 (step S 606 ).
  • the CPU 31 instructs the write-in operation each time when the write-in operation of the memory control unit 2 is terminated until the content of a write-in object file is written into an empty cluster retrieved at step S 603 .
  • the memory control unit 2 writes a content of a file successively in following pages according to actions of steps S 201 to S 212 each time when it receives an instruction (step S 607 ).
  • a size of a file to be produced by the CPU 31 is integer times the size of a block. Therefore, a write-in object file is divided equally and stored in a plurality of blocks.
  • step S 608 the CPU 31 updates the FAT and directory according to actions of steps S 504 to S 508 for erase processing.
  • step S 506 instead of erasing information indicating an erase object file from the FAT and directory stored in the main storage unit 32 , information indicating a written file is added. If updating of the FAT and directory is terminated, the processing of this flow chart is terminated.
  • step S 610 the CPU 31 recognizes that write-in of a file is impossible and terminates processing of this flow chart.
  • the CPU 31 specifies a file name of a read-out object file, reads out FAT information and directory information on the first read-out mode and specifies a page in which a file having an appropriate file name is stored according to read-out information.
  • the CPU 31 instructs to read out on the first read-out mode. As a result, the appropriate file is successively read out and supplied to the CPU- 31 .
  • the size and position of a block of the flash memory 1 are coincided with the size and position of a cluster which is a minimum unit of a file managed by the OS.
  • the structure of the flash memory 1 in the memory control system according to this embodiment is not restricted to the above described structure.
  • the entire memory capacity of the flash memory 1 does not have to be 8 M byte
  • the memory capacity of each memory cell does not have to be 1 byte
  • the memory capacity of a page does not have to be 528 bytes.
  • the number of pages of each block does not have to be 16.
  • the flash memory may be of NOR type.
  • the amount of data inputted or outputted once by the flash memory 1 does not have to be 1 byte, for example, may input or output more than 2 bytes all at once.
  • the format of the flash memory 1 is determined by accessing the boot region. However, it is permissible to make access to the boot region temporarily when the flash memory 1 is accessed, determine that it coincides with a format recognized by the control circuit 21 or CPU 31 and then make access to data.
  • the FAT and directory are allocated in the same cluster, it is permissible to allocate them separately. In this case, by making a cluster storing the FAT and directory correspond to “1”, “2” or other specified number cluster, the positions of the FAT and direction are determined.
  • the boot information and other information like FAT are written in separate blocks, it is permissible to write these information items in the same cluster (block). If such a format structure is applied, the boot information and the like are copied in other empty block accompanied with updating of the FAT. Therefore, the control circuit 21 and CPU 31 store a position of the boot region.
  • each cluster has eight pages (4 KB) for example, it is permissible to write the master boot record in page 1 of a sector, keep pages 2 to 4 as empty region, write a partition boot record in page 5, write FAT 1 and FAT 2 in pages 7 and 8 and write its directory in other cluster.
  • This configuration is effectively available when the FAT and directory size are small, for example, the entire memory capacity is about 1 MB.
  • each cluster has 16 pages (8 KB)
  • it is permissible to write the master boot record in page 1 of a sector keep pages 2 to 9 as empty region, write the partition boot record in page 10, write FAT 1 and FAT 2 in pages 11 to 16 and write its directory in other cluster.
  • it is permissible to write the master boot record in page 1 of a sector keep pages 2 and 3 as empty region, write the partition boot record in page 4, write FAT 1 and FAT 2 in pages 5 to 16 and write its directory in other cluster.
  • This configuration is effectively available when the sizes of the FAT and directory are relatively large, for example, when the memory capacity is 8 MB, 16 MB or equivalent.
  • the flash memory 1 does not have to be fixed in the memory control unit 2 but may be removably installed in the memory control unit 2 .
  • the memory control unit 2 carries out formatting of the flash memory 1 , erasing of a file, write-in of a file and the like corresponding to a command from the CPU 31 , in the second embodiment, the CPU 31 itself is capable of carrying out the operation of the memory control unit 2 .
  • the address register 12 , column decoder 13 , low address decoder 14 , voltage converter 15 and high voltage generator 15 of the flash memory 1 are connected to the IOC 33 .
  • the CPU 31 itself carries out the operation executed by the memory control unit 2 .
  • the CPU 31 updates the block address and simultaneously instructs the low address decoder 14 , voltage converter 15 and high voltage generator 16 to start the processing for erasing data through the IOC 33 (FIG. 10, step S 401 ). Further, it outputs a write-in object master boot record and partition boot record and instructs the column decoder 13 , low address decoder 14 , voltage converter 15 and high voltage generator 16 to start the processing for writing these data (steps S 402 , 403 ). Then, the address conversion table on the main storage unit 32 is produced (step S 404 ).
  • the CPU 31 makes access to a head block of the flash memory 1 upon power on, so as to read out boot information, determines a cluster structure (size and position) and controls following access to the flash memory 1 according to this.
  • the CPU 31 itself reads out the FAT and directory according to a pointer value (FIG. 11, steps S 501 , S 502 ) and determines a cluster in which a file to be erased is stored (step S 503 ).
  • the FAT and directory are updated (steps S 504 to S 508 ) and a block corresponding to that cluster is erased (step S 509 ).
  • the CPU 31 erases a block in which FAT and the like before updating are stored (step S 510 ) and terminates the processing.
  • the CPU 31 determines an empty cluster according to the FAT and controls the column decoder 13 , low address decoder 14 , voltage converter 15 and high voltage generator 16 so as to store data successively in the memory cell array 11 . If file write-in is completed, the FAT and directory are updated.
  • the size of a file generated by the CPU 31 is integer times the block size. Therefore, the file is stored exactly in one or a plurality of blocks. Because the sizes of the FAT and directory are set to the same size as a single block, the FAT and directory are stored exactly in a block. Therefore, it is possible to prevent a small amount of data which is a part of a file or directory from being stored in a part of the block by a single write-in processing so that the file can be erased in units of one block at the aforementioned erasing time.
  • CPU 31 By CPU 31 's controlling the formatting, file erasing and file updating, it is possible to access the flash memory 1 without using any control circuit.
  • the flash memory 1 is formatted so that a single cluster coincides with a single block
  • the flash memory 1 is formatted so that a single cluster corresponds to a plurality of blocks as shown in FIG. 14.
  • the block 1 of the flash memory is boot region, in which the master boot record and partition boot record are stored.
  • the cluster of the flash memory 1 is specified by data stored in the master boot record and partition boot record in the boot region.
  • the blocks 2 to 4 of the flash memory 1 correspond to the cluster 1 .
  • the blocks 5 to 7 correspond to the cluster 2 .
  • the blocks 8 to 10 correspond to the cluster 3 .
  • the blocks 1022 to 1024 correspond to the cluster 343 .
  • the memory control system according to this embodiment and processing thereof are the same as the first and second-embodiments. However, when data of a cluster will be erased, this memory control system erases each data of three blocks corresponding to data erasing object cluster. Therefore, the processing of steps S 301 to S 307 is repeated three times.
  • FIG. 14 shows an example in which a cluster corresponds to three blocks, a cluster may correspond to any integer more than 2 blocks.
  • the fourth embodiment when the flash memory 1 is formatted, the storage content of all the blocks of the flash memory 1 is erased and then the master boot record and partition boot record are written into the block 1 .
  • the fourth embodiment has proposed a method in which if the boot information is the same between before and after the formatting, the flash memory 1 is formatted without erasing the boot information.
  • the memory control system configuration is the same as the case of FIG. 1. Further, processing of the flash memory 1 other than formatting is the same as the first embodiment.
  • FIG. 15 is a flow chart showing a processing for formatting the flash memory 1 according to this embodiment.
  • the processing of this flow chart is started by inputting a predetermined command to the I/O control circuit 22 from the CPU 31 through the system bus 34 , IOC 33 and I/O bus 4 by user's operating an input device such as a key board (not shown) connected to the computer 3 like the processing of the flow chart shown in FIG. 10.
  • the CPU 31 reads out a master boot record and partition boot record stored in the boot region of the flash memory 1 like the processing for power on in the first embodiment and temporarily stores them in the main storage unit 32 (step S 701 ).
  • the CPU 31 reads out the master boot record and partition boot record stored in the main storage unit 32 through the system bus 34 , IOC 33 , I/O bus 4 and I/O control circuit 22 . Then, it is determined whether the readout master boot record and partition boot record coincide with the master boot record and partition boot record temporarily stored at step S 701 (step S 702 ).
  • step S 702 If it is determined that they coincide at step S 702 , the processing of steps S 301 to S 307 are carried out for blocks other than the block 1 of the flash memory 1 . As a result, data stored in the memory cell of blocks other than the block 1 (boot region) of the flash memory 1 is erased (step S 703 ). The processing of this flow chart is terminated. As a result, the flash memory 1 is formatted as shown in FIG. 4.
  • step S 702 the control circuit 21 carries out the processing of steps S 401 to S 404 shown in FIG. 10 so as to format the flash memory 1 (step S 704 ), so that the processing of this flow chart is terminated.
  • the flash memory 1 can be formatted more quickly than the memory control system according to the first embodiment.
  • the structure of the memory control system and the format structure of the flash memory 1 are the same as the first embodiment.
  • the number of a cluster in which the FAT and directory data are to be written is not specified and instead, a particular number is allocated to a cluster belonging to a particular cluster group which will be described later.
  • the CPU 31 determines a cluster in which the FAT and directory data are written according to an identification flag which will be described later.
  • FIG. 16 is a diagram showing particular cluster groups for storing data of the FAT and directory according to this embodiment.
  • the particular cluster group includes two groups, cluster group 1 and cluster group 2 , in any one of which the FAT and directory are to be written.
  • the structures of the directory and FAT are substantially the same as the first and second embodiments.
  • an identification flag employing the value “FFh” which cannot be used by ordinary data is written at a head of a cluster group in which the FAT and directory are written.
  • the cluster group in which the FAT and directory are not written is an empty block.
  • each identification code (not shown) is attached to the head of the FAT region and directory region.
  • the control circuit 21 carries out the same processing as steps S 401 to S 403 of FIG. 5 (step S 801 ).
  • the CPU 31 writes FFh data into a head page of a cluster group for storing initially set FAT and directory according to the processing of steps S 201 to S 212 and then terminates the processing of this flow chart (step S 802 ).
  • the flash memory 1 is formatted.
  • a processing for erasing a file written in the flash memory 1 executed by the control circuit 21 according to this embodiment will be described with reference to a flow chart shown in FIG. 19.
  • the processing of this flow chart is started by inputting a predetermined command to the I/O control circuit 22 from the CPU 31 through the system bus 34 , IOC 33 and I/O bus 4 by user's operating such an input device (not shown) as a key board connected to the computer 3 .
  • control circuit 21 carries out the processing of steps S 501 to S 506 (step S 901 ).
  • the CPU 31 writes a content of the updated FAT and directory successively in each page following a head page of a cluster group in which the identification flat is not FFh, according to actions of the steps S 201 to S 212 (step S 902 ).
  • the CPU 31 erases the content of the cluster group in which the directory and FAT before updating are stored according to processing of steps S 301 to S 306 (step S 903 ) and terminates the processing of this flow chart.
  • the control circuit 21 carries out the processing of steps S 601 to S 607 shown in FIG. 11 (however, if it is determined that the number of empty clusters is insufficient at a processing of step S 604 , further processing of S 610 ) (step S 1001 ).
  • the CPU 31 carries out the processing of steps S 902 to S 903 (step S 1002 ).
  • the updated FAT and directory information indicating an erasing object file has been deleted, but information of a newly written file has been added. Then, the processing of the flow chart is terminated.
  • the FAT and directory data can be read out even if the memory position of the FAT and directory data are not rewritten each time when file erasing or rewrite is performed.
  • the number of clusters for constructing the cluster group is not restricted to 2 but the cluster group can be constructed by any number of clusters more than 1.
  • particular two cluster groups for storing the FAT and directory data do not always have to be provided in a first region of the flash memory 1 but may be provided at any position.
  • a program (a driver for formatting) for carrying out a processing for formatting the flash memory 1 , executed by the CPU 31 or the like may be provided by such a recording medium as a floppy disk and CR-ROM.
  • the block erasing type memory device can be formatted so that data erasing and write-in can be carried out rapidly by executing a program stored in the program memory medium according to this embodiment. Further, by carrying out a program stored in the program memory medium of this embodiment, data erasing and write-in can be carried out rapidly.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Read Only Memory (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Memory System (AREA)

Abstract

A data processing system is provided with a flash memory including a plurality of blocks and capable of erasing stored data collectively in units of block and a memory control unit for accessing the flash memory, the memory control unit having a control circuit for formatting the flash memory according to a format information for substantially coinciding each cluster serving as a logical unit of memory region of the flash memory with integer ones of the blocks and a control circuit for determining a size and position of each cluster and carrying out access control for erasing, write-in and reading of data of the flash memory according to the size and position of the determined cluster.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This is a continuation of Application No. PCT/JP98/02862, filed Jun. 25, 1998. [0001]
  • BACKGROUND OF THE INVENTION
  • This invention relates to data processing system using block erasing type memory device, block erasing type memory device and computer readable program memory medium storing program for formatting, data erasing and date write for block erasing type memory device. [0002]
  • Recently, a flash memory has been used as a portable nonvolatile memory medium instead of a floppy disk, particularly as a memory medium for a mobile information terminal. The flash memory mentioned herein refers to a nonvolatile block erasing type memory device comprising a plurality of blocks, in which data stored internally can be electrically erased by each block. [0003]
  • When the flash memory is used under a control of such a disk operating system as MS-DOS (Microsoft's trademark), it is formatted according to the same format as that used conventionally for the floppy disk so as to handle it in the same way as the floppy disk. According to this format, a memory area is divided to boot area, FAT (file allocation table) area, directory area and data area. The data area is logically divided to clusters according to a definition stored in the boot area and a file to be stored in the flash memory is memorized in units of one cluster. [0004]
  • However, in the format of the conventional flash memory, the position of the cluster does not coincide with that of a block. [0005]
  • Therefore, if it is intended to update data (file) stored in a cluster, data (file) not necessary to update is also erased in units of a block altogether. Thus, the data not necessary to update must be saved in other cluster. [0006]
  • The same problem occurs when data (file) is written into a flash memory. [0007]
  • Further, if erasing or write-in of data is executed, FAT or directory must be rewritten, so that correspondingly the data not necessary to erase must be saved in other block. [0008]
  • Therefore, in order to update a single file in a conventional block erasing type memory device, plural blocks must be updated even if it is data within one block. For the reason, data write processing is divided to two parts so that it takes a long time, thereby often leading to deceleration of the entire memory device operation. [0009]
  • The same problem occurs when data (file) is written into the flash memory. [0010]
  • Further, if erasing or write-in of data is executed, FAT or directory must be rewritten, so that correspondingly the data not necessary to erase must be saved in other block. [0011]
  • This problem becomes more conceivable when data processing unit such as CPU controls the block erasing type memory device through a direct access thereto without using a special controller for reduction of the size and power consumption of the memory device. [0012]
  • BRIEF SUMMARY OF THE INVENTION
  • An object of the present invention is to accelerate data access, particularly processing including data erasing in the block erasing type memory device. [0013]
  • Another object of the invention is to provide a block erasing type memory device having a format structure capable of achieving data write-in processing rapidly and making the best use of the storage capacity, data processing system using the same memory medium and a program memory medium storing a program for formatting of the block erasing type memory device, data erasing and data write-in. [0014]
  • According to a first aspect of the present invention, there is provided data processing system comprising a block erasing type memory device including a plurality of blocks, capable of erasing stored data collectively in units of one block and data processing means for accessing the block erasing type memory device, wherein the data processing means includes a formatting portion connected to the block erasing type memory device for formatting the block erasing type memory device according to formatting information for substantially coinciding the size and position of a cluster as a logical unit of a memory region of the block erasing type memory device with those of integer ones of the blocks, and an access control portion for determining the size and position of the cluster according to the format information and carrying out access control for data erasing, data write-in and data read-out for the block erasing type memory device according to the determined size and position of the cluster. [0015]
  • In this data processing system, a cluster includes integer ones of the blocks. Thus, data erasing and write-in processing can be carried out in units of one block. Thus, the necessity of saving other data for data write-in or erasing is eliminated, so that the data erasing and write-in processing can be carried out rapidly. [0016]
  • According to a second aspect of the present invention, there is provided a block erasing type memory device having a format information memory region for storing format information for making integer ones substantially correspond to a cluster serving as a unit of data memory region and capable of erasing stored data collectively in units of one block. [0017]
  • In this block erasing type memory device, the cluster includes integer ones. Thus, data erasing and write-in processing can be carried out in units of one block. Thus, the necessity of saving other data for data write-in is eliminated, so that the data erasing and write-in processing can be carried out rapidly. [0018]
  • Although ordinarily, the cluster has a single block, it may be formed of a plurality of the blocks. [0019]
  • The format information comprises information for corresponding the size of the cluster with the size of the block and a position adjusting region for coinciding a start position and end position of each of the clusters with the start position and end position of the block, for example, an empty region. [0020]
  • The block erasing type memory device may store directory information indicating a file name and head memory position and a file allocation table indicating a file position in a single cluster. [0021]
  • When data is stored in a memory medium, ordinarily it is necessary to memorize position information (e.g., file allocation table) indicating which position each data is stored and identification name (e.g., file name and directory) of each data. This position information and identification name must be updated each time when data write-in or erasing is carried out. In the above block erasing type memory device, the position information and identification name are stored in a single cluster or a single block. Therefore, the necessity of saving other data for updating these data is eliminated. Thus, the data write-in or erase processing can be carried out rapidly. [0022]
  • It is preferred that stored data of blocks other than the aforementioned block including the block for storing the format information is physically erased. [0023]
  • In general memory medium, it is possible to consider that data has been erased by replacing a particular portion of the data (e.g., head one character) with a specific code, without physically erasing data stored in the data region (e.g., erasing by writing data corresponding to “1”). [0024]
  • However, in the block erasing type memory device like the flash memory, by such data erasing method, new data cannot be written over the erased data, so that the processing for saving the original data and erasing its appropriate area is required. [0025]
  • Because according to the present invention, in other regions than such particular regions as boot region and FAT region and the like, data has been erased, saving of data and erasing upon write-in processing become unnecessary, so that the write-in processing can be accelerated. [0026]
  • According to a third aspect of the present invention, there is provided data processing system comprising a connecting portion containing a plurality of blocks and so constructed to be connectable to a block erasing type memory device capable of erasing collectively stored data in units of one block and a formatting portion for formatting the block erasing type memory device by writing format information for substantially coinciding integer ones of the blocks, for example, one block with a cluster into the block erasing type memory device through the connecting portion. [0027]
  • According to this system, the cluster includes integer ones of the blocks. Thus, the data erasing and write-in processings can be carried out in units of one block. Therefore, the necessity of saving other data for data write-in processing is eliminated, so that the data erasing and write-in processing can be accelerated. [0028]
  • To correspond the cluster with the block, it is permissible to write information for corresponding the size of the cluster with the size of the block and position adjusting information for coinciding the start position and end position of each cluster with the start position and end position of each block into the block erasing type memory device. [0029]
  • The aforementioned data processing system may further comprise a section for recording directory information indicating a file name and head memory position and a file allocation table indicating a file positioning a cluster. [0030]
  • These information items are updated each time when data write-in or erase processing is carried out. Because in such a system, these information items are stored in a single block, the necessity of saving other data for updating these data is eliminated. Thus, the data write-in or erase processing can be accelerated. [0031]
  • The aforementioned formatting portion may include an erasing portion for physically erasing stored data of blocks other than a block in which the format information is written. [0032]
  • In general memory medium, it is possible to assume that data has been erased by replacing a particular portion of data with a particular code, without physically erasing data. [0033]
  • However, in the block erasing type memory device, according to such data erasing method, a processing for erasing the original data or the like is needed at the time of data write-in processing, so that the processing takes long time. Because according to the present invention, data in the data region is physically erased upon formatting, the write-in processing can be accelerated. [0034]
  • In erasing a file written in the block erasing type memory device also, it is preferable that data of a block including that appropriate data is physically erased. [0035]
  • The aforementioned data processing system further comprises a format information readout portion for reading out the format information through the connecting portion, a cluster determining portion for determining a size and position of a cluster serving as a minimum unit of a file according to format information read out by the format information readout portion and a control portion for controlling erasing, write-in and readout of data of the block erasing type memory device according to the size and position of a cluster determined by the cluster determining means. [0036]
  • With such components, the data erasing, write-in processing and the like can be accelerated. [0037]
  • A program for making the computer to execute the above described data processing system and function may be stored in a memory medium and distributed, and installed in the computer so as to carry out the above described operation on the computer. [0038]
  • 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 hereinafter. [0039]
  • BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING
  • 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. [0040]
  • FIG. 1 is a block diagram showing a structure of a memory control system of a flash memory according to a first embodiment of the present invention; [0041]
  • FIG. 2 is a schematic diagram showing a structure of the flash memory; [0042]
  • FIG. 3 is a diagram showing a structure of a memory cell array; [0043]
  • FIG. 4 is a diagram showing a relation between a block and cluster in the format of the flash memory according to the first embodiment of the present invention; [0044]
  • FIG. 5 is a diagram showing a correspondence among directory, file allocation table and cluster in the first embodiment of the present invention; [0045]
  • FIG. 6 is a diagram showing an example of a structure of an address conversion table; [0046]
  • FIG. 7 is a flow chart showing data read-out operation of the first embodiment of the present invention; [0047]
  • FIG. 8 is a flow chart showing data write-in operation of the first embodiment of the present invention; [0048]
  • FIG. 9 is a flow chart showing data erasing operation of the first embodiment of the present invention; [0049]
  • FIG. 10 is a flow chart showing formatting processing of the flash memory according to the first embodiment of the present invention; [0050]
  • FIG. 11 is a flow chart showing file erasing in the flash memory according to the first embodiment of the present invention; [0051]
  • FIG. 12 is a flow chart showing a processing for writing a file into the flash memory according to the first embodiment of the present invention; [0052]
  • FIG. 13 is a block diagram showing a structure of a memory device according to a second embodiment of the present invention; [0053]
  • FIG. 14 is a formatting diagram of the flash memory according to a third embodiment of the present invention; [0054]
  • FIG. 15 is a flow chart showing a processing of formatting the flash memory according to the fourth embodiment of the present invention; [0055]
  • FIG. 16 is a diagram showing a particular cluster group for storing data of a file allocation table and directory according to a fifth embodiment of the present invention; [0056]
  • FIG. 17 is a diagram showing particular two cluster groups according to the fifth embodiment of the present invention; [0057]
  • FIG. 18 is a flow chart of a processing for formatting the flash memory according to the fifth embodiment of the present invention; [0058]
  • FIG. 19 is a flow chart showing a processing of erasing a file in the flash memory according to the fifth embodiment of the present invention; and [0059]
  • FIG. 20 is a flow chart showing a processing of writing a file into the flash memory according to the fifth embodiment of the present invention. [0060]
  • DETAILED DESCRIPTION OF THE INVENTION
  • Hereinafter, the embodiment of the present invention will be described with reference to the accompanying drawings. [0061]
  • FIG. 1 is a block diagram showing a structure of a memory control system of a flash memory according to a first embodiment of the present invention. [0062]
  • As shown here, this memory control system comprises a [0063] flash memory 1, a memory control unit (memory controller) 2, a computer 3 and I/O bus 4. The memory control unit 2 is connected to the computer 3 through the I/O bus 4 such as SCSI bus and is removable from the computer 3.
  • The [0064] flash memory 1 is a block erasing type memory device containing a memory cell array 11, an address register 12, a column decoder 13, a low address decoder 14, a voltage converting circuit (voltage converter) 15 and a high voltage generating circuit (high voltage generator) 16.
  • The [0065] memory cell array 11 is constituted of a plurality of memory regions each having a memory capacity of 1 byte. These memory regions are arranged in matrix of 16384 rows×528 columns, and therefore the entire memory cell array has a memory capacity of about 8.65 M byte.
  • Each row of the [0066] memory cell array 11 forms a page having a memory capacity of 528 byte as shown in FIG. 2. Respective memory regions contained in each page are supplied with a column address continuously from 1 to 528.
  • Each unit of 16 pages from beginning forms a single block. Each block has a memory capacity of about 8.03 K byte and the entire memory area includes 1024 blocks. Each block is supplied with a block address continuously from 1 to 1024. [0067]
  • Every 16 memory regions belonging to the same block contains memory cells arranged in matrix of 16 rows×8 columns as shown in FIG. 3. These memory cells are of NAND type, formed on a common substrate. [0068]
  • The current path of the memory cell of each column is connected in cascade and the gate of each row is connected to a common row control input terminal (Trcnt). Each row control input terminal Trcnt is connected to a gate of each memory cell belonging to other column of the same page. [0069]
  • A source of FETs (field effect transistors) [0070] 1-1 to 1-8 is connected to an end of each current path connected in cascade. A drain of each of FETs 1-1 to 1-8 is connected to data I/O terminal Tdata corresponding to each column and a gate thereof is connected to the common row control input terminal Tccntl.
  • A drain of each of column selection FETs [0071] 2-1 to 2-8 is connected to the other end of each current path a source of each of the FETs 2-1 to 2-8 is connected to a substrate. A gate of each of the FETs 2-1 to 2-8 is connected to a common column control input terminal (Tccnt2).
  • The column control input terminals Tccnt[0072] 1 and Tccnt2 are connected to the gates of the row selection FETs 1-1 to 1-8 and FETs 2-1 to 2-8 connected to respective memory cells belonging to the same row of the flash memory array 11.
  • Each memory cell carries out write-in of data on the data I/O terminal Tdata, reading to the data I/O terminal Tdata and erasing of the memory according to a voltage applied to the row control input terminal Trcnt, column control input terminal Tccnt[0073] 1, Tccnt2 and substrate. As described later, in the memory cell array 11 generally, data write is carried out in units of one page, data read is carried out in units of one byte and data erasing is carried out in units of one block.
  • Because each memory cell is of NAND type, data recording cannot be carried out but in a direction from “1” to “0” in a recorded value. A bit in which a recorded value of the memory cell is “0” keeps a state of “0” until the recording content is reset (erasing in units of one block). [0074]
  • The [0075] address register 12 is connected to the column decoder 13, low address decoder 14 and memory control unit 2.
  • The [0076] address register 12 receives 3-byte information indicating column address and page address of the memory cell array 11 from the memory control unit 2 by each byte and stores it. Of the stored information, column address information is outputted to the column decoder 13 and page address information is outputted to the low address decoder 14.
  • Column address information is inputted from the [0077] address register 12 to the column decoder 13. According to inputted column address information and an instruction of the control circuit (controller) 21, write-in voltage, erasing voltage, readout voltage or readout inhibiting voltage generated by a high voltage generator 16 is applied to each row control input terminal Trcnt.
  • Page address information is inputted from the [0078] address register 12 to the low address decoder 14. According to that information and an instruction of the control circuit 21, forward bias voltage or reverse bias voltage generated by the high voltage generator 16 is applied to respective column control input terminals Tccnt1, Tccnt2.
  • The [0079] voltage converter 15 receives data to be written into the memory cell array from data register 24 and a voltage indicating each bit of that data is converted to a predetermined write-in voltage. Then, this write-in voltage is applied to the data I/O terminal Tdata according to an instruction of the control circuit 21. When data is read from the memory cell array 11, the voltage converter 15 fetches a voltage indicating a content of each memory cell from the data I/O terminal Tdata, amplifies that voltage and then stores it in the data register 24.
  • According to an instruction of the [0080] control circuit 21, the high voltage generator 16 generates a write-in voltage to be applied to each row control input terminal Trcnt, write inhibiting voltage to be applied to each data I/O terminal Tdata, erasing voltage to be applied to the substrate and forward bias voltage and reverse bias voltage to be applied to the column control input terminals Tccnt1, Tccnt2 of each column. A generated voltage is supplied to a substrate of the memory cell array 11, column decoder 13 and low address decoder 14.
  • The memory control unit (memory controller) [0081] 2 shown in FIG. 1 comprises the control circuit 21, I/O control circuit 22, operating logic control circuit 23, command register 24 and data register 25. The memory control unit 2 transfers data between the flash memory 1 and a main storage unit 32.
  • The [0082] control circuit 21 controls the column decoder 13, low address decoder 14, voltage converter 15 and high voltage generator 16 as described later, according to a command stored in a command register 24 and an instruction of the operating logic control circuit 23.
  • The I/[0083] O control circuit 22 is connected to the data bus of the flash memory 1, I/O bus 4, operating logic control circuit 23, command register 24, address register 12 and status register 28.
  • The I/[0084] O control circuit 22 fetches in data from the data register 25 and I/O bus 4 according to an instruction of the operating logic control circuit 23 and outputs data to the address register 12, command register 24, data register 25 and I/O bus 4.
  • The operating [0085] logic control circuit 23 is connected to a CPU 31 which will be described later, I/O control circuit 22 and control circuit 21.
  • The operating [0086] logic control circuit 23 receives a command latch signal, address latch signal, write-in signal and read-out signal from the CPU 31 and according to these signals, controls the control circuit 21 and I/O control circuit 22 as will be described later.
  • The command register [0087] 22 stores command information received from the I/O control circuit 22 and outputs to the control circuit 21.
  • The data register [0088] 25 has a memory capacity of 528 bytes and stores data of a write-in object received from the I/O control circuit 22 and outputs to the voltage converter 15. Further, it fetches data outputted from the voltage converter 15 as a result of read-out from the memory cell array 11 and outputs to the I/O control circuit 22.
  • The [0089] computer 3 comprises a CPU (central processing unit) 31, main storage unit 32 and IOC (I/O control unit) 33, each connected through a system bus 34 made of VME bus. The computer 3 is connected to the I/O bus 4 through an IOC 33.
  • The [0090] CPU 31 executes a program stored in the main storage unit 32. The CPU 31 outputs a command for executing a program shown in a flow chart described later corresponding to an operation of an input device (not shown) like a key board, connected to the computer 3 through the I/O bus 4. It outputs a command for executing a program shown in a flow chart described later.
  • The [0091] main storage unit 32 stores a file to be stored in the flash memory and a file to be read from the flash memory 1 as well as processing program of the CPU 31.
  • The [0092] main storage unit 32 stores master boot record to be recorded in boot region when the flash memory 1 is formatted, partition record and an address conversion table which will be described later.
  • The [0093] IOC 33 is an I/O controller for controlling an output of data from the CPU 31 or main storage unit 32 of the computer 3 to the I/O bus 4 and input of the opposite direction processing. Logical structure of memory region of the memory cell array 11
  • The [0094] memory cell array 11 is formatted according to an operating system (OS) used by the computer 3, for example, MS-DOS (Microsoft's trade name) and particularly formatted in such a manner that a block of a physical structure of the memory cell array 11 coincides with a cluster of a logical unit of a file managed by OS.
  • Each cluster is supplied with a number beginning with “1” and this number does not always agree with an order of the block from a head address of the [0095] memory cell array 11.
  • In the initial state in which the [0096] memory cell array 11 is formatted, as shown in FIG. 4, the memory region of the memory cell array 11 is divided to master boot memory region (master boot memory region), empty region (empty region), partition boot memory region (partition boot memory region), FAT (file allocation table), directory region and file region.
  • Of these regions, the master boot memory region, empty region, and partition boot memory region are allocated at a head block of the [0097] memory cell array 11.
  • The master boot memory region includes a first page (first sector) of a head and a region for recording information about processing of startup and information of each partition provided on this memory (each virtual memory in a case when this memory is divided to one or more virtual memories). [0098]
  • Information about each partition includes information, for example, of whether or not each partition is to be started and further includes following information. [0099]
  • (1) Position of a beginning page of each partition [0100]
  • (2) Position of an end page of each partition [0101]
  • (3) Total pages included in each partition [0102]
  • The empty region has [0103] 14 pages following the master boot memory region. The empty region is provided for coinciding a head and end of the block which is a physical unit with those of a cluster which is a logical unit managed by the OS when the memory region is divided to a plurality of clusters.
  • The partition boot memory region has a page following the empty region. The partition boot memory region stores information about a structure of each partition and information about processing for startup. The information about the structure of each partition has a following content. [0104]
  • (4) Memory capacity of a page contained in each partition [0105]
  • (5) Number of pages for consisting a single cluster [0106]
  • (6) Maximum number of directories which each partition is capable of containing [0107]
  • (7) Number of pages occupied by FAT [0108]
  • (8) Number of FATs [0109]
  • The cluster is a unit of memory consisting of a specified number of pages which are defined in the partition boot memory region and a minimum unit of memory in which a content of a file managed by the OS is recorded. Therefore, different file contents are never contained in a cluster. [0110]
  • According to this embodiment, it is defined that each cluster has 16 pages so as to coincide the sizes of the block and cluster with each other. [0111]
  • The [0112] blocks 2 to 1024 form data region for storing arbitrary data, file and the like.
  • FAT and directory are stored in any of the data regions ([0113] block 2 in the initial condition). The FAT is stored in head three pages of 16 pages in a block and the directory is stored in the remaining 13 pages.
  • The FAT is a table indicating an allocation of the file. The directory includes information about a name of a stored file and a number of a cluster in which a head of the file is stored, and the like. [0114]
  • To coincide the size and position of the block which is a physical unit of the [0115] memory cell 11 with those of the cluster managed by the operating system (OS) of the computer 3, concretely, for example, following values are stored in the master boot memory region and partition boot region.
  • (1) Position of a beginning page of each partition=1 [0116]
  • (2) Position of an end page of each partition=16384 [0117]
  • (3) Total number of pages contained in each partition=1 [0118]
  • (4) Memory capacity of a page contained in each partition=512 bytes [0119]
  • (5) Number of pages composing a cluster=16 [0120]
  • (6) Maximum number of directories which each partition is capable of containing=256 [0121]
  • (7) Number of pages occupied by FAT=3 [0122]
  • (8) Number of FATs=1 [0123]
  • FIG. 5 is a diagram showing a relation between FAT, directory and cluster. [0124]
  • As shown in the same Figure, the number of a cluster in which the FAT and directory are stored is indicated by a pointer in a memory portion [0125] 21 a of the control circuit 21.
  • The directory points out a file name of a file stored in the [0126] memory cell array 11 and a cluster in which a head portion of that file is stored with a pointer.
  • When a file cannot be contained in a file, the FAT points out a cluster for storing the following portion. A cluster in which the final portion of the file is stored is indicated by an end cord (EC). [0127]
  • Address conversion table [0128]
  • The address conversion table is a table for storing information indicating the number of a cluster allocated for each block. As described previously, the address conversion table is stored in the [0129] main storage unit 32 of the computer 3 and accessed by the CPU 31 and updated.
  • FIG. 6 shows an example of a structure of the address conversion table. The address conversion table comprises a plurality of records. A cluster number beginning with “1” is stored at the head of each record and a block number corresponding to that number is stored. [0130]
  • The number “1” is always allocated to a block in which the FAT is stored as a cluster No. The number “I” of the cluster is updated by a processing described later so as to indicate a block in which the FAT is to be newly stored. [0131]
  • Basic operation of the flash memory and memory control unit [0132]
  • Next, the basic operation for data readout, write-in and erasing with the [0133] flash memory 1 and memory control unit 2 will be described with reference to a flow chart of FIGS. 7 to 9.
  • Readout [0134]
  • Following three types of readout mode are available. In the first readout mode shown in FIG. 7, the command latch signal is on active level and it is started if a write-in signal is inputted to the operating [0135] logic control circuit 23 with command “00H” indicating a first readout mode being inputted to the I/O control circuit 22 through the I/O bus 4 (step 101, a numerical value having “H” at its end expresses hexadecimal number).
  • If the write-in signal is inputted, the operating [0136] logic control circuit 23 instructs the I/O control circuit 22 to input a command (step S102) and the I/O control circuit 22 receiving the instruction stores command “00H” in the command register 24 (step S103).
  • If the [0137] control circuit 21 reads a content of the command register 24 (step S104), the control circuit 21 detects a start of the first readout mode.
  • Next, the command latch signal is released and instead, the address latch signal is made to active level. A signal indicating a column address is inputted to the I/[0138] O bus 4. If the write-in signal is inputted again in this condition (step S105), the operating logic control circuit 23 instructs the I/O control circuit 22 to input an address (step S106). The I/O control circuit 22 receiving such an instruction stores a column address in the address register 12 (step S107).
  • Next, a low order page address signal specifying [0139] low order 8 bits of the page address is inputted to the I/O bus 4 in the condition that the address latch signal is kept in active level (step S108). If the write-in signal is inputted again in this condition, the operating logic control circuit 23 instructs the I/O control circuit 22 to input an address. The I/O control circuit 22 receiving such an instruction stores a low order page address in the address register 12 (step S109).
  • Next by the same processing as steps S[0140] 108 to S109, a high order page address specifying a high order 5 bits of the page address is stored in the address register 12 (step S110).
  • The address register in which the column address and page address information items are inputted through above three times inputs the column address to the [0141] column decoder 13 and then block address and page address to the low address decoder 14 (step S111). As a result, the column decoder 13 and low address decoder 14 specify a memory region at the head of an readout object.
  • If the readout object is specified, the address latch signal is released and the readout signal is inputted (step S[0142] 112). The operating logic control circuit 23 in which the readout signal is inputted instructs the control circuit 21 to start a start of data readout control (step S113).
  • The control circuit receiving such an instruction instructs the [0143] column decoder 13, low address decoder 14 and high voltage generator 16 to start an operation for reading data (step S114).
  • The [0144] column decoder 13 receiving such an instruction applies a sufficiently deep forward bias to the column control input terminals Tccnt1, Tccnt2. In this condition, the low address decoder 14 applies a predetermined readout voltage to the column control input terminal Tccnt connected to a gate of each memory cell forming a memory region of a readout object and a predetermined read-out inhibiting voltage to the other row control input terminal Tccnt (step S115).
  • Consequently, data of 1 byte stored in the memory region of the readout object is outputted to each data I/O terminal Tdata. That data is outputted to the I/[0145] O bus 4 through the data register 25 and I/O control circuit 22 after its voltage value is converted by the voltage converter 15 (step S116).
  • Each time when the readout signal is inputted to the operating logic control circuit, the storage content in following memory regions is outputted successively by each byte to the I/O bus through the same processing as steps S[0146] 112 to S116 (step S117).
  • The second readout mode is started by the write-in signal when the command “01H” indicating the second readout mode is inputted in the I/[0147] O control circuit 22 by the I/O bus 4 at the aforementioned step S101.
  • The second readout operation is different from the first readout mode in that a head position read out is an [0148] address 256 ahead of a position indicated by the column address or page address inputted through the I/O bus 4. The other operation is the same as the first readout mode.
  • The third readout mode is started by the write-in signal when the command “50H” indicating the second readout mode is inputted to the I/[0149] O control circuit 22 by the I/O bus 4 at the aforementioned step S101.
  • In the second readout mode operation, a head position read out is an [0150] address 512 ahead of a position indicated by the low order 4 bits of the column address and page address inputted from the I/O bus 4. Further, after data of the memory cell of a final column of each page is read, if a readout signal is further inputted, readout from a 513th memory cell of a next page is carried out. Memory cells following 513th one of each page are objects of readout. The other operation is the same as the first readout mode.
  • Write-in [0151]
  • An operation for data write-in shown in FIG. 8 is carried out as described below, when an address of a write-in object page is specified, data of a page is written into the data register [0152] 25 and then data in the data register is written successively into a specified page.
  • The write-in processing is started when a write-in signal is inputted to the operating [0153] logic control circuit 23 in the condition that the command “80H” indicating data output to the data register is inputted to the I/O control circuit 22 while the command latch signal is active level (step S201).
  • After the processing is started, the [0154] column decoder 13 and low address decoder 14 specify a column address and a page address indicating a position of head of a write-in object page in the same processing as steps S102 to S111 in data read-in processing (step S202).
  • If the address latch signal is released after the processing of the step S[0155] 202 is terminated and then a write-in signal is inputted to the operating logic control circuit 23, the operating logic control circuit 23 instructs the I/O control circuit 22 to input data (step S203).
  • The I/[0156] O control circuit 22 in which such an instruction is inputted stores data outputted to the I/O bus 4 at an address of a head of the data register 25 (step S204).
  • The [0157] control circuit 21, I/O control circuit 22 and operating logic control circuit 23 carry out the same processing as steps S203 to S204 and stores write-in data at a following address of the data register 25 (step S205). Total amount of data to be written in must be within a single page, namely less than 528 bytes.
  • If all write-in object data are stored in the data register [0158] 25, the command latch signal is made to active level and the command “10H” instructing to write the storage content of the data register 25 into a write-in object page is inputted to the I/O bus 4 (step S206).
  • If the write-in signal is inputted to the operating [0159] logic control circuit 23 under this condition, the operating logic control circuit 23 instructs the control circuit 21 to start data write-in control (step S207).
  • A control circuit [0160] 221 receiving such an instruction instructs the column decoder 13, low address decoder 14, voltage converter 15, high voltage generator 16 and data register 25 to start data write-in operation (step S208).
  • The [0161] high voltage generator 16 receiving such an instruction generates a write-in voltage and supplies it to the low address decoder 14 and then generates a write-in inhibiting voltage and supplies it to the voltage converter 15 (step S209).
  • The [0162] voltage converter 15 reads 1 byte data stored at a head address of the low address decoder 14. The write-in inhibiting voltage inputted from the high voltage generator 16 is applied to the data I/O terminal Tdata corresponding to a bit the logical value of which is “1” and on the other hand, ground voltage is applied to the data I/O terminal Tdata corresponding to a bit the logical value of which is “0” (step S210).
  • Next, the [0163] column decoder 13 applies a sufficiently deep forward bias to the column control input terminal Tccntl which is a memory region for a page specified at step S202 and applies a sufficiently deep reverse bias to the column control terminal Tccnt 2. Further, the low address decoder 14 applies a write-in voltage inputted from the high voltage generator 16 to the row control input terminal Trcnt which is a page specified at step S202 (step S211).
  • At this, if ground voltage is applied to a current path of an appropriate memory cell, the memory value of the memory cell is changed from “1” to “0”. [0164]
  • If the processing of step S[0165] 211 is terminated, following data stored in the data register 25 is successively written into following memory region specified by step S202 through the same processing as steps S209 to S211 (step S212).
  • Data is written into the [0166] memory cell array 11 in the unit of a page by the above described processing.
  • Erasing [0167]
  • An operation for erasing data in a block shown in FIG. 9 is started by inputting a write-in signal into the operating [0168] logic control circuit 23 when the command latch signal is on active level and a command“60H” indicating a load of address of an erasing object block is inputted to the I/O control circuit 22 (step S301).
  • After the processing is started, the [0169] address register 12 inputs an address of high order and low order pages by the same processing as steps S102 to S111 in data read-in processing. High order 9 bits of the inputted page address are extracted and a block address indicating a position of the erasing object block is specified (step S302).
  • If the address of the erasing object block is specified, the command latch signal is made to active level and the command “D0H” instructing to erase the storage content of the erasing object block is inputted to the I/O bus [0170] 4 (step S303).
  • If the write-in signal is inputted to the operating [0171] logic control circuit 23, the operating logic control circuit 23 instructs the control circuit 21 to start a control for erasing data of the specified block (step S304). The control circuit 21 receiving this instruction instructs the column decoder 13, low address decoder 14 and high voltage generator 16 to start the processing for erasing data (step S305).
  • The [0172] column decoder 13 receiving such an instruction applies a sufficiently deep reverse bias to all row control input terminals Tccntl and Tccnt2 of the memory cell array 11. The low address decoder 14 applies ground voltage to the row control input terminals Trcnt of all pages belonging to a block specified by step S302 (step S306).
  • In this condition, the [0173] high voltage generator 16 generates an erasing voltage and this erasing voltage is applied to a substrate of the memory cell array 11 (step S307). As a result, the memory values of all the memory cells belonging to the appropriate block turn to “1”. By the above described processing, data stored in the memory cell array 11 is erased in units of one block.
  • Format processing of the [0174] flash memory 1
  • Next, the format processing of the [0175] flash memory 1 as shown in FIG. 4 will be described with reference to a flow chart of FIG. 10. This processing is started by user's instructing to start the format by operating such an input device (not shown) as a keyboard connected to the computer 3.
  • The [0176] flash memory 1 and memory control unit 2 execute the above described erasing operation, namely the operations of steps S301 to S306 in order to erase each block and then erase the storage content of each block (step S401). In the processing of step S401, the commands “60H” and “D0H” outputted to the I/O bus 4 are transmitted from the CPU 31 through the system bus 34 and IOC 33.
  • Next, the [0177] CPU 31 executes the format program so as to generate a master boot record, empty area size and partition boot record having the above described content in order to coincide in the size and position the block and sector of the flash memory 1 with each other.
  • The [0178] flash memory 1 and memory control unit 2 execute the above described operation, namely, the operation of steps S201 to S211 to write a master boot record having the above described content by each page from the beginning (step S402). In the processing of step S402, the commands “80H” and “10H” and write-in object data are transmitted from the CPU 31 through the system bus 34 and IOC 33.
  • Next, the [0179] memory control unit 2 empties 14 pages and writes a partition boot record into page 16 of block 1 in the same operation (step S403).
  • As a result,- the master boot region, empty region and partition boot region are formed in the [0180] block 1.
  • Finally, the [0181] CPU 31 generates an address conversion table and stores it in the main storage unit 32 (step S404).
  • In the address conversion table generated in step S[0182] 404, each cluster and block values are set so that each block number from a head address of the memory cell array 11 coincides with each cluster. That is, the block 2 is set to coincide with cluster 2, and the block 3 is set to coincide with the cluster 3. In the following treatment, matching of the block number or cluster number is performed.
  • Here, the processing of the flow chart shown in FIG. 10 is terminated. As a result, the [0183] flash memory 1 is formatted as shown in FIG. 4.
  • Processing at the time of power on [0184]
  • If the power of the [0185] computer 3 is turned on, the CPU 31 instructs the memory control unit 2 according to a program stored in an internal ROM (not shown) to read information stored in the master boot region and partition boot region of the flash memory 1 by a first readout mode.
  • Consequently, the master boot record stored in the first page of the first block is read out from the data I/O terminal Tdata. The read out master boot record is supplied to the [0186] CPU 31.
  • The [0187] CPU 31 instructs the memory control unit 2 to read a partition boot record on the first readout mode by the same operation based on the read out master boot record. The read out partition boot record is supplied to the CPU 31. The CPU 31 stores the read out boot information in the main storage unit 32.
  • The [0188] CPU 31 determines a cluster size and a head of the data region according to the readout data. The file access operation is carried out following a definition of these boot information. Therefore, the minimum unit and position of a file at the time of data read-out and write-in become the same size and position of the block of the flash memory 1.
  • File erase processing [0189]
  • Next, processing for erasing a file written in the [0190] flash memory 1 will be described with reference to a flow chart shown in FIG. 11.
  • The file erase processing is started by operating such an input device (not shown) as a key board connected to the [0191] computer 3 or a necessity of an application program being executed by the CPU 31.
  • If the file erase processing is started, the [0192] CPU 31 specifies an erase object file (step S501). Next, the CPU 31 specifies a page having FAT and directory (that is, pages after a head of a block in which cluster number “1” is allocated on the address conversion table). The CPU 31 instructs the memory control unit 2 to read out an appropriate page on the first readout mode through the system bus 34, IOC 33 and I/O bus 4. The CPU 31 inputs the storage content of the FAT and directory read out by the memory control unit 2 and stores it in the main storage unit 32 (step S502).
  • Next, the [0193] CPU 31 retrieves the FAT and directory stored in the main storage unit 32 and specifies a cluster in which a file specified at step S501 is stored. The cluster number is temporarily stored in the main storage unit 32 (step S503).
  • Next, the [0194] CPU 31 analyzes a content of the FAT stored in the main storage unit 32 and selects an empty cluster (step S504). The CPU 31 allocates a cluster number selected at step S504 to a block to which the cluster number “1” is currently allocated and on the other hand, allocates a cluster number selected at step S504 to a block in which FAT is currently stored. According to this change of the allocation, the content of the address conversion table is written (step S505).
  • Next, the [0195] CPU 31 erases information indicating an erasing object file specified at step S501 from the content of the FAT and directory stored in the main storage unit 32 (step S506). As a result, the FAT and directory are updated. Next, the CPU 31 instructs the memory control unit 2 to write the updated FAT and directory into a first empty block. As a result, the memory control unit 2 writes a single page of a head of the updated FAT into a page of a head of an empty block selected at step S504 according to actions of steps S201 to S212 (step S507).
  • The [0196] CPU 31 instructs to write in each time when the write-in operation of the memory control unit 2 is terminated until the updated FAT and directory are all written into the empty block selected at step S504. The memory control unit 2 writes the FAT and directory successively in each of following pages according to actions of steps S201 to S212 each time when an instruction is received (step S508).
  • Next, the [0197] CPU 31 specifies a block corresponding to the number of a cluster stored at step S503 referring to the address conversion table and instructs the memory control unit 2 to erase a storage content of that block. As a result, data stored in that block or an erasing object file is erased by actions of steps S301 to S306 (step S509).
  • Next, the [0198] CPU 31 instructs the memory control unit 2 to erase a storage content of a block in which a FAT and directory before updating exist (step S510). Consequently, the storage content of the block in which the directory and FAT before updating are stored is erased according to actions of steps S301 to S306.
  • By the aforementioned processings of steps S[0199] 501 to S510, information indicating an erasing object file is erased from the FAT and directory and the content of that file is also erased. The processing of step S502 may be omitted if the content of the FAT and directory has been read in the main storage unit 32 by a processing executed prior to the processing of steps S501 to S510.
  • File write-in processing [0200]
  • A processing for writing a file into the flash memory will be described with reference to a flow chart shown in FIG. 12. The processing of this flow chart is executed by user's operating such an input device (not shown) as a keyboard connected to the [0201] computer 3 or necessity of a user program.
  • After the processing is started, the [0202] CPU 31 specifies a file name of a file to be written, a head address and data amount (step S601). Because the CPU 31 is operated according to the aforementioned format information, the data amount is integer times a block.
  • Next, the [0203] CPU 31 specifies a block in which the FAT and directory exist by referring to the address conversion table, instructs the memory control unit 2 to read out that block on the first readout mode and then inputs the storage content of the FAT and directory (step S602). By referring to the inputted FAT, an empty cluster in the flash memory 1 is retrieved (step S603).
  • Next, it is determined whether the number of empty clusters retrieved at step S[0204] 603 is sufficient for storing a file of data amount specified at step S601, and directory and FAT after updating which will be described later (step S604). If it is determined that the number of empty clusters is not sufficient at step S604, the processing proceeds to that of step S610 described later.
  • If it is determined that the number of empty clusters is sufficient at step S[0205] 604, a block necessary for storing a file of data amount specified at step S601 is specified in order from a head of empty clusters retrieved at step S603. The number of each block indicated by each specified cluster is specified by retrieving the address conversion table and a specified block number is temporarily stored in the main storage unit 32 (step S605).
  • Next, the [0206] CPU 31 instructs the memory control unit 2 to carry out write-in operation in order to write a file in a block specified at step S605. As a result, the memory control unit 2 writes a single page of a head of a write-in object file into a page of a head of an empty block retrieved at step S603 (step S606).
  • The [0207] CPU 31 instructs the write-in operation each time when the write-in operation of the memory control unit 2 is terminated until the content of a write-in object file is written into an empty cluster retrieved at step S603. The memory control unit 2 writes a content of a file successively in following pages according to actions of steps S201 to S212 each time when it receives an instruction (step S607). A size of a file to be produced by the CPU 31 is integer times the size of a block. Therefore, a write-in object file is divided equally and stored in a plurality of blocks.
  • If file write-in operation is terminated, the [0208] CPU 31 updates the FAT and directory according to actions of steps S504 to S508 for erase processing (step S608). In processing of step S506, instead of erasing information indicating an erase object file from the FAT and directory stored in the main storage unit 32, information indicating a written file is added. If updating of the FAT and directory is terminated, the processing of this flow chart is terminated.
  • On the other hand, if it is determined that the number of empty clusters is not sufficient for write-in of a file at step [0209] 604, the CPU 31 recognizes that write-in of a file is impossible and terminates processing of this flow chart (step S610).
  • File readout processing [0210]
  • To read out a file from the [0211] flash memory 1, the same processing as that conventionally used for reading a file from the flash memory 1 is applied. That is, the CPU 31 specifies a file name of a read-out object file, reads out FAT information and directory information on the first read-out mode and specifies a page in which a file having an appropriate file name is stored according to read-out information. The CPU 31 instructs to read out on the first read-out mode. As a result, the appropriate file is successively read out and supplied to the CPU-31.
  • In the memory control system according to this embodiment, as described above, the size and position of a block of the [0212] flash memory 1 are coincided with the size and position of a cluster which is a minimum unit of a file managed by the OS.
  • Therefore, plural files are not stored in each block. Therefore, when a file stored in the [0213] flash memory 1 is written in, it is not necessary to save data other than erasing object data in the same block in other cluster or erase a block for storing the saved data and the like. Generally, the data write-in speed of the flash memory 1 is higher than data read-out speed and the data erase speed is slower than the data write-in speed. Thus, with such a structure, the write-in processing and erase processing conventionally necessary are not required to be carried out thereby making it possible to accelerate the processing speed.
  • In general operating system, when a medium is initialized, data is erased not by erasing it physically but replacing a part of existing data with a specific code. However, in the flash memory, when data is written, even if there is left erased data, saving of the data and physical erasing of an appropriate block are necessary thereby decelerating the write-in action. According to this embodiment, data region is physically erased upon formatting. Therefore the erasing processing is not required at the time of write-in, so that the write-in processing can be accelerated. [0214]
  • Further in general operation system, when a file is erased, the entire data actually forming that file is not erased, but by replacing a head one character with a specific code like “CE”, that file is handled as an erased file. In the flash memory, even when such erased data is left, saving of the data and physical erasing of an appropriate block are necessary thereby decelerating the write-in action. Because according to this embodiment, the data region is physically erased at the time of formatting, the erasing processing upon write-in is not necessary so that the write-in processing can be accelerated. [0215]
  • Meanwhile, the structure of the [0216] flash memory 1 in the memory control system according to this embodiment is not restricted to the above described structure. For example, the entire memory capacity of the flash memory 1 does not have to be 8 M byte, the memory capacity of each memory cell does not have to be 1 byte and the memory capacity of a page does not have to be 528 bytes. Further, the number of pages of each block does not have to be 16.
  • The flash memory may be of NOR type. The amount of data inputted or outputted once by the [0217] flash memory 1 does not have to be 1 byte, for example, may input or output more than 2 bytes all at once.
  • According to the above described embodiment, upon power on, the format of the [0218] flash memory 1 is determined by accessing the boot region. However, it is permissible to make access to the boot region temporarily when the flash memory 1 is accessed, determine that it coincides with a format recognized by the control circuit 21 or CPU 31 and then make access to data.
  • Although in a format shown in FIG. 4, the FAT and directory are allocated in the same cluster, it is permissible to allocate them separately. In this case, by making a cluster storing the FAT and directory correspond to “1”, “2” or other specified number cluster, the positions of the FAT and direction are determined. [0219]
  • Although in the format shown in FIG. 4, only one FAT is allocated, it is permissible to allocate a first copy (FAT[0220] 1) and a second copy (FAT2) of the FAT following an ordinary disk format.
  • Although in the format shown in FIG. 4, the boot information and other information like FAT are written in separate blocks, it is permissible to write these information items in the same cluster (block). If such a format structure is applied, the boot information and the like are copied in other empty block accompanied with updating of the FAT. Therefore, the [0221] control circuit 21 and CPU 31 store a position of the boot region.
  • In a case when each cluster has eight pages (4 KB) for example, it is permissible to write the master boot record in [0222] page 1 of a sector, keep pages 2 to 4 as empty region, write a partition boot record in page 5, write FAT1 and FAT2 in pages 7 and 8 and write its directory in other cluster. This configuration is effectively available when the FAT and directory size are small, for example, the entire memory capacity is about 1 MB.
  • In a case when each cluster has eight pages, it is permissible to write the master boot record in [0223] page 1 of a sector, keep pages 2 and 3 as empty region, write the partition record in page 4, write FAT1 and FAT2 in pages 5 to 8 and write its directory in other cluster.
  • In a case when each cluster has 16 pages (8 KB), it is permissible to write the master boot record in [0224] page 1 of a sector, keep pages 2 to 9 as empty region, write the partition boot record in page 10, write FAT1 and FAT2 in pages 11 to 16 and write its directory in other cluster. Likewise, it is permissible to write the master boot record in page 1 of a sector, keep pages 2 and 3 as empty region, write the partition boot record in page 4, write FAT1 and FAT2 in pages 5 to 16 and write its directory in other cluster. This configuration is effectively available when the sizes of the FAT and directory are relatively large, for example, when the memory capacity is 8 MB, 16 MB or equivalent.
  • Even if such a format configuration is employed, because the sizes of the block and cluster are set to the same size and position, unrequited erase processing does not occur, so that the processing can be executed rapidly. [0225]
  • The [0226] flash memory 1 does not have to be fixed in the memory control unit 2 but may be removably installed in the memory control unit 2.
  • Next, the second embodiment will be described. Although according to the first embodiment, the [0227] memory control unit 2 carries out formatting of the flash memory 1, erasing of a file, write-in of a file and the like corresponding to a command from the CPU 31, in the second embodiment, the CPU 31 itself is capable of carrying out the operation of the memory control unit 2.
  • In this structure, as shown in FIG. 13 for example, the [0228] address register 12, column decoder 13, low address decoder 14, voltage converter 15 and high voltage generator 15 of the flash memory 1 are connected to the IOC 33.
  • If such a configuration is employed, the [0229] CPU 31 itself carries out the operation executed by the memory control unit 2. For example, when the flash memory 1 is formatted, the CPU 31 updates the block address and simultaneously instructs the low address decoder 14, voltage converter 15 and high voltage generator 16 to start the processing for erasing data through the IOC 33 (FIG. 10, step S401). Further, it outputs a write-in object master boot record and partition boot record and instructs the column decoder 13, low address decoder 14, voltage converter 15 and high voltage generator 16 to start the processing for writing these data (steps S402, 403). Then, the address conversion table on the main storage unit 32 is produced (step S404).
  • The [0230] CPU 31 makes access to a head block of the flash memory 1 upon power on, so as to read out boot information, determines a cluster structure (size and position) and controls following access to the flash memory 1 according to this.
  • For example, in a case when a file is erased, the [0231] CPU 31 itself reads out the FAT and directory according to a pointer value (FIG. 11, steps S501, S502) and determines a cluster in which a file to be erased is stored (step S503). The FAT and directory are updated (steps S504 to S508) and a block corresponding to that cluster is erased (step S509). Finally, the CPU 31 erases a block in which FAT and the like before updating are stored (step S510) and terminates the processing.
  • For example when new data is written, the [0232] CPU 31 determines an empty cluster according to the FAT and controls the column decoder 13, low address decoder 14, voltage converter 15 and high voltage generator 16 so as to store data successively in the memory cell array 11. If file write-in is completed, the FAT and directory are updated.
  • The size of a file generated by the [0233] CPU 31 is integer times the block size. Therefore, the file is stored exactly in one or a plurality of blocks. Because the sizes of the FAT and directory are set to the same size as a single block, the FAT and directory are stored exactly in a block. Therefore, it is possible to prevent a small amount of data which is a part of a file or directory from being stored in a part of the block by a single write-in processing so that the file can be erased in units of one block at the aforementioned erasing time.
  • By [0234] CPU 31's controlling the formatting, file erasing and file updating, it is possible to access the flash memory 1 without using any control circuit.
  • With this structure, if there exist erasing object data and other data mixedly in the same block, the [0235] CPU 31 must carry out the processing of saving and erasing a file, so that there is a fear that the operating speed of the entire computer system drops. Because this embodiment employs a format that the class coincides with the block as shown in FIG. 4, unnecessary saving processing and erasing processing can be suppressed, thereby making it possible to raise the processing speed of the entire system.
  • Next, the third embodiment will be described. Although according to the first and second embodiments, the [0236] flash memory 1 is formatted so that a single cluster coincides with a single block, according to a third embodiment, the flash memory 1 is formatted so that a single cluster corresponds to a plurality of blocks as shown in FIG. 14.
  • As shown in the Figure, in this format, the [0237] block 1 of the flash memory is boot region, in which the master boot record and partition boot record are stored.
  • The cluster of the [0238] flash memory 1 is specified by data stored in the master boot record and partition boot record in the boot region. In this format, the blocks 2 to 4 of the flash memory 1 correspond to the cluster 1. The blocks 5 to 7 correspond to the cluster 2. The blocks 8 to 10 correspond to the cluster 3. Hereinafter, the blocks 1022 to 1024 correspond to the cluster 343.
  • The memory control system according to this embodiment and processing thereof are the same as the first and second-embodiments. However, when data of a cluster will be erased, this memory control system erases each data of three blocks corresponding to data erasing object cluster. Therefore, the processing of steps S[0239] 301 to S307 is repeated three times. Although FIG. 14 shows an example in which a cluster corresponds to three blocks, a cluster may correspond to any integer more than 2 blocks.
  • Next, a fourth embodiment will be described. According to the first embodiment, when the [0240] flash memory 1 is formatted, the storage content of all the blocks of the flash memory 1 is erased and then the master boot record and partition boot record are written into the block 1. However, if the boot information is the same between before and after the formatting, such information does not have to be written again. Therefore, the fourth embodiment has proposed a method in which if the boot information is the same between before and after the formatting, the flash memory 1 is formatted without erasing the boot information.
  • According to the fourth embodiment, the memory control system configuration is the same as the case of FIG. 1. Further, processing of the [0241] flash memory 1 other than formatting is the same as the first embodiment.
  • FIG. 15 is a flow chart showing a processing for formatting the [0242] flash memory 1 according to this embodiment. The processing of this flow chart is started by inputting a predetermined command to the I/O control circuit 22 from the CPU 31 through the system bus 34, IOC 33 and I/O bus 4 by user's operating an input device such as a key board (not shown) connected to the computer 3 like the processing of the flow chart shown in FIG. 10.
  • If the processing is started, the [0243] CPU 31 reads out a master boot record and partition boot record stored in the boot region of the flash memory 1 like the processing for power on in the first embodiment and temporarily stores them in the main storage unit 32 (step S701).
  • Next, to format the [0244] flash memory 1, the CPU 31 reads out the master boot record and partition boot record stored in the main storage unit 32 through the system bus 34, IOC 33, I/O bus 4 and I/O control circuit 22. Then, it is determined whether the readout master boot record and partition boot record coincide with the master boot record and partition boot record temporarily stored at step S701 (step S702).
  • If it is determined that they coincide at step S[0245] 702, the processing of steps S301 to S307 are carried out for blocks other than the block 1 of the flash memory 1. As a result, data stored in the memory cell of blocks other than the block 1 (boot region) of the flash memory 1 is erased (step S703). The processing of this flow chart is terminated. As a result, the flash memory 1 is formatted as shown in FIG. 4.
  • On the other hand, if the comparison result does not coincide at step S[0246] 702, the control circuit 21 carries out the processing of steps S401 to S404 shown in FIG. 10 so as to format the flash memory 1 (step S704), so that the processing of this flow chart is terminated.
  • According to the memory control system according to this embodiment, as described above, if the master boot record and partition boot record written in the boot region do not have to be changed when the [0247] flash memory 1 is formatted, the erasing of data written in the boot region and writing of data into the boot region are not carried out. Because data write-in processing and erase processing which take longer than data read-out processing do not have to be carried out, the flash memory 1 can be formatted more quickly than the memory control system according to the first embodiment.
  • Next, a fifth embodiment will be described. Although according to the first to fourth embodiments, the FAT and directory are written into an empty cluster in the data region appropriately, in the fifth embodiment the FAT and directory can be written into only a particular block. [0248]
  • According to this embodiment, the structure of the memory control system and the format structure of the [0249] flash memory 1 are the same as the first embodiment. However, the number of a cluster in which the FAT and directory data are to be written is not specified and instead, a particular number is allocated to a cluster belonging to a particular cluster group which will be described later. The CPU 31 determines a cluster in which the FAT and directory data are written according to an identification flag which will be described later.
  • FIG. 16 is a diagram showing particular cluster groups for storing data of the FAT and directory according to this embodiment. As shown here, the particular cluster group includes two groups, [0250] cluster group 1 and cluster group 2, in any one of which the FAT and directory are to be written.
  • The structures of the directory and FAT are substantially the same as the first and second embodiments. As shown in FIG. 17, an identification flag employing the value “FFh” which cannot be used by ordinary data is written at a head of a cluster group in which the FAT and directory are written. On the other hand, the cluster group in which the FAT and directory are not written is an empty block. Further, each identification code (not shown) is attached to the head of the FAT region and directory region. [0251]
  • The format processing on the flash memory executed by the [0252] control circuit 21 according to this embodiment will be described with reference to a flow chart of FIG. 18. The processing of this flow chart is started by inputting a predetermined command to the I/O control circuit 22 from the CPU 31 through the system bus 34, IOC 33 and I/O bus 4 by user's operating such an input device (not shown) as a key board connected to the computer 3.
  • After the processing is started, the [0253] control circuit 21 carries out the same processing as steps S401 to S403 of FIG. 5 (step S801). Next, the CPU 31 writes FFh data into a head page of a cluster group for storing initially set FAT and directory according to the processing of steps S201 to S212 and then terminates the processing of this flow chart (step S802). As a result, the flash memory 1 is formatted.
  • A processing for erasing a file written in the [0254] flash memory 1 executed by the control circuit 21 according to this embodiment will be described with reference to a flow chart shown in FIG. 19. The processing of this flow chart is started by inputting a predetermined command to the I/O control circuit 22 from the CPU 31 through the system bus 34, IOC 33 and I/O bus 4 by user's operating such an input device (not shown) as a key board connected to the computer 3.
  • If the processing is started, the [0255] control circuit 21 carries out the processing of steps S501 to S506 (step S901). Next, the CPU 31 writes a content of the updated FAT and directory successively in each page following a head page of a cluster group in which the identification flat is not FFh, according to actions of the steps S201 to S212 (step S902).
  • Next, the [0256] CPU 31 erases the content of the cluster group in which the directory and FAT before updating are stored according to processing of steps S301 to S306 (step S903) and terminates the processing of this flow chart.
  • The processing of writing a file into the [0257] flash memory 1 executed by the control circuit 21 according to this embodiment will be described with reference to a flow chart shown in FIG. 20. The processing of this flow chart is started by inputting a predetermined command to the I/O control circuit 22 from the CPU 31 through the system bus 34, IOC 33 and I/O bus 4 by user's operating such an input device (not shown) as a key board connected to the computer 3.
  • If the processing is started, the [0258] control circuit 21 carries out the processing of steps S601 to S607 shown in FIG. 11 (however, if it is determined that the number of empty clusters is insufficient at a processing of step S604, further processing of S610) (step S1001). Next, the CPU 31 carries out the processing of steps S902 to S903 (step S1002). In the updated FAT and directory, information indicating an erasing object file has been deleted, but information of a newly written file has been added. Then, the processing of the flow chart is terminated.
  • As described above, in the memory control system of this embodiment, the FAT and directory data can be read out even if the memory position of the FAT and directory data are not rewritten each time when file erasing or rewrite is performed. In the memory control system according to this embodiment, the number of clusters for constructing the cluster group is not restricted to 2 but the cluster group can be constructed by any number of clusters more than 1. [0259]
  • In the memory control system of this embodiment, particular two cluster groups for storing the FAT and directory data do not always have to be provided in a first region of the [0260] flash memory 1 but may be provided at any position.
  • A program (a driver for formatting) for carrying out a processing for formatting the [0261] flash memory 1, executed by the CPU 31 or the like may be provided by such a recording medium as a floppy disk and CR-ROM.
  • As described above, according to the block erasing type memory device according to this embodiment, data erasing and write-in can be carried out rapidly. [0262]
  • Further, the block erasing type memory device can be formatted so that data erasing and write-in can be carried out rapidly by executing a program stored in the program memory medium according to this embodiment. Further, by carrying out a program stored in the program memory medium of this embodiment, data erasing and write-in can be carried out rapidly. [0263]

Claims (18)

What is claimed is:
1. A data processing system comprising:
a block erasing type memory device writing in and reading out data using a FAT and directory method and including a plurality of blocks, capable of erasing stored data collectively in units of block; and
data processing means for accessing said block erasing type memory device,
wherein said data processing means includes:
control means connected to said block erasing type memory device for formatting said block erasing type memory device according to formatting information for substantially allowing a cluster serving as a logical unit of a memory region of said block erasing type memory device to correspond in size and position with a block or integer ones of said blocks, and
access means for determining the size and position of the cluster according to said format information and carrying out access control for data erasing, data write-in and data read-out for said block erasing type memory device formatted according to the determined size and position of the cluster.
2. A block erasing type memory device having a plurality of blocks and capable of erasing data collectively in units of block, wherein
said block erasing type device writes in and reads out data using a FAT and directory method, and includes:
a memory region formatted according to format information for making one or integer ones of the blocks substantially correspond to each of clusters, each cluster serving as a unit of said memory region.
3. A block erasing type memory device according to
claim 2
, wherein each of said clusters has a size and position substantially coinciding with a corresponding one of said blocks.
4. A block erasing type memory device according to
claim 2
or
3
, wherein said format information comprises information for corresponding the size of each of said clusters with the size of each of said blocks and a position adjusting region for corresponding a start position and end position of each of said clusters with the start position and end position of each of said blocks.
5. A block erasing type memory device according to
claim 4
, in which directory information indicating a file name and head memory position and a file allocation table indicating a file position is stored in one of said clusters.
6. A block erasing type memory device according to
claim 4
, wherein stored data of the blocks other than said block for storing said format information is physically erased.
7. A block erasing type memory device according to
claim 2
or
3
, in which directory information indicating a file name and head memory position and a file allocation table indicating a file position is stored in one of said clusters.
8. A block erasing type memory device according to
claim 2
or
3
, wherein stored data of the blocks other than said block for storing said format information is physically erased.
9. A data processing system comprising:
a connecting portion constructed to be connectable to a block erasing type memory device writing in and reading out data using a FAT and directory method and containing a plurality of blocks and capable of erasing collectively stored data in units of block; and
formatting means for formatting said block erasing type memory device by writing format information for substantially allowing one or integer ones of said blocks to coincide with each cluster into said block erasing type memory device through said connecting portion.
10. A data processing system according to
claim 9
, wherein said formatting means writes format information for substantially coinciding the size and position of each of said clusters with the size and position of each of said blocks into said block erasing type memory device.
11. A data processing system according to
claim 9
, wherein said formatting means writes information for corresponding the size of each of said clusters with the size of each of said blocks and position adjusting information for corresponding the start position and end position of each of said clusters with the start position and end position of each of said blocks into said block erasing type memory device.
12. A data processing system according to
claim 9
, further comprising means for recording in each cluster directory information indicating a file name and head memory position and a file allocation table indicating a file positioning.
13. A data processing system according to
claim 9
, wherein said formatting means includes means for physically erasing stored data of said blocks other than that of said blocks in which said format information is written.
14. A data processing system according to
claim 9
, further comprising file erasing means for erasing a file written in said block erasing type memory device through said connecting portion, said file erasing means including means for physically erasing data of blocks of said blocks including an appropriate data.
15. A data processing system according to any one of
claims 9
to
14
, further comprising format information readout means for reading out said format information through said connecting means, cluster determining means for determining a size and position of each of the clusters each serving as a minimum unit of a file, according to format information read out by said format information readout means and means for controlling erasing, write-in and readout of data of said block erasing type memory device according to the size and position of each of the clusters determined by said cluster determining means.
16. A data storage medium storing a program comprising a set of instructions for:
physically erasing stored data of a block erasing type memory device capable of erasing stored data collectively in units of block; and
writing information for allowing a size and position of each of clusters, each serving as a unit of data memory region, to correspond with the size and position of one or integer ones of the blocks into the block erasing type memory device the stored data of which has been erased.
17. A data storage medium according to
claim 16
, further storing a program including an instruction for, when stored data in the block erasing type memory device is instructed to be erased, physically erasing a storage content of the block including the data which has been instructed to be erased.
18. A data storage medium according to
claim 16
or
17
, further storing a program including an instruction for recording directory information for indicating a file name and head memory position and a file allocation table for indicating an allocation of the file, in each cluster.
US09/816,383 1997-08-04 2001-03-26 Data processing system, block erasing type memory device and memory storing program for controlling memory device Expired - Fee Related US6401166B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US09/816,383 US6401166B2 (en) 1997-08-04 2001-03-26 Data processing system, block erasing type memory device and memory storing program for controlling memory device

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
JP20897697A JP3588231B2 (en) 1997-08-04 1997-08-04 Data processing system and block erase type storage medium
JP9-208976 1997-08-04
PCT/JP1998/002862 WO1999008177A1 (en) 1997-08-04 1998-06-25 Data processing system, block erasing type memory device and memory medium storing program for controlling memory device
US09/498,066 US6411552B1 (en) 1997-08-04 2000-02-04 Data processing system, block erasing type memory device and memory medium storing program for controlling memory device
US09/816,383 US6401166B2 (en) 1997-08-04 2001-03-26 Data processing system, block erasing type memory device and memory storing program for controlling memory device

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/498,066 Division US6411552B1 (en) 1997-08-04 2000-02-04 Data processing system, block erasing type memory device and memory medium storing program for controlling memory device

Publications (2)

Publication Number Publication Date
US20010010065A1 true US20010010065A1 (en) 2001-07-26
US6401166B2 US6401166B2 (en) 2002-06-04

Family

ID=16565284

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/498,066 Expired - Fee Related US6411552B1 (en) 1997-08-04 2000-02-04 Data processing system, block erasing type memory device and memory medium storing program for controlling memory device
US09/816,383 Expired - Fee Related US6401166B2 (en) 1997-08-04 2001-03-26 Data processing system, block erasing type memory device and memory storing program for controlling memory device

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/498,066 Expired - Fee Related US6411552B1 (en) 1997-08-04 2000-02-04 Data processing system, block erasing type memory device and memory medium storing program for controlling memory device

Country Status (6)

Country Link
US (2) US6411552B1 (en)
EP (1) EP1000394A1 (en)
JP (1) JP3588231B2 (en)
KR (1) KR100375533B1 (en)
TW (1) TW449690B (en)
WO (1) WO1999008177A1 (en)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2004040455A2 (en) 2002-10-28 2004-05-13 Sandisk Corporation Method and apparatus for splitting a logical block
US20040148454A1 (en) * 2002-03-19 2004-07-29 Minoru Seo Information processing apparatus and method
US20060004969A1 (en) * 2004-06-30 2006-01-05 Takaya Suda High-speed accessible memory featuring reduced data movement
US7188228B1 (en) 2003-10-01 2007-03-06 Sandisk Corporation Hybrid mapping implementation within a non-volatile memory system
US20070244941A1 (en) * 2002-02-07 2007-10-18 Reed John M Method and System to Quarantine System Software and Configuration
US20070294695A1 (en) * 2006-06-19 2007-12-20 Craig Jensen Method, system, and apparatus for scheduling computer micro-jobs to execute at non-disruptive times
US20080086734A1 (en) * 2006-10-10 2008-04-10 Craig Jensen Resource-based scheduler
US20080086733A1 (en) * 2006-10-10 2008-04-10 Diskeeper Corporation Computer micro-jobs
US20090094433A1 (en) * 2007-10-05 2009-04-09 Basil Thomas Solid State Drive Optimizer
US20090164538A1 (en) * 2006-05-16 2009-06-25 Buffalo Inc. Data storage apparatus and initialization method thereof
US20090193183A1 (en) * 2006-07-31 2009-07-30 Kabushiki Kaisha Toshiba Nonvolatile memory system, and data read/write method for nonvolatile memory system
US20170010969A1 (en) * 2015-07-08 2017-01-12 Hon Hai Precision Industry Co., Ltd. Computing device and method for processing data in cache memory of the computing device
US9626287B2 (en) 2009-01-21 2017-04-18 Micron Technology, Inc. Solid state memory formatting
US20170286446A1 (en) * 2016-04-01 2017-10-05 Tuxera Corporation Systems and methods for enabling modifications of multiple data objects within a file system volume

Families Citing this family (38)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3588231B2 (en) * 1997-08-04 2004-11-10 東京エレクトロンデバイス株式会社 Data processing system and block erase type storage medium
JP4079506B2 (en) 1997-08-08 2008-04-23 株式会社東芝 Method for controlling nonvolatile semiconductor memory system
US6725322B1 (en) 1999-02-22 2004-04-20 Renesas Technology Corp. Memory card, method for allotting logical address, and method for writing data
CN1203395C (en) 1999-10-21 2005-05-25 松下电器产业株式会社 Semiconductor memory card access apparatus, computer-readable recording medium, an initialization method, and semiconductor memory card
JP3942807B2 (en) * 2000-06-06 2007-07-11 株式会社ルネサステクノロジ Semiconductor memory device with block alignment function
US7510572B2 (en) * 2000-09-12 2009-03-31 Shlomo Gabbay Implantation system for delivery of a heart valve prosthesis
JP2002358248A (en) * 2001-06-04 2002-12-13 Pioneer Electronic Corp Data recording device and data erasing device
JP2003296177A (en) 2002-04-03 2003-10-17 Sony Corp Recording device and method, storage medium and program
JP4218406B2 (en) 2003-04-25 2009-02-04 富士フイルム株式会社 Information recording and playback method
CN1890645B (en) * 2003-12-03 2010-09-08 松下电器产业株式会社 Information recording medium data processing apparatus and data recording method
US8504798B2 (en) 2003-12-30 2013-08-06 Sandisk Technologies Inc. Management of non-volatile memory systems having large erase blocks
US7631138B2 (en) 2003-12-30 2009-12-08 Sandisk Corporation Adaptive mode switching of flash memory address mapping based on host usage characteristics
JP4347707B2 (en) * 2004-01-09 2009-10-21 パナソニック株式会社 Information recording medium formatting method and information recording medium
EP1729218A4 (en) * 2004-04-20 2007-07-18 Matsushita Electric Ind Co Ltd Nonvolatile storage system
EP2977906A1 (en) 2004-04-28 2016-01-27 Panasonic Corporation Nonvolatile storage device and data write method
KR20060007668A (en) * 2004-07-20 2006-01-26 엘지전자 주식회사 Databse system most suitable for flash memory and mamnagement method for the same
JP2006155461A (en) * 2004-12-01 2006-06-15 Sony Corp Information processor and processing method, and program
JP2007095222A (en) * 2005-09-30 2007-04-12 Eastman Kodak Co Semiconductor memory and memory controller thereof
EP3167847B1 (en) * 2005-11-10 2020-10-14 Edwards Lifesciences CardiAQ LLC Heart valve prosthesis
EP1895418B1 (en) 2005-12-09 2015-04-01 Panasonic Corporation Nonvolatile memory device, method of writing data, and method of reading out data
US7510426B2 (en) * 2006-05-26 2009-03-31 Mina Hwang Electrical power apparatus with retractable cords and moveable sockets
JP4991320B2 (en) 2007-01-12 2012-08-01 株式会社東芝 Host device and memory system
JP4978224B2 (en) * 2007-02-08 2012-07-18 カシオ計算機株式会社 Photoelectric conversion device and display panel having the same
KR100909358B1 (en) * 2007-04-16 2009-07-24 삼성전자주식회사 Flash memory device providing reliable initialization data and method of initializing it
JP4539677B2 (en) 2007-04-23 2010-09-08 コニカミノルタビジネステクノロジーズ株式会社 Image forming apparatus, program update system, program update method, and program update program
JP2010044822A (en) * 2008-08-12 2010-02-25 Toppan Printing Co Ltd Semiconductor memory
US8281117B2 (en) * 2008-09-24 2012-10-02 Airbus Operations Gmbh Method and a memory unit for booting a server by copying boot data from an exchangeable memory unit to primary hard disk of the server
US8180995B2 (en) 2009-01-21 2012-05-15 Micron Technology, Inc. Logical address offset in response to detecting a memory formatting operation
JP5341584B2 (en) 2009-03-17 2013-11-13 株式会社東芝 Controller and memory system
EP2688516B1 (en) 2011-03-21 2022-08-17 Cephea Valve Technologies, Inc. Disk-based valve apparatus
JP5366159B2 (en) * 2011-09-06 2013-12-11 ルネサスエレクトロニクス株式会社 Semiconductor device and microcomputer
EP2798500A1 (en) 2011-12-29 2014-11-05 Memory Technologies LLC Method for erasing data entity in memory module
US9561103B2 (en) 2013-07-17 2017-02-07 Cephea Valve Technologies, Inc. System and method for cardiac valve repair and replacement
EP3229736B1 (en) 2014-12-09 2024-01-10 Cephea Valve Technologies, Inc. Replacement cardiac valves and method of manufacture
US10849746B2 (en) 2015-05-14 2020-12-01 Cephea Valve Technologies, Inc. Cardiac valve delivery devices and systems
WO2017218877A1 (en) 2016-06-17 2017-12-21 Cephea Valve Technologies, Inc. Cardiac valve delivery devices and systems
AU2018203053B2 (en) 2017-01-23 2020-03-05 Cephea Valve Technologies, Inc. Replacement mitral valves
CA3051272C (en) 2017-01-23 2023-08-22 Cephea Valve Technologies, Inc. Replacement mitral valves

Family Cites Families (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH01103248A (en) 1987-10-14 1989-04-20 Koyo Seiko Co Ltd Tool positioner
JPH0484216A (en) * 1990-07-26 1992-03-17 Toshiba Corp Data erasing method for semiconductor disk device
US5303198A (en) * 1990-09-28 1994-04-12 Fuji Photo Film Co., Ltd. Method of recording data in memory card having EEPROM and memory card system using the same
GB2251324B (en) 1990-12-31 1995-05-10 Intel Corp File structure for a non-volatile semiconductor memory
JPH0546459A (en) * 1991-08-09 1993-02-26 Toshiba Corp Memory card device
JPH0695955A (en) * 1992-09-09 1994-04-08 Ricoh Co Ltd Flash file system
JP2856621B2 (en) * 1993-02-24 1999-02-10 インターナショナル・ビジネス・マシーンズ・コーポレイション Batch erase nonvolatile memory and semiconductor disk device using the same
US5485595A (en) 1993-03-26 1996-01-16 Cirrus Logic, Inc. Flash memory mass storage architecture incorporating wear leveling technique without using cam cells
US5522076A (en) * 1993-05-13 1996-05-28 Kabushiki Kaisha Toshiba Computer system having BIOS (basic input/output system)-ROM (Read Only Memory) writing function
JPH0773098A (en) * 1993-09-01 1995-03-17 Toshiba Emi Ltd Data write method
US5542077A (en) * 1993-09-10 1996-07-30 Compaq Computer Corporation Personal computer with CMOS memory not having a separate battery
JPH0877286A (en) * 1994-08-31 1996-03-22 Fuji Photo Film Co Ltd Interface device for memory card
KR0182939B1 (en) * 1995-06-28 1999-04-15 김광호 Ic card memory with a dedicated recording format and recording / reproducing method for digital voice therefor
US6125435A (en) * 1995-09-13 2000-09-26 Lexar Media, Inc. Alignment of cluster address to block addresses within a semiconductor non-volatile mass storage memory
US5835935A (en) * 1995-09-13 1998-11-10 Lexar Media, Inc. Method of and architecture for controlling system data with automatic wear leveling in a semiconductor non-volatile mass storage memory
US5933847A (en) * 1995-09-28 1999-08-03 Canon Kabushiki Kaisha Selecting erase method based on type of power supply for flash EEPROM
US5701492A (en) * 1996-03-29 1997-12-23 Canon Kabushiki Kaisha Fail-safe flashing of EPROM
JPH10124384A (en) * 1996-08-28 1998-05-15 Toshiba Corp Method for controlling non-volatile semiconductor memory
US5754567A (en) * 1996-10-15 1998-05-19 Micron Quantum Devices, Inc. Write reduction in flash memory systems through ECC usage
US5937423A (en) * 1996-12-26 1999-08-10 Intel Corporation Register interface for flash EEPROM memory arrays
JP3588231B2 (en) * 1997-08-04 2004-11-10 東京エレクトロンデバイス株式会社 Data processing system and block erase type storage medium
JP4135049B2 (en) * 1999-03-25 2008-08-20 ソニー株式会社 Non-volatile memory

Cited By (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070244941A1 (en) * 2002-02-07 2007-10-18 Reed John M Method and System to Quarantine System Software and Configuration
US7702897B2 (en) * 2002-02-07 2010-04-20 Netapp, Inc. Method and system to quarantine system software and configuration
US20040148454A1 (en) * 2002-03-19 2004-07-29 Minoru Seo Information processing apparatus and method
WO2004040455A3 (en) * 2002-10-28 2004-12-23 Sandisk Corp Method and apparatus for splitting a logical block
US7039788B1 (en) 2002-10-28 2006-05-02 Sandisk Corporation Method and apparatus for splitting a logical block
WO2004040455A2 (en) 2002-10-28 2004-05-13 Sandisk Corporation Method and apparatus for splitting a logical block
US7188228B1 (en) 2003-10-01 2007-03-06 Sandisk Corporation Hybrid mapping implementation within a non-volatile memory system
US7702880B2 (en) 2003-10-01 2010-04-20 Sandisk Corporation Hybrid mapping implementation within a non-volatile memory system
US20060004969A1 (en) * 2004-06-30 2006-01-05 Takaya Suda High-speed accessible memory featuring reduced data movement
US20090164538A1 (en) * 2006-05-16 2009-06-25 Buffalo Inc. Data storage apparatus and initialization method thereof
US20070294695A1 (en) * 2006-06-19 2007-12-20 Craig Jensen Method, system, and apparatus for scheduling computer micro-jobs to execute at non-disruptive times
US8239869B2 (en) 2006-06-19 2012-08-07 Condusiv Technologies Corporation Method, system and apparatus for scheduling computer micro-jobs to execute at non-disruptive times and modifying a minimum wait time between the utilization windows for monitoring the resources
US9727372B2 (en) 2006-06-19 2017-08-08 Invisitasking Llc Scheduling computer jobs for execution
US7836245B2 (en) 2006-07-31 2010-11-16 Kabushiki Kaisha Toshiba Nonvolatile memory system, and data read/write method for nonvolatile memory system
US20110082968A1 (en) * 2006-07-31 2011-04-07 Kabushiki Kaisha Toshiba Nonvolatile memory system, and data read/write method for nonvolatile memory system
US20090193183A1 (en) * 2006-07-31 2009-07-30 Kabushiki Kaisha Toshiba Nonvolatile memory system, and data read/write method for nonvolatile memory system
US8615765B2 (en) 2006-10-10 2013-12-24 Condusiv Technologies Corporation Dividing a computer job into micro-jobs
US8056083B2 (en) 2006-10-10 2011-11-08 Diskeeper Corporation Dividing a computer job into micro-jobs for execution
US20080086733A1 (en) * 2006-10-10 2008-04-10 Diskeeper Corporation Computer micro-jobs
US20080086734A1 (en) * 2006-10-10 2008-04-10 Craig Jensen Resource-based scheduler
US9588809B2 (en) 2006-10-10 2017-03-07 Invistasking LLC Resource-based scheduler
US8086819B2 (en) * 2007-10-05 2011-12-27 Diskeeper Corporation Solid state drive optimizer
US20090094433A1 (en) * 2007-10-05 2009-04-09 Basil Thomas Solid State Drive Optimizer
US9626287B2 (en) 2009-01-21 2017-04-18 Micron Technology, Inc. Solid state memory formatting
US20170010969A1 (en) * 2015-07-08 2017-01-12 Hon Hai Precision Industry Co., Ltd. Computing device and method for processing data in cache memory of the computing device
US9842054B2 (en) * 2015-07-08 2017-12-12 Hon Hai Precision Industry Co., Ltd. Computing device and method for processing data in cache memory of the computing device
US20170286446A1 (en) * 2016-04-01 2017-10-05 Tuxera Corporation Systems and methods for enabling modifications of multiple data objects within a file system volume
US10496607B2 (en) * 2016-04-01 2019-12-03 Tuxera Inc. Systems and methods for enabling modifications of multiple data objects within a file system volume

Also Published As

Publication number Publication date
JP3588231B2 (en) 2004-11-10
KR100375533B1 (en) 2003-03-10
TW449690B (en) 2001-08-11
KR20010022618A (en) 2001-03-26
WO1999008177A1 (en) 1999-02-18
EP1000394A1 (en) 2000-05-17
US6411552B1 (en) 2002-06-25
US6401166B2 (en) 2002-06-04
JPH1153248A (en) 1999-02-26

Similar Documents

Publication Publication Date Title
US6411552B1 (en) Data processing system, block erasing type memory device and memory medium storing program for controlling memory device
JP3680142B2 (en) Storage device and access method
EP0712067B1 (en) Flash disk card
US7388792B2 (en) Memory management device and memory device
US6477616B1 (en) Storage device, storage system, memory management method, recording medium, and computer data signal
US7814264B2 (en) Memory card, semiconductor device, and method of controlling semiconductor memory
US5787493A (en) Control method and apparatus for direct execution of a program on an external apparatus using a randomly accessible and rewritable memory
US8694722B2 (en) Memory systems
EP0522780B1 (en) Control method for a computer memory device
US5592669A (en) File structure for a non-volatile block-erasable semiconductor flash memory
US8327068B2 (en) Memory module, memory controller, nonvolatile storage, nonvolatile storage system, and memory read/write method
US20050172068A1 (en) Memory card and semiconductor device
US20040064636A1 (en) Storage device, storage device controlling method, and program
JP2001243110A (en) Memory controller, flash memory system and access method to flash memory
US5724544A (en) IC memory card utilizing dual eeproms for image and management data
JP2000030375A (en) Data processing system, access device, and recording media
JPH0675836A (en) Auxiliary storage device
US6898680B2 (en) Minimization of overhead of non-volatile memory operation
US20060059296A1 (en) Emulating small block size of flash memory
US20070150528A1 (en) Memory device and information processing apparatus
JPH05250884A (en) Nonvolatile storage device
JPH0877081A (en) File memory system

Legal Events

Date Code Title Description
AS Assignment

Owner name: TOKYO ELECTRON LIMITED, JAPAN

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CHIBA, TOSHIHIKO;REEL/FRAME:011653/0962

Effective date: 20000107

AS Assignment

Owner name: TOKYO ELECTRON DEVICE LIMITED, JAPAN

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:TOKYO ELECTRON LIMITED;REEL/FRAME:012799/0963

Effective date: 20020328

CC Certificate of correction
CC Certificate of correction
FEPP Fee payment procedure

Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

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

REMI Maintenance fee reminder mailed
LAPS Lapse for failure to pay maintenance fees
STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20140604