Memory with on-die data transfer
US-2020411081-A1 · Dec 31, 2020 · US
US12487952B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-12487952-B2 |
| Application number | US-202418936668-A |
| Country | US |
| Kind code | B2 |
| Filing date | Nov 4, 2024 |
| Priority date | Apr 29, 2024 |
| Publication date | Dec 2, 2025 |
| Grant date | Dec 2, 2025 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
Provided is a method for shifting data within a memory, which is performed by a direct memory access (DMA) controller, and which includes receiving a task associated with an operation of shifting target data stored in a first area of a memory connected to the DMA controller to a second area of the memory, receiving the target data from the memory, determining a priority of each of a plurality of data items divided from the target data based on an address of the first area and an address of the second area, generating a plurality of write requests corresponding to the plurality of data items, and transmitting the plurality of generated write requests sequentially to a memory controller associated with the memory, so that the plurality of data items are stored in the second area in sequence according to the determined priority.
Opening claim text (preview).
The invention claimed is: 1 . A method for shifting data within a memory, the method being performed by a direct memory access (DMA) controller and comprising: receiving a task that requires an operation of shifting target data stored in a first area of a memory connected to the DMA controller to a second area of the memory, wherein the second area partially overlaps with the first area; receiving the target data from the memory; determining, based on an address of the first area compared to an address of the second area, a priority from a highest priority to a lowest priority for each of a plurality of data items divided from the target data; generating a plurality of write requests corresponding to the plurality of data items; and transmitting the plurality of write requests sequentially to a memory controller associated with the memory, so that the plurality of data items are stored in the second area in sequence from the highest priority to the lowest priority according to the determined priority for each of the plurality of data items, wherein at least one data item in the plurality of data items is stored in an area that overlaps with the first area. 2 . The method according to claim 1 , wherein the memory controller is configured to sequentially store in the second area, in response to sequentially receiving the plurality of write requests from the DMA controller, the plurality of data items corresponding to the plurality of write requests. 3 . The method according to claim 1 , wherein the generating the plurality of write requests comprises sequentially generating the plurality of write requests according to the determined priority such that a first write request for a first data item with a higher priority is transmitted prior to a second write request for a second data item with a lower priority than the first data item. 4 . The method according to claim 3 , wherein the generating the plurality of write requests comprises: withholding, in response to receiving the second data item before receiving the first data item, generation of the second write request; and generating, in response to transmitting all write requests associated with data items having higher priorities than the first data item to the memory controller and to receiving the first data item, the first write request. 5 . The method according to claim 1 , wherein each of the plurality of data items is stored in a respective one of a plurality of sub-areas in the first area, and in response to an address of the second area being higher than an address of the first area, the higher an address of a respective one sub-area of the plurality of sub-areas in the first area is, the higher priority is assigned to a data item stored in the respective one sub-area, wherein a higher address is an address further from a starting point of a memory space and a lower address is an address closer to the starting point of the memory space. 6 . The method according to claim 1 , wherein each of the plurality of data items is stored in a respective one of a plurality of sub-areas in the first area, and in response to an address of the second area being lower than an address of the first area, the lower an address of a respective one sub-area of the plurality of sub-areas in the first area is, the higher priority is assigned to a data item stored in the respective one sub-area, wherein a lower address is an address closer to a starting point of a memory space and a higher address is an address further from the starting point of the memory space. 7 . The method according to claim 1 , wherein the generating the plurality of write requests comprises calculating address information of a plurality of sub-areas in the second area where the plurality of data items are to be stored, and each of the plurality of write requests comprises address information of each of the plurality of sub-areas. 8 . The method according to claim 1 , wherein the transmitting the plurality of write requests comprises transmitting, in response to a first condition, each of the plurality of write requests to the memory controller, the first condition is that a read of an area where a data item corresponding to each of the plurality of write requests is to be stored is completed. 9 . The method according to claim 1 , wherein the receiving the target data comprises: generating a plurality of read requests associated with the plurality of data items; transmitting the plurality of generated read requests to the memory controller; and receiving the plurality of data items corresponding to the plurality of read requests from the memory controller. 10 . The method according to claim 9 , wherein the transmitting the plurality of read requests comprises sequentially transmitting the plurality of generated read requests to the memory controller, so that the plurality of data items are read from the first area according to the determined priority, and the receiving the plurality of data items comprises receiving the plurality of data items in sequence according to the determined priority. 11 . The method according to claim 9 , wherein the receiving the plurality of data items comprises receiving the plurality of data items in sequence independent of the priority of each of the plurality of data items. 12 . The method according to claim 9 , wherein the generating the plurality of read requests comprises generating the plurality of read requests in sequence according to the determined priority. 13 . The method according to claim 9 , wherein the generating the plurality of read requests comprises calculating address information of a plurality of sub-areas in the first area where the plurality of data items are stored, and each of the plurality of read requests comprises address information of each of the plurality of sub-areas. 14 . A memory system, comprising: a direct memory access (DMA) controller; a memory connected to the DMA controller; and a memory controller associated with the memory, wherein the DMA controller is configured to: receive a task that requires an operation of shifting a target data stored in a first area of the memory to a second area of the memory, wherein the second area partially overlaps with the first area; receive the target data from the memory; determine, based on an address of the first area compared to an address of the second area, a priority from a highest priority to a lowest priority for each of a plurality of data items divided from the target data; generate a plurality of write requests corresponding to the plurality of data items; and transmit the plurality of generated write requests sequentially to the memory controller, so that the plurality of data items are stored in the second area in sequence from the highest priority to the lowest priority according to the determined priority for each of the plurality of data items, wherein at least one data item in the plurality of data items is stored in an area that overlaps with the first area. 15 . The memory system according to claim 14 , wherein the memory controller is configured to sequentially store in the second area, in response to sequentially receiving the plurality of write requests from the DMA controller, the plurality of data items corresponding to the plurality of write requests. 16 . The memory system according to claim 14 , wherein each of the plurality of data items is stored in a respective one of a plurality of sub-areas in the first area, and in response to an address of the second area being higher than an
Reliability improvement, data loss prevention, degraded operation etc · CPC title
Performance improvement · CPC title
DMA · CPC title
Improving the reliability of storage systems · CPC title
Improving or facilitating administration, e.g. storage management · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.