Method and system for shifting data within memory

US12487952B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-12487952-B2
Application numberUS-202418936668-A
CountryUS
Kind codeB2
Filing dateNov 4, 2024
Priority dateApr 29, 2024
Publication dateDec 2, 2025
Grant dateDec 2, 2025

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

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.

First claim

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

Assignees

Inventors

Classifications

  • 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

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US12487952B2 cover?
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 o…
Who is the assignee on this patent?
Rebellions Inc
What technology area does this patent fall under?
Primary CPC classification G06F13/18. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Dec 02 2025 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).