The present disclosure relates generally to semiconductor memory devices, methods, and systems, and more particularly, to boot partitions in memory devices and systems
Memory devices are typically provided as internal, semiconductor, integrated circuits and/or external removable devices in computers and other electronic devices. There are many different types of memory including random-access memory (RAM), read only memory (ROM), dynamic random access memory (DRAM), synchronous dynamic random access memory (SDRAM), phase change random access memory (PCRAM), and flash memory, among others.
Flash memory devices can be utilized as volatile and non-volatile memory for a wide range of electronic applications. Flash memory devices typically use a one-transistor memory cell that allows for high memory densities, high reliability, and low power consumption. Uses for flash memory include memory for solid state drives (SSDs), personal computers, personal digital assistants (PDAs), digital cameras, cellular telephones, portable music players, e.g., MP3 players, and movie players, among other electronic devices. Data, such as program code, user data, and/or system data, such as a basic input/output system (BIOS), are typically stored in flash memory devices.
Two common types of flash memory array architectures are the “NAND” and “NOR” architectures, so called for the logical form in which the basic memory cell configuration of each is arranged. A NAND array architecture arranges its array of memory cells in a matrix such that the control gates of each memory cell in a “row” of the array are coupled to (and in some cases form) an access line, which is commonly referred to in the art as a “word line”. However each memory cell is not directly coupled to a data line (which is commonly referred to as a digit line, e.g., a bit line, in the art) by its drain. Instead, the memory cells of the array are coupled together in series, source to drain, between a common source and a data line, where the memory cells commonly coupled to a particular data line are referred to as a “column”.
Memory cells in a NAND array architecture can be programmed to a desired state. For example, electric charge can be placed on or removed from a charge storage node of a memory cell to put the cell into one of a number of programmed states. For example, a single level cell (SLC) can represent two states, e.g., 1 or 0. Flash memory cells can also store more than two states, e.g., 1111, 0111, 0011, 1011, 1001, 0001, 0101, 1101, 1100, 0100, 0000, 1000, 1010, 0010, 0110, and 1110. Such cells can be referred to as multilevel cells (MLCs). MLCs can allow the manufacture of higher density memories without increasing the number of memory cells since each cell can represent more than one digit, e.g., more than one bit. For example, a cell capable of representing four digits can have sixteen programmed states.
A memory system can include a host, such as a computer, and various types of memory used in various combinations to provide memory for the host. For example, a memory system can include a host and an external memory device coupled to the host. The external memory device can be, for example, a flash memory device. Additionally, the external memory device can be a removable memory device coupled to the host through an interface, such as a USB connection, for example.
The external memory device can include, e.g., store, system boot code used to boot the memory system. For example, responsive to a booting event of the memory system, the boot code, e.g., data representing the boot code, can be loaded from the external memory device to the host, and the host can use the boot code to boot the memory system. However, the boot code stored in the memory device may be visible to a user of the host.
The present disclosure includes boot partitions in memory devices and systems, and methods associated therewith. One or more embodiments include an array of memory cells, wherein the array includes a boot partition and a number of additional partitions. Sequential logical unit identifiers are associated with the additional partitions, and a logical unit identifier that is not in sequence with the sequential logical unit identifiers is associated with the boot partition.
Embodiments of the present disclosure can prevent a user from viewing a boot partition, e.g., boot code, included, e.g., stored, in a memory device. For example, the boot partition in the memory device may not be visible to a user of a host coupled to the memory device. That is, the boot partition may be hidden from the user.
In the following detailed description of the present disclosure, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration how a number of embodiments of the disclosure may be practiced. These embodiments are described in sufficient detail to enable those of ordinary skill in the art to practice the embodiments of this disclosure, and it is to be understood that other embodiments may be utilized and that process, electrical, and/or structural changes may be made without departing from the scope of the present disclosure.
As used herein, “a number of” something can refer to one or more such things. For example, a number of memory devices can refer to one or more memory devices. Additionally, the designators “B”, “P”, “R”, and “S” as used herein, particularly with respect to reference numerals in the drawings, indicates that a number of the particular feature so designated can be included with a number of embodiments of the present disclosure.
The figures herein follow a numbering convention in which the first digit or digits correspond to the drawing figure number and the remaining digits identify an element or component in the drawing. Similar elements or components between different figures may be identified by the use of similar digits. For example, 232 may reference element “32” in
As shown in
In the example shown in
As shown in
As one of ordinary skill in the art will appreciate, each row 120-0, 120-1, . . . , 120-R can include, e.g., store, one or more physical pages of data. A physical page refers to a unit of programming and/or sensing, e.g., a number of cells that are programmed and/or sensed together as a functional group of memory cells. In the embodiment shown in
In one or more embodiments of the present disclosure, and as shown in
As one of ordinary skill in the art will appreciate, logical block addressing is a scheme that can be used by a host for identifying a logical sector of data. For example, each logical sector can correspond to a unique logical block address (LBA). Additionally, an LBA may also correspond to a physical address. As an example, a logical sector of data can be a number of bytes of data, e.g., 256 bytes, 512 bytes, or 1,024 bytes. However, embodiments are not limited to these examples.
In one or more embodiments of the present disclosure, a number of LBAs can correspond to a logical unit. That is, a logical unit can include a number of LBAs, e.g., a number of logical sectors of data. Additionally, in one or more embodiments, a logical unit can be associated with one or more logical partitions. For example, a particular logical unit can correspond to a particular logical partition. Additionally, a logical unit can be a subdivision of a logical partition, e.g., a logical partition can include two or more logical units. Alternatively, a logical partition can be a subdivision of a logical unit, e.g., a logical unit can include two or more logical partitions.
It is noted that other configurations for the physical blocks 116-0, 116-1, . . . , 116-B, rows 120-0, 120-1, . . . , 120-R, sectors 122-0, 122-1, . . . , 122-S, and pages are possible. For example, rows 120-0, 120-1, . . . , 120-R of physical blocks 116-0, 116-1, . . . , 116-B can each store data corresponding to a single logical sector which can include, for example, more or less than 512 bytes of data.
As shown in
As shown in
Boot partition 236 and/or additional partitions 238-0, 238-1, . . . 238-P can be physical partitions, e.g., one or more physical blocks, rows, pages, or sectors, as previously described herein. Boot partition 236 and/or additional partitions 238-0, 238-1, . . . , 238-P can also be logical partitions. For example, boot partition 236 and/or additional partitions 238-0, 238-1, . . . , 238-P can each correspond to a particular logical unit, boot partition 236 and/or additional partitions 238-0, 238-1, . . . , 238-P can be subdivisions of logical units, and/or logical units can be subdivisions of boot partition 236 and/or additional partitions 238-0, 238-1, . . . , 238-P, as previously described herein.
A boot partition, as used herein, can be a physical or logical partition in a memory array that includes boot code for a memory system that is executable by a host in the memory system. For example, boot partition 236 can include boot code for a memory system, such as memory system 350 described in connection with
In embodiments in which memory array 200 includes more than one boot partition, the boot partitions can include different boot code for the memory system. For example, a first partition can include a first version of boot code, a second partition can include a second version of boot code that is different than the first version, a third partition can include a third version of boot code that is different than the first and second versions, etc. Additionally, the boot partitions can include identical boot code for the memory system. For example, one of the boot partitions can include particular boot code, and the other boot partitions can include duplicate copies of the particular boot code, e.g., for redundancy.
Additional partitions 238-0, 238-1, . . . , 238-P can be non-boot partitions, e.g., partitions that do not include boot code and/or are not used during a booting operation. Rather, additional partitions 238-0, 238-1, . . . , 238-P can be partitions that are used during programming, sensing, and/or erase operations performed on memory device 232. That is, additional partitions 238-0, 238-1, . . . 238-P can store data associated with programming, sensing, and/or erase operations performed on memory device 232.
As shown in
For example, control circuitry 234 can be configured to assign, in a configuration descriptor list, a unique logical unit identifier, e.g., a unique logical unit number (LUN), to boot partition 236 and a unique logical unit identifier, e.g., a unique LUN, to each additional partition 238-0, 238-1, . . . , 238-P. The LUNs can be associated with, e.g., assigned to, boot partition 236 and additional partitions 238-0, 238-1, . . . , 238-P during manufacture and/or operation of memory device 232.
The LUN associated with boot partition 236 can be a default LUN that has been pre-assigned to boot partition 236. That is, a particular LUN can be pre-assigned as the default LUN to be associated with, e.g., assigned to, boot partition 236, and control circuitry 234 can be configured to assign the particular LUN to boot partition 236.
The LUNs associated with additional partitions 238-0, 238-1, . . . 238-P can be sequential LUNs and/or can be within a range of LUNs. The LUN associated with boot partition 236 may not be in sequence with the sequential LUNs associated with additional partitions 238-0, 238-1, . . . , 238-P. Additionally, the LUN associated with boot partition 236 can be outside the range of LUNs associated with additional partitions 238-0, 238-1, . . . , 238-P. Further, the LUN associated with boot partition 236 can be larger than each of the LUNs associated with additional partitions 238-0, 238-1, . . . , 238-P. For example, the sequence and/or range of LUNs associated with additional partitions 238-0, 238-1, . . . , 238-P can include all integers from 0 to N−1, inclusive, wherein N is equal to the number of additional partitions 238-0, 238-1, . . . , 238-P, and the LUN associated with boot partition 236 may be outside this sequence and/or range, e.g., the LUN associated with boot partition 236 can be larger than N. For instance, if the number of additional partitions is eight, the sequence and/or range of LUNs associated with the additional partitions can be LUN [0], LUN [1], . . . , LUN [7], and the LUN associated with the boot partition can be LUN [X], wherein X is outside this sequence and/or range, e.g., LUN [99].
Associating a LUN with boot partition 236 that is not in sequence with and/or outside the range of the LUNs associated with additional partitions 238-0, 238-1, . . . , 238-P in accordance with one or more embodiments of the present disclosure can prevent a user from viewing a boot partition 236, e.g., the boot code associated with boot partition 236. For example, boot partition 236 may not be visible to a user of a host, such as host 352 described in connection with
The embodiment illustrated in
As shown in
Host 352 can be a computing device, such as a personal computer, among other computing device types. Examples of host 352 include laptop computers, personal computers, mobile phones, digital cameras, digital recording and play back devices, PDA's, memory card readers, and interface hubs, among other examples. Host 352 can include a single monolithic chip, multiple chips in a single package and/or module, and/or a combination of packages and/or modules on a printed circuit board.
As shown in
Port 354 can be a hardware port. A hardware port can be used to couple a hardware device to host 352. For example, a hardware port can be used to couple a peripheral device, such as a digital camera, an MP3 player, a network device, and/or USB device, among other devices, to host 352. A hardware port can also be used to couple a media codec to host 352 for play-back of audio and/or video. The coupling of a hardware device to host 352 via port 354 can allow the hardware device to communicate with memory device 332, host memory 360, and/or other memory in host 352. Communication can include, for example, reading, writing, and/or erasing data to and/or from the hardware devices, memory device 332, and/or the memory on or coupled to host 352.
Host controller 356 can be used to communicate information between host 352 and memory device 332, e.g., to communicate information from host 352 to memory device 332 and to communicate information from memory device 332 to host 352. For example, host controller 356 can be coupled to implement a standardized interface (not shown) for passing control, address, data, instructions, commands, and other signals between host 352, e.g., host processor 358, and memory device 332. Additionally, when memory device 332 is used for data storage for memory system 350, host controller 356 can implement a serial advanced technology attachment (SATA), a peripheral component interconnect express (PCIe), a universal serial bus (USB), a small computer system interface (SCSI), and/or a universal flash storage (UFS), among other interfaces.
Memory device 332 can include a boot partition that includes boot code for memory system 350, and a number of additional, e.g., non-boot, partitions, as previously described herein. The additional partitions can have sequential and/or a range of logical unit identifiers, e.g., logical unit numbers (LUNs), associated therewith, and the boot partition can have a logical unit identifier, e.g., a logical unit number (LUN), associated therewith that is not in sequence with and/or is outside the range of the logical unit identifiers, e.g., LUNs, associated with the additional partitions, as previously described herein.
Host 352 can be configured to select the boot partition that includes boot code for memory system 350. Memory device 332, e.g., control circuitry in memory device 332, can be configured to associate the LUN with, e.g., assign the LUN to, the boot partition responsive to the selection of the boot partition by host 352.
Host 352 can be aware of the LUN associated with the boot partition. For example, the LUN associated with the boot partition can be stored in host memory 360, and/or the LUN associated with the boot partition can be known to host processor 358. Additionally, the LUN associated with the boot partition can be a default LUN that has been pre-assigned to the boot partition, as previously described herein. However, the boot partition, e.g., the boot code associated with the boot partition, may not be visible to a user of host 352, as previously described herein.
Host 352 can use the boot code to boot memory system 350, e.g., host 352 and/or memory device 332, responsive to an event of memory system 350. For example, responsive to an event of memory system 350, host processor 358 can use the LUN associated with the boot partition to access, e.g., load, the boot code, e.g., data representing the boot code, from memory device 332 through host controller 356. As used herein, “an event” of a memory system can include a booting event of the memory system, such as a power-on and/or a reset of the memory system, among other examples.
For example, responsive to an event of memory system 350, host processor 358 can execute an instruction, e.g., a specific data sequence and/or reference clock, to send a boot command, e.g., a boot code read command, to memory device 332 through host controller 356. The boot command can be addressed to the LUN associated with the boot partition, e.g., the boot command can include the LUN associated with the boot partition. The boot command can also include a header that identifies the command as a boot command. Responsive to receiving the boot command, memory device 332 can send the boot code, e.g., data representing the boot code, to host 352. The data can include a header that identifies the data as boot code data. Responsive to receiving the boot code, host processor 358 can execute the boot code to boot memory system 350.
The present disclosure includes boot partitions in memory devices and systems, and methods associated therewith. One or more embodiments include an array of memory cells, wherein the array includes a boot partition and a number of additional partitions. Sequential logical unit identifiers are associated with the additional partitions, and a logical unit identifier that is not in sequence with the sequential logical unit identifiers is associated with the boot partition.
Although specific embodiments have been illustrated and described herein, those of ordinary skill in the art will appreciate that an arrangement calculated to achieve the same results can be substituted for the specific embodiments shown. This disclosure is intended to cover adaptations or variations of a number of embodiments of the present disclosure. It is to be understood that the above description has been made in an illustrative fashion, and not a restrictive one. Combination of the above embodiments, and other embodiments not specifically described herein will be apparent to those of skill in the art upon reviewing the above description. The scope of a number of embodiments of the present disclosure includes other applications in which the above structures and methods are used. Therefore, the scope of a number of embodiments of the present disclosure should be determined with reference to the appended claims, along with the full range of equivalents to which such claims are entitled.
In the foregoing Detailed Description, some features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the disclosed embodiments of the present disclosure have to use more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus, the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate embodiment.
Number | Name | Date | Kind |
---|---|---|---|
5450576 | Kennedy | Sep 1995 | A |
5555540 | Radke | Sep 1996 | A |
5659748 | Kennedy | Aug 1997 | A |
5751699 | Radke | May 1998 | A |
5835784 | Gillespie et al. | Nov 1998 | A |
6295575 | Blumenau et al. | Sep 2001 | B1 |
6301657 | Jones et al. | Oct 2001 | B1 |
6370645 | Lee | Apr 2002 | B1 |
6430687 | Aguilar et al. | Aug 2002 | B1 |
6484229 | Ichikawa et al. | Nov 2002 | B1 |
6484245 | Sanada et al. | Nov 2002 | B1 |
6646646 | Peterson et al. | Nov 2003 | B2 |
6715031 | Camble et al. | Mar 2004 | B2 |
6734865 | Peterson et al. | May 2004 | B1 |
6741253 | Radke et al. | May 2004 | B2 |
6766351 | Datla | Jul 2004 | B1 |
6784889 | Radke | Aug 2004 | B1 |
6791555 | Radke et al. | Sep 2004 | B1 |
6816165 | Radke | Nov 2004 | B1 |
6816750 | Klaas | Nov 2004 | B1 |
6856529 | Radke | Feb 2005 | B1 |
6956577 | Radke et al. | Oct 2005 | B2 |
6963343 | Peterson et al. | Nov 2005 | B1 |
7006377 | Oh | Feb 2006 | B2 |
7024551 | King et al. | Apr 2006 | B2 |
7032106 | Horanzy et al. | Apr 2006 | B2 |
7073013 | Lasser | Jul 2006 | B2 |
7139182 | Radke | Nov 2006 | B2 |
7180522 | Radke et al. | Feb 2007 | B2 |
7206832 | Matsunami et al. | Apr 2007 | B2 |
7222230 | Hsu | May 2007 | B2 |
7231643 | Galbo et al. | Jun 2007 | B1 |
7234052 | Lee et al. | Jun 2007 | B2 |
7237105 | Fujita et al. | Jun 2007 | B2 |
7284084 | Atherton et al. | Oct 2007 | B2 |
7296143 | Gaskins et al. | Nov 2007 | B2 |
7322002 | Keays et al. | Jan 2008 | B2 |
7369434 | Radke | May 2008 | B2 |
7379068 | Radke | May 2008 | B2 |
7389465 | Radke et al. | Jun 2008 | B2 |
7397477 | Radke | Jul 2008 | B2 |
7409672 | Datla | Aug 2008 | B1 |
7444543 | Babudri et al. | Oct 2008 | B2 |
7444579 | Radke et al. | Oct 2008 | B2 |
7453723 | Radke | Nov 2008 | B2 |
7467417 | Stillerman et al. | Dec 2008 | B2 |
7493484 | Lee | Feb 2009 | B2 |
7496719 | Peterson et al. | Feb 2009 | B2 |
7499902 | Datla et al. | Mar 2009 | B2 |
7512909 | Radke | Mar 2009 | B2 |
7594063 | Estakhri et al. | Sep 2009 | B1 |
8082435 | Ugokwe | Dec 2011 | B2 |
20020070941 | Peterson et al. | Jun 2002 | A1 |
20030067472 | Radke et al. | Apr 2003 | A1 |
20030233533 | Avraham | Dec 2003 | A1 |
20040183808 | Radke et al. | Sep 2004 | A1 |
20050024367 | Radke | Feb 2005 | A1 |
20050030313 | Radke et al. | Feb 2005 | A1 |
20050052889 | Radke | Mar 2005 | A1 |
20050128208 | Radke | Jun 2005 | A1 |
20050152288 | Datla et al. | Jul 2005 | A1 |
20050169030 | Radke | Aug 2005 | A1 |
20050172207 | Radke et al. | Aug 2005 | A1 |
20050195738 | Datla et al. | Sep 2005 | A1 |
20050268077 | Kuan et al. | Dec 2005 | A1 |
20050268203 | Keays et al. | Dec 2005 | A1 |
20050273851 | Raju Datla et al. | Dec 2005 | A1 |
20060004742 | Datla et al. | Jan 2006 | A1 |
20060007944 | Movassaghi et al. | Jan 2006 | A1 |
20060010282 | Kim | Jan 2006 | A1 |
20060012393 | Raju Datla et al. | Jan 2006 | A1 |
20060013217 | Datla et al. | Jan 2006 | A1 |
20060015591 | Datla et al. | Jan 2006 | A1 |
20060064575 | Jo | Mar 2006 | A1 |
20060075395 | Lee et al. | Apr 2006 | A1 |
20060143368 | Lasser et al. | Jun 2006 | A1 |
20060161725 | Lee et al. | Jul 2006 | A1 |
20060179302 | Hatakeyama | Aug 2006 | A1 |
20060203529 | Radke | Sep 2006 | A1 |
20060245274 | Choi et al. | Nov 2006 | A1 |
20060248434 | Radke et al. | Nov 2006 | A1 |
20070028083 | Yu et al. | Feb 2007 | A1 |
20070028084 | Yu et al. | Feb 2007 | A1 |
20070113067 | Oh et al. | May 2007 | A1 |
20070162824 | Radke et al. | Jul 2007 | A1 |
20070180223 | Tanaka | Aug 2007 | A1 |
20070180291 | Galbo et al. | Aug 2007 | A1 |
20070192529 | Roh et al. | Aug 2007 | A1 |
20070206434 | Radke | Sep 2007 | A1 |
20070220247 | Lee et al. | Sep 2007 | A1 |
20070226592 | Radke | Sep 2007 | A1 |
20070233955 | Luo et al. | Oct 2007 | A1 |
20070250693 | Lin et al. | Oct 2007 | A1 |
20070253384 | Kanagala et al. | Nov 2007 | A1 |
20070254710 | Kanagala et al. | Nov 2007 | A1 |
20070260869 | Dade et al. | Nov 2007 | A1 |
20070283140 | Jones et al. | Dec 2007 | A1 |
20080037320 | Radke | Feb 2008 | A1 |
20080040596 | Mai et al. | Feb 2008 | A1 |
20080040598 | Lee et al. | Feb 2008 | A1 |
20080046711 | Tung et al. | Feb 2008 | A1 |
20080056027 | Radke | Mar 2008 | A1 |
20080072120 | Radke | Mar 2008 | A1 |
20080082814 | Kuo et al. | Apr 2008 | A1 |
20080086631 | Chow et al. | Apr 2008 | A1 |
20080092017 | Keays et al. | Apr 2008 | A1 |
20080098164 | Lee et al. | Apr 2008 | A1 |
20080147964 | Chow et al. | Jun 2008 | A1 |
20080155130 | Mosek | Jun 2008 | A1 |
20080172554 | Armstrong et al. | Jul 2008 | A1 |
20080184094 | Murray et al. | Jul 2008 | A1 |
20080215870 | Liew | Sep 2008 | A1 |
20080215930 | Radke | Sep 2008 | A1 |
20080218525 | Radke | Sep 2008 | A1 |
20080266306 | Radke | Oct 2008 | A1 |
20090013233 | Radke | Jan 2009 | A1 |
20090013234 | Radke | Jan 2009 | A1 |
20090019321 | Radke | Jan 2009 | A1 |
20090019340 | Radke et al. | Jan 2009 | A1 |
20090055639 | Kuusilinna et al. | Feb 2009 | A1 |
20090055697 | Radke et al. | Feb 2009 | A1 |
20090067249 | Radke | Mar 2009 | A1 |
20090089534 | Zohar et al. | Apr 2009 | A1 |
20090103362 | Pekny et al. | Apr 2009 | A1 |
20090103380 | Pekny et al. | Apr 2009 | A1 |
20090109747 | Radke | Apr 2009 | A1 |
20090122989 | Asnaashari et al. | May 2009 | A1 |
20090129169 | Roohparvar et al. | May 2009 | A1 |
20090132755 | Radke | May 2009 | A1 |
20090132889 | Radke | May 2009 | A1 |
20090172321 | Scheuerlein et al. | Jul 2009 | A1 |
20090198880 | Radke | Aug 2009 | A1 |
20090248952 | Radke et al. | Oct 2009 | A1 |
20090271214 | Kandasamy et al. | Oct 2009 | A1 |
20090271351 | Kandasamy et al. | Oct 2009 | A1 |
20090276545 | Lee et al. | Nov 2009 | A1 |
20090300269 | Radke et al. | Dec 2009 | A1 |
20090327595 | Estakhri et al. | Dec 2009 | A1 |
Entry |
---|
International Search Report and Written Opinion for related PCT Patent Application No. PCT/US2011/000651 dated Nov. 30, 2011 (9 pp.). |
Number | Date | Country | |
---|---|---|---|
20110258425 A1 | Oct 2011 | US |