Mask-Programmed Read-Only Memory with Reserved Space

Abstract
The present invention discloses a mask-ROM with reserved space (mask-ROMRS). For small content revision, the present invention salvages the original data-mask by writing the data-pattern of new content into a reserved mask-region which originally has no data-pattern.
Description
BACKGROUND

1. Technical Field of the Invention


The present invention relates to the field of integrated circuits, and more particularly to mask-programmed read-only memory (mask-ROM).


2. Prior Arts


For a mask-programmed read-only memory (mask-ROM), content is written using at least one data-mask during manufacturing process (step 10 of FIG. 1C). For example, a data-mask 2 comprises a plurality of mask-regions 2a-2i, whose patterns represent content data 4a-4i (FIG. 1A). Hereinafter, the pattern representing content data is referred to as data-pattern. Being permanently formed, the data-patterns cannot be modified once written onto the data-mask 2.


In prior art, whenever a new content needs to be included in a mask-ROM, a new data-mask 2x needs to be made to replace the original data-mask 2 (step 12 of FIG. 1C). For example, the new data-mask 2x includes the data-pattern of the new content 4e* in the mask-region 2e (FIG. 1B), as well as the data-patterns for the original contents 4a-4d, 4f-4i. The original and new contents 4a-4d, 4e*, 4f-4i are written to a second batch of mask-ROMs using the new data-mask 2x (step 14 of FIG. 1C).


As technology advances, data-mask becomes more and more expensive. For example, a 22 nm data-mask costs ˜$260 k. In addition, a data-mask contains more and more data. For example, a 22 nm data-mask contains up to ˜155 GB data. Some of these data will likely be revised at a future point of time. Replacing a whole data-mask for small data revision is costly. To overcome this and other drawbacks, the present invention discloses a mask-ROM with reserved space (mask-ROMRS).


OBJECTS AND ADVANTAGES

It is a principle object of the present invention to provide a mask-ROM that can economically accommodate small content revision.


It is a further object of the present invention to provide a mask-ROM which salvages the original data-mask for small content revision.


In accordance with these and other objects of the present invention, a mask-ROM with reserved space (mask-ROMRS) is disclosed.


SUMMARY OF THE INVENTION

The present invention discloses a mask-ROM with reserved space (mask-ROMRS). For small content revision, the present invention salvages the original data-mask instead of discarding it. On its original data-mask, at least one mask-region is reserved for a future new content and has no data-pattern. Being un-patterned, the reserved mask-region can be used to write the data-pattern of the new content. This differs from prior art. In prior art, because all mask-regions have been written, there is no un-patterned mask-region on the data-mask to write the data-pattern of the new content into.


The mask-ROMRS comprises first and second portions. In its original version, the first portion stores an original content, while its second portion stores no content and forms a reserved space. In its updated version, the second portion stores the new content. In the present invention, both the updated and the original mask-ROMRS use the same data-mask (although with revision), not two different data-masks. Because the original data-mask is salvaged instead of being discarded, little extra mask cost is incurred for small content revision. Here, small content revision means the amount of new content that is to be included at a future point of time is substantially less than the original contents.





BRIEF DESCRIPTION OF THE DRAWINGS


FIGS. 1A-1B illustrate original and new data-masks in prior art; FIG. 1C discloses a data-writing method to the original and new mask-ROMs in prior art;



FIGS. 2A-2B illustrate exemplary original and updated data-masks 6, 6*; FIG. 2C discloses a preferred data-writing method to the original and updated mask-ROMRS's;


FIGS. 3AA-3AB are different views of an original mask-ROMRS array 30; FIGS. 3BA-3BB are different views of an updated mask-ROMRS array 30*;



FIG. 4 is a circuit block diagram of a preferred mask-ROMRS;



FIG. 5A discloses an exemplary address-mapping table of an original mask-ROMRS; FIGS. 5B-5C disclose exemplary address-mapping tables of two updated mask-ROMRS's.





It should be noted that all the drawings are schematic and not drawn to scale. Relative dimensions and proportions of parts of the device structures in the figures have been shown exaggerated or reduced in size for the sake of clarity and convenience in the drawings. The same reference symbols are generally used to refer to corresponding or similar features in the different embodiments.


DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

Those of ordinary skills in the art will realize that the following description of the present invention is illustrative only and is not intended to be in any way limiting. Other embodiments of the invention will readily suggest themselves to such skilled persons from an examination of the within disclosure.


In this specification, the term “original” refers to the first version of the mask-ROM, which stores an initial collection of contents, i.e. original contents. The term “updated” refers to the second version of the mask-ROM, which stores a large portion of the original contents, plus at least a new content. The new content could be included as an additional content, which adds to the original contents; or as an upgrade content, which replaces an outdated content in the original contents.


In this specification, “content” can be broadly interpreted as a standalone content or a component thereof. Here, “standalone content” refers to information which, by itself, provides value for an end-user in specific context. A content could be a single file or a collection of files. One example of content is a multimedia content, including a textual content, an audio content, an image content (e.g. a digital map) and/or a video content (e.g. a movie, a TV program, a video game). Another example of content is a computer program, including an operating system, a computer software for computers and/or an application software for cellular phones.


The present invention discloses a mask-ROM with reserved space (mask-ROMRS). For small content revision, the present invention salvages the original data-mask instead of discarding it. On its original data-mask, at least one mask-region is reserved for a future new content and has no data-pattern. Being un-patterned, the reserved mask-region can be used to write the data-pattern of the new content. Here, small content revision means the amount of new content that is to be included at a future point of time is substantially less than the original contents.


Referring now to FIGS. 2A-2C, the original and updated data-masks used for a preferred mask-ROMRS and a preferred data-writing method are disclosed. The original data-mask 6 comprises a plurality of mask-regions 6a-6i (FIG. 2A). Most mask-regions 6a-6e, 6g-6i have data-patterns representing data for the original contents 8a-8e, 8g-8i. However, at least one mask-region 6f is reserved for at least a future new content and has no data-pattern. This mask-region 6f is blank, i.e. either all dark or all clear. The original contents 8a-8e, 8g-8i are written into a first batch of mask-ROMRS's (i.e. original mask-ROMRS's) using the original data-mask 6 (step 20 of FIG. 2C).


When a new content 8f needs to be included in an updated mask-ROMRS, the data-pattern representing this new content 8f is written to the reserved mask-region 6f (step 22 of FIG. 2C). As a result, the updated data-mask 6* contains the data-patterns representing the original contents 8a-8e, 8g-8i plus the new content 8f (FIG. 2B). These contents 8a-8e, 8f, 8g-8i are written into a second batch of mask-ROMRS's (i.e. updated mask-ROMRS's) using the updated data-mask 6* (step 24 of FIG. 2C). In the present invention, the first and second batches of mask-ROMRS's use the same data-mask 6 (although with revision), not two different data-masks 2 and 2x as in prior art. Because the original data-mask 6 is salvaged instead of being discarded, little extra mask cost is incurred for small content revision.


To make it economically feasible to salvage the original data-mask, the original contents should occupy a substantial portion of the original data-mask, preferably at least 50% of the original data-mask. On the other hand, when revising the original data-mask 6, it is crucial to write the data-pattern of the new content into an un-patterned mask-region 6f. This differs from prior art. In prior art, because all mask-regions have been written, there is no un-patterned mask-region on the data-mask to write the data-pattern of the new content into.


Referring now to FIGS. 3AA-3BB, an exemplary mask-ROMRS array in its original and updated versions is disclosed. The mask-ROMRS array 30 (or 30*) comprises a plurality of lower address lines (210a . . . ) and upper address line (230a . . . ) and mask-ROM cells. Each memory cell further comprises at least a data-layer 220, where the existence or absence of a contact via determines the digital state of the memory cell. Examples of the data-layer include an insulating dielectric or a resistive layer. The data-pattern of the data-layer is defined by the data-mask 6 (or 6*). For reason of simplicity, diodes, transistors and other memory components are not shown in FIGS. 3AA-3BB.


FIG. 3AA is a cross-sectional view of the original mask-ROMRS array 30 along the cut-line AA′ of FIG. 3AB; FIG. 3AB is a top view of the data-pattern 250 of the data-layer 220 in the original mask-ROMRS array 30 and its relative placement with respect to the address lines 210a . . . ; 230a . . . . The mask-ROMRS array 30 comprises a first portion 240A and a second portion 240B. The first portion 240A corresponds to the region 260A of the data-layer 250, which has data-patterns 220a-220c. Accordingly, the memory cells in the first portion 240A are associated with a plurality of data blocks. They store the original content and form the original data space. On the other hand, the second portion 240B corresponds to the region 260B of the data-layer 250, which has no data-pattern, or just an all-dark pattern 220x. Accordingly, the memory cells in the second portion 240B are associated with a plurality of empty blocks. They store no content and form a reserved space. Here, a “block” is the smallest allocation unit of a memory that can be addressed by a user (or, a host). A “data block” is a block whose data has been written, while an “empty block” is a block whose data has not been written. To make it economically feasible to salvage the original data-mask, the total number of the memory cells in the first portion 240A is more than the total number of the memory cells in the second portion 240B in this preferred embodiment.


Due to the rules governing memory allocation, slack space cannot be avoided in a mask-ROM. Although both contain empty blocks, slack space in prior art can be easily distinguished from the reserved space of the present invention. Because it is wasteful, prior art purposely minimizes slack space in a mask-ROM, generally to under 1% of the total memory space. In contrast, the present invention purposely includes a reserved mask-region associated with the reserved space to accommodate a future new content. To further distinguish the present invention from prior art, the reserved space is preferably more than 10% of the total memory space. Namely, the reserved mask-region preferably occupies at least 10% of the original data-mask. Because memory cells are uniformly distributed in a mask-region, this implies that the total number of the memory cells in the second portion 240B is roughly more than ˜10% of the total number of the memory cells in the first portion 240A.


FIG. 3BA is the cross-sectional view of the updated mask-ROMRS array 30* along the cut-line BB′ of FIG. 3BB; FIG. 3BB is the top view of the updated data-pattern 250* of the data-layer 220 and its relative placement with respect to the address lines 210a . . . ; 230a . . . . Here, the original data-patterns 220a-220c remain the same. However, updated data-patterns 220d, 220e representing the new content are written into the region 260B* of the data-layer 220. Accordingly, the memory cells in the second portion 240B* stores the new content.


Referring now to FIGS. 4-5C, a preferred mask-ROMRS 50 and its address-mapping tables are shown. As illustrated in FIG. 4, the preferred mask-ROMRS 50 includes an interface 52 for physically connecting to and electrically communicating with a variety of hosts. The interface 52 includes contacts 52x, 52y, 52a-52d which are coupled to corresponding contacts in a host receptacle. For example, the host provides a voltage supply VDD and a ground voltage VSS to the mask-ROMRS 50 through the power contact 52x and the ground contact 52y, respectively; the host further exchanges address/data with the mask-ROMRS 50 through signal contacts 52a-52b. Here, a host is an apparatus that directly uses the mask-ROMRS 50, and the address/data used by the host are logical address/data.


The preferred mask-ROMRS 50 comprises at least a mask-ROMRS array 30 and an address translator 38. The mask-ROMRS array 30 is similar to those disclosed in FIGS. 3AA-3BB. The address translator 38 converts logical addresses from the host to physical addresses of the mask-ROMRS array 30. Here, the logical addresses are represented on an internal bus 58, while the physical addresses are represented on an external bus 54 (including signals from contacts 52a-52d). The address translator 38 comprises a non-volatile memory (NVM) for storing an address mapping table 38, which maintains links between the logical addresses and the physical addresses. During read, upon receiving the logical address for the memory block to be read, the address translator 36 looks up the address mapping table and fetches the physical address corresponding to the logical address.


The preferred mask-ROMRS 50 could comprise a plurality of mask-ROMRS arrays. In addition, the mask-ROMRS 30 and the address translator 36 could be formed on separate dies or on a single die. When formed on separate dies, the mask-ROMRS array die and the address translator die could be vertically stacked or mounted side-by-side. They could form a multi-chip package (MCP) or a multi-chip module (MCM).



FIGS. 5A-5C disclose three exemplary address-mapping tables. Each address-mapping table comprises a plurality of entries. The addresses of these entries are logical addresses, while the data stored in these entries are physical addresses of the content data associated with the logical addresses. For example, the entry at logical address LA1 includes the physical address PA(8a) of at least one memory block storing at least a portion of the content 8a.


The first address-mapping table 38 in FIG. 5A is for an original mask-ROMRS 30. Data are written into the original mask-ROMRS 30 using the original data-mask 6 of FIG. 2A. The entries at logical addresses LA1-LA8 include the physical addresses for the contents 8a-8e, 8g-8i, respectively.


The second address-mapping table 38* in FIG. 5B is for a first preferred updated mask-ROMRS 30*. Data are written into this updated mask-ROMRS 30* using the updated data-mask 6* of FIG. 2B. In this updated mask-ROMRS 30*, a new content 8f is added to the original content. Accordingly, a new entry is added to the logical address LA9 of the address-mapping table 38*. It contains the physical address PA(8f) for the content 8f. To add new entries, the NVM storing the address-mapping table 38* is preferably a writable memory, which can be programmed at least once. One example of the writable memory is an antifuse-based memory, or a flash memory.


The third address-mapping table 38** in FIG. 5C is for a second preferred updated mask-ROMRS 30*. Data are written into this updated mask-ROMRS 30* using the updated data-mask 6* of FIG. 2B. In this updated mask-ROMRS 30*, an upgrade content 8f is included to replace an outdated content 8e. Accordingly, the entry PA(8e) at LA5 is replaced by the physical address(es) PA(8f) for the content 8f. In other words, the address-mapping table 38** does not contain the physical address(es) of the outdated content 8e. To replace entries, the NVM storing the address-mapping table 38** is preferably a re-writable memory, which can be programmed many times. One example of the re-writable memory is a flash memory.


In the updated mask-ROMRS 30* of FIG. 5C, contents 8a-8d, 8g-8i are not replaced by any upgrade contents. They are referred to as permanent contents. To make it economically feasible to salvage the original data-mask, a substantial portion of the original data-mask should represent the permanent contents. In other words, the memory cells storing the permanent contents should be more than the memory cells storing the outdated content or the upgrade content, as is reflected in FIG. 5C.


While illustrative embodiments have been shown and described, it would be apparent to those skilled in the art that may more modifications than that have been mentioned above are possible without departing from the inventive concepts set forth therein. The invention, therefore, is not to be limited except in the spirit of the appended claims.

Claims
  • 1. A mask-programmed read-only memory (mask-ROM), comprising: a plurality of first mask-ROM cells associated with a plurality of data blocks, each of said first mask-ROM cells comprising a data-layer, wherein said data-layer in said first mask-ROM cells has at least a data-pattern;a plurality of second mask-ROM cells associated with a plurality of empty blocks, each of said second mask-ROM cells comprising said data-layer, wherein said data-layer in said second mask-ROM cells has no data-pattern;wherein the total number of said second mask-ROM cells is more than 10% of the total number of said first mask-ROM cells.
  • 2. The mask-ROM according to claim 1, wherein the total number of said first mask-ROM cells is more than 50% of the total number of mask-ROM cells in said mask-ROM.
  • 3. The mask-ROM according to claim 1, further comprising an address translator for translating logical addresses from a host to physical addresses of said first mask-ROM cells.
  • 4. The mask-ROM according to claim 3, wherein said address translator comprises a non-volatile memory for storing an address-mapping table.
  • 5. The mask-ROM according to claim 4, wherein said non-volatile memory is a writable memory.
  • 6. The mask-ROM according to claim 4, wherein said non-volatile memory is a re-writable memory.
  • 7. The mask-ROM according to claim 6, wherein said re-writable memory is a flash memory.
  • 8. The mask-ROM according to claim 1, wherein said data-pattern of said data-layer in said first mask-ROM cells represent at least a multimedia content.
  • 9. The mask-ROM according to claim 1, wherein said data-pattern of said data-layer in said first mask-ROM cells represent at least a computer program.
  • 10. The mask-ROM according to claim 1, wherein said data-pattern of said data-layer in said first mask-ROM cells represent at least one of a textual content, an audio content, an image content, a video content, an operating system, a computer software and an application software.
  • 11. A mask-programmed read-only memory (mask-ROM), comprising: a plurality of first mask-ROM cells, each of said first mask-ROM cells comprising a data-layer, the data-pattern of said data-layer in said first mask-ROM cells representing data in an original version of a first file;a plurality of second mask-ROM cells, each of said second mask-ROM cells comprising said data-layer, the data-pattern of said data-layer in said second mask-ROM cells representing data in an updated version of said first file;a plurality of third mask-ROM cells, each of said third mask-ROM cells comprising said data-layer, the data-pattern of said data-layer in said third mask-ROM cells representing data of at least a second file, wherein said mask-ROM does not store another version of said second file;an address translator comprising a non-volatile memory for storing an address-mapping table, wherein said address-mapping table contains physical addresses of said second mask-ROM cells and said third mask-ROM cells.
  • 12. The mask-ROM according to claim 11, wherein said address-mapping table does not contain physical addresses of said first mask-ROM cells.
  • 13. The mask-ROM according to claim 11, wherein the total number of said third mask-ROM cells is substantially more than the total number of said first or second mask-ROM cells.
  • 14. The mask-ROM according to claim 11, wherein the total number of said third mask-ROM cells is more than 50% of the total number of the mask-ROM cells in said mask-ROM.
  • 15. The mask-ROM according to claim 11, wherein said non-volatile memory is a writable memory.
  • 16. The mask-ROM according to claim 11, wherein said non-volatile memory is a re-writable memory.
  • 17. The mask-ROM according to claim 16, wherein said re-writable memory is a flash memory.
  • 18. The mask-ROM according to claim 11, wherein said first or second file is at least a component of a multimedia content.
  • 19. The mask-ROM according to claim 11, wherein said first or second file is a component of a computer program.
  • 20. The mask-ROM according to claim 11, wherein said first or second file is at least a component of at least one of a textual content, an audio content, an image content, a video content, an operating system, a computer software and an application software.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation-in-part of U.S. patent application Ser. No. 13/396,596, “Mask-Programmable Memory with Reserved Space”, filed Feb. 14, 2012, which is a continuation-in-part of U.S. patent application Ser. No. 12/883,172, “Three-Dimensional Mask-Programmable Memory with Reserved Space”, filed Sep. 15, 2010, which is a continuation-in-part of U.S. patent application Ser. No. 11/736,773, “Mask-Programmable Memory with Reserved Space”, filed Apr. 18, 2007, which is a non-provisional application of a U.S. patent application Ser. No. 60/884,618, “Mask-Programmable Memory with Reserved Space”, filed Jan. 11, 2007.

Provisional Applications (1)
Number Date Country
60884618 Jan 2007 US
Continuation in Parts (3)
Number Date Country
Parent 13396596 Feb 2012 US
Child 13846928 US
Parent 12883172 Sep 2010 US
Child 13396596 US
Parent 11736773 Apr 2007 US
Child 12883172 US