IPC분류정보
국가/구분 |
United States(US) Patent
등록
|
국제특허분류(IPC7판) |
|
출원번호 |
US-0354513
(2012-01-20)
|
등록번호 |
US-9104548
(2015-08-11)
|
발명자
/ 주소 |
|
출원인 / 주소 |
- Blackbird Technology Holdings, Inc.
|
대리인 / 주소 |
McAndrews, Held & Malloy, Ltd.
|
인용정보 |
피인용 횟수 :
2 인용 특허 :
41 |
초록
▼
One or more circuits of a device may comprise a memory. A first portion of a first block of the memory may store program code and/or program data, a second portion of the first block may store an index associated with a second block of the memory, and a third portion of the first block may store an
One or more circuits of a device may comprise a memory. A first portion of a first block of the memory may store program code and/or program data, a second portion of the first block may store an index associated with a second block of the memory, and a third portion of the first block may store an indication of a write status of the first portion. Each bit of the third portion of the first block may indicate whether an attempt to write data to a corresponding one or more words of the first portion of the first block has failed since the last erase of the corresponding one or more words of the first portion of the first block. Whether data to be written to a particular virtual address is written to the first block or the second block may depend on the write status of the first block and the second block.
대표청구항
▼
1. A method comprising: performing by one or more circuits comprising memory, in response to an instruction to write data to said memory: if a first portion of a first block of said memory has been erased more recently than it has been written to, writing data to said first portion of said first blo
1. A method comprising: performing by one or more circuits comprising memory, in response to an instruction to write data to said memory: if a first portion of a first block of said memory has been erased more recently than it has been written to, writing data to said first portion of said first block of said memory without first erasing said first block of said memory;if said first portion of said first block of said memory has been written to more recently than it has been erased, and a first portion of a second block of said memory has been erased more recently than it has been written to, writing data to said first portion of said second block of memory without first erasing said second block of said memory; and if said first portion of said first block of said memory has been written to more recently than it has been erased, and said first portion of said second block of said memory has been written to more recently than it has been erased, recombining said first block of said memory and said second block of said memory and, subsequent to said recombining, writing said data to said first portion of said first block of said memory;storing an index associated with a said second block of said memory in said first block of said memory. 2. The method of claim 1, wherein said recombining said first block of said memory and said second block of said memory comprises: copying at least some of the contents of said first block of said memory to said second block of said memory;erasing said first block of said memory; andassociating an index with said second block of said memory, wherein said index was associated with said first block of said memory prior to said recombining. 3. The method of claim 1, comprising performing by said one or more circuits in response to said instruction to write said data to said memory: converting a virtual memory address of said instruction to an index associated with said first block of said memory. 4. The method of claim 3, comprising performing by said one or more circuits in response to said instruction to write said data to said memory: determining a physical address of said first block of said memory based on said index associated with said first block of said memory. 5. A method comprising: performing by one or more circuits comprising memory in response to an instruction to write said data to said memory: if a first portion of a first block of said memory has been erased more recently than it has been written to, writing data to said first portion of said first block of said memory without first erasing said first block of said memory;if said first portion of said first block of said memory has been written to more recently than it has been erased, and a first portion of a second block of said memory has been erased more recently than it has been written to, writing data to said first portion of said second block of memory without first erasing said second block of said memory;if said first portion of said first block of said memory has been written to more recently than it has been erased, and said first portion of said second block of said memory has been written to more recently than it has been erased, recombining said first block of said memory and said second block of said memory and, subsequent to said recombining, writing said data to said first portion of said first block of said memory;reading an index associated with said second block of said memory from said first block of said memory; anddetermining a physical address of said second block of said memory using said index of said second block of said memory. 6. The method of claim 1, wherein said memory is a NAND flash memory. 7. The method of claim 1, wherein erasing any memory cell of said first block of said memory requires erasing all memory cells of said first block of said memory. 8. The method of claim 1, wherein erasing any memory cell of said second block of said memory requires erasing all memory cells of said second block of said memory. 9. A system comprising: one or more circuits comprising a memory, wherein: a first portion of a first block of said memory stores program code and/or program data;a second portion of said first block of said memory stores an index associated with a second block of said memory; anda third portion of said first block of said memory stores an indication of a write status of said first portion of said first block of said memory;a first portion of said second block of said memory stores program code and/or program data;a second portion of said second block of said memory stores an index associated with said first block of said memory;a third portion of said second block of said memory stores an indication of a write status of said first portion of said second block of said memory. 10. The system of claim 9, wherein each bit of said third portion of said first block of said memory indicates whether an attempt to write data to a corresponding one or more words of said first portion of said first block of said memory has failed since the last erase of said corresponding one or more words of said first portion of said first block of said memory. 11. The system of claim 9, wherein said one or more circuits are operable to: receive an instruction to write data to said memory;write said data to a word of said first portion of said first block of said memory if said word of said first portion of said first block of said memory has been erased more recently than it has been written to; andwrite said data to a word of a first portion of said second block of said memory if said word of said first portion of said first block of said memory has been written to more recently than it has been erased. 12. The system of claim 9, wherein said one or more circuits are operable to: receive an instruction to write data to said memory;detect that (i) a word of said first portion of said first block of said memory has been written to more recently than it has been erased, and (ii) a word of said first portion of said second block of said memory has been written to more recently than it has been erased; andrecombine said first block of said memory and said second block of said memory in response to said detection. 13. The system of claim 12, wherein said recombining said first block of said memory and said second block of said memory comprises: copying at least some of the contents of said first block of said memory to said second block of said memory;erasing said first block of said memory; andassociating said second block of said memory with an index formerly associated with said first block of said memory. 14. The system of claim 13, wherein said recombining said first block of said memory and said second block of said memory comprises changing an index stored in said second portion of said second block of said memory. 15. The system of claim 14, wherein said index stored in said second portion of said second block of said memory is changed to an index associated with a third block of said memory. 16. The system of claim 14, wherein said index stored in said second portion of said second block of said memory is changed to an index formerly associated with said second block of said memory. 17. The system of claim 14, wherein said new index is randomly selected from a plurality of available indices. 18. The system of claim 9, wherein: said memory is a NAND flash memory; andsaid first block is located at a single, particular physical address of said NAND flash memory.
※ AI-Helper는 부적절한 답변을 할 수 있습니다.