CN107111452A - 应用于计算机***的数据迁移方法和装置、计算机*** - Google Patents

应用于计算机***的数据迁移方法和装置、计算机*** Download PDF

Info

Publication number
CN107111452A
CN107111452A CN201580061176.0A CN201580061176A CN107111452A CN 107111452 A CN107111452 A CN 107111452A CN 201580061176 A CN201580061176 A CN 201580061176A CN 107111452 A CN107111452 A CN 107111452A
Authority
CN
China
Prior art keywords
address
target data
memory device
file
physical
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201580061176.0A
Other languages
English (en)
Other versions
CN107111452B (zh
Inventor
罗庆超
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Huawei Technologies Co Ltd
Original Assignee
Huawei Technologies Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Huawei Technologies Co Ltd filed Critical Huawei Technologies Co Ltd
Publication of CN107111452A publication Critical patent/CN107111452A/zh
Application granted granted Critical
Publication of CN107111452B publication Critical patent/CN107111452B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0646Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
    • G06F3/0647Migration mechanisms
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/061Improving I/O performance
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/20Handling requests for interconnection or transfer for access to input/output bus
    • G06F13/28Handling requests for interconnection or transfer for access to input/output bus using burst mode transfer, e.g. direct memory access DMA, cycle steal
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/06Addressing a physical block of locations, e.g. base addressing, module addressing, memory dedication
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/10Address translation
    • G06F12/1081Address translation for peripheral access to main memory, e.g. direct memory access [DMA]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/13File access structures, e.g. distributed indices
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0655Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0683Plurality of storage devices

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

一种应用于计算机***的数据迁移方法和装置。包括:确定目标数据的第一地址,其中,目标数据为需要从内存设备迁移到外存设备的数据,第一地址为目标数据在内存设备中的逻辑地址,内存设备为永久性存储器PM,计算机***中的操作***访问内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;根据第一地址计算目标数据在内存设备中的物理地址;构建散布表,散布表包括目标数据在内存设备中的物理地址;向直接内存存取DMA引擎发送迁移指令,迁移指令中包括散布表的信息,迁移指令用于指示DMA引擎根据物理地址从内存设备中获取目标数据,并将目标数据写到外存设备中。

Description

应用于计算机***的数据迁移方法和装置、计算机***
技术领域
本发明涉及计算机技术领域,尤其涉及一种应用于计算机***的数据迁移方法和装置、计算机***。
背景技术
存储器大致可分为两类:易失存储器和非易失存储器(Non Volatile Memory,NVM)。NVM包括多种模型,其中一种是永久性存储器(Persistent Memory,缩写:PM)。永久性存储器具有直接随机访问与非易失性双重特性的编程模型,可以采用传统虚拟内存管理接口,为文件***或者数据库提供新的存储行为。
现有技术中,将作为内存设备的永久性存储器中的数据迁移到外存储设备中时,需要先将数据从永久性存储器中读取到随机存取存储器(Random-Access Memory,RAM)后,然后根据数据在RAM中的物理地址构建散布表(Scatter Gather List,SGL)。直接内存存取(Directional Memory Access,DMA)引擎根据该散布表来从RAM中读取数据并写入到硬盘中。在每一次对永久性存储器和随机存取存储器的操作时都需要访问内存控制器,因此上述数据传输流程中总共有3次对内存控制器的访问,大大影响了内存控制器的带宽。
发明内容
本发明实施例提供了一种应用于计算机***的数据迁移方法和装置、计算机***,能够在将内存设备与外存设备的数据迁移过程中,减少对内存控制器的带宽的影响。
本发明实施例第一方面提供了一种应用于计算机***的数据迁移方法。该方法用于在永久性存储器作为内存设备,且计算机***中的操作***访问该内存设备的访问方式为卷访问方式或文件访问方式时,将存储在内存设备中的目标数据迁移到外存设备中。在迁移目标数据之前,获取该目标数据在内存设备中的逻辑地址,并根据该逻辑地址计算目标数据在内存设备中的物理地址,然后构建散布表,该散布表包括目标数据在内存设备中的物理地址;将包含有散布表的信息的迁移指令发送给DMA引擎,该散布表的信息包括目标数据在内存设备中的物理地址,该迁移指令用于指示DMA引擎根据该物理地址从内存设备中获取该目标数据,并将目标数据写到外存设备中。
本方法中,通过根据目标数据在内存设备的逻辑地址计算目标数据在内存设备中的物理地址,这样,可直接根据该目标数据在内存设备中的物理地址生成SGL,而无需将目标数据从内存设备读取到RAM后,再根据目标数据在RAM中的物理地址构建SGL。由于在这个过程中减少了对RAM的操作,因此减少了对内存控制器的访问次数,进而在数据迁移过程中减少了对内存控制器的带宽的影响。
其中,当内存设备的访问方式为卷访问方式时,目标数据的逻辑地址包括卷标识、偏移地址及长度,该卷标识为该目标数据所属的逻辑卷的标识。
其中,当内存设备的访问方式为文件访问方式时,目标数据的逻辑地址包括文件标识、偏移地址及长度,该文件标识为该目标数据所属的文件在文件***中的标识。
在第一方面的第一种可能的实现方式中,内存设备的访问方式为卷访问方式,根据目标数据在内存设备中的逻辑地址计算目标数据在内存设备中的物理地址包括:根据逻辑地址所包括的卷标识确定目标数据所属的逻辑卷在内存设备中的物理起始地址;根据该逻辑卷的物理起始地址和逻辑地址所包括的偏移地址计算目标数据在内存设备中的物理起始地址;根据目标数据在内存设备中的物理起始地址以及目标数据的长度确定目标数据的物理地址。本实现方式中能够简单快捷地计算出目标数据在内存设备中的物理地址。
根据第一方面的第一种可能的实现方式,在第二种可能的实现方式中,计算机***中存储有映射表,该映射表记录了每个卷标识对应的逻辑卷的物理起始地址和长度;通过在映射表中查询卷标识所对应的物理起始地址来确定目标数据所述的逻辑卷在内存设备中的物理起始地址。通过查询映射表的的方式能够快速准确获取到逻辑卷在内存设备中的物理起始地址。
根据第一方面的第一种可能的实现方式,在第三种可能的实现方式中,计算目标数据所属的逻辑卷的物理起始地址和目标数据的逻辑地址中所包括的偏移地址的和,目标数据在内存设备中的物理起始地址为该和。
在第一方面的第四种可能的实现方式中,内存设备的访问方式为文件访问方式,根据目标数据在内存设备中的逻辑地址计算目标数据在内存设备中的物理地址包括:根据逻辑地址所包括的文件标识获取目标数据所属的文件在内存设备中的物理起始地址;根据该文件的物理起始地址和逻辑地址所包括的偏移地址计算目标数据在内存设备中的物理起始地址;根据目标数据在内存设备中的物理起始地址以及目标数据的长度确定目标数据的物理地址。本实现方式中能够简单快捷地计算出目标数据在内存设备中的物理地址。
根据第一方面的第四种可能的实现方式,在第五种可能的实现方式中,在内存设备中构建文件***的过程中,计算机***中存储有映射表,该映射表记录了每个文件标识对应的文件的全路径信息,该全路径信息包括该文件的物理起始地址;通过在映射表中查询文件标识所对应的物理起始地址来确定目标数据所属的文件在内存设备中的物理起始地址。通过查询映射表的方式能够快速准确获取到逻辑卷在内存设备中的物理起始地址。
根据第一方面的第四种可能的实现方式,在第六种可能的实现方式中,当处理器中的进程根据目标数据的逻辑地址访问文件***时,操作***会先打开进程要访问的目标数据所在的目标文件,然后再对打开的目标文件进行读操作。在操作***打开目标文件的过程中,操作***会调用内核,内核会为该进程访问的目标文件分配一个文件标识。在对目标文件进行读操作的过程中,该进程可以根据该文件标识识别要访问的目标文件。当进程访问文件***时,进程中维护有该进程访问的所有打开的文件的描述信息。以文件标识为索引可以找到目标数据所属的文件的描述信息,并在该文件的描述信息中找到该文件在所述内存设备中的物理起始地址。
根据第一方面的第四种可能的实现方式,在第七种可能的实现方式中,计算目标数据所属的文件的物理起始地址和目标数据的逻辑地址中所包括的偏移地址的和,目标数据在内存设备中的物理起始地址为该和。
本发明实施例第二方面提供了一种应用于计算机***的数据迁移方法。该方法用于在永久性存储器作为内存设备,且计算机***中的操作***访问该内存设备的访问方式为卷访问方式或文件访问方式时,将存储在外存设备中的目标数据迁移到该内存设备中。在迁移目标数据之前,获取该目标数据待迁移到内存设备中的逻辑地址,并根据该逻辑地址计算目标数据待迁移到内存设备中的物理地址,然后构建散布表,该散布表包括目标数据待迁移到内存设备中的物理地址;将包含有散布表的信息的迁移指令发送给DMA引擎,该散布表的信息包括目标数据待迁移到内存设备中的物理地址,该迁移指令用于指示DMA引擎从外存设备中获取该目标数据,并根据该物理地址将目标数据写到内存设备中。
本方法中,通过根据目标数据待迁移到所述内存设备中的逻辑地址计算对应的物理地址,这样可以直接根据该物理地址构建散布表,使得DMA引擎可以根据该散布表将目标数据写入到内存设备中,无需像背景技术中先将外存设备的数据迁移到RAM中再根据数据在RAM中的物理地址构建SGL,由于减少了对RAM的操作,因此减少了对内存控制器的访问次数,进而减少了对内存控制器的带宽的影响。
其中,当内存设备的访问方式为卷访问方式时,目标数据待迁移到内存设备中的逻辑地址包括卷标识、偏移地址及长度,该卷标识为该目标数据所属的逻辑卷的标识。
其中,当内存设备的访问方式为文件访问方式时,目标数据待迁移到内存设备中的逻辑地址包括文件标识、偏移地址及长度,该文件标识为该目标数据所属的文件在文件***中的标识。
在第二方面的第一种可能的实现方式中,内存设备的访问方式为卷访问方式,根据目标数据待迁移到内存设备中的逻辑地址计算目标数据待迁移到内存设备中的物理地址包括:根据逻辑地址所包括的卷标识确定目标数据待迁移到的逻辑卷在内存设备中的物理起始地址;根据该逻辑卷的物理起始地址和逻辑地址所包括的偏移地址计算目标数据待迁移到内存设备中的物理起始地址;根据目标数据待迁移到内存设备中的物理起始地址以及目标数据的长度确定目标数据待迁移到内存设备中的物理地址。本实现方式中能够简单快捷地计算出目标数据在内存设备中的物理地址。
根据第二方面的第一种可能的实现方式,在第二种可能的实现方式中,计算机***中存储有映射表,该映射表记录了每个卷标识对应的逻辑卷的物理起始地址和长度;通过在映射表中查询卷标识所对应的物理起始地址来确定目标数据待迁移到的逻辑卷在内存设备中的物理起始地址。通过查询映射表的方式能够快速准确获取到逻辑卷在内存设备中的物理起始地址。
根据第二方面的第一种可能的实现方式,在第三种可能的实现方式中,计算目标数据待迁移到的逻辑卷的物理起始地址和目标数据的逻辑地址中所包括的偏移地址的和,目标数据在内存设备中的物理起始地址为该和。
在第二方面的第四种可能的实现方式中,内存设备的访问方式为文件访问方式,根据目标数据待迁移到内存设备中的逻辑地址计算目标数据待迁移到内存设备中的物理地址包括:根据该逻辑地址所包括的文件标识获取目标数据待迁移到的文件在内存设备中的物理起始地址;根据该文件的物理起始地址和逻辑地址所包括的偏移地址计算目标数据待迁移到内存设备中的物理起始地址;根据目标数据待迁移到内存设备中的物理起始地址以及目标数据的长度确定目标数据迁移到内存设备中的物理地址。本实现方式中能够简单快捷地计算出目标数据在内存设备中的物理地址。
根据第二方面的第四种可能的实现方式,在第五种可能的实现方式中,在内存设备中构建文件***的过程中,计算机***中存储有映射表,该映射表记录了每个文件标识对应的文件的全路径信息,该全路径信息包括该文件的物理起始地址;通过在映射表中查询文件标识所对应的物理起始地址来确定目标数据迁移到的文件在内存设备中的物理起始地址。通过查询映射表的的方式能够快速准确获取到逻辑卷在内存设备中的物理起始地址。
根据第二方面的第四种可能的实现方式,在第六种可能的实现方式中,当处理器中的进程根据目标数据的逻辑地址访问文件***时,操作***会先打开进程要访问的目标数据待迁移到的目标文件,然后再对打开的目标文件进行写操作。在操作***打开目标文件的过程中,操作***会调用内核,内核会为该进程访问的目标文件分配一个文件标识。在对目标文件进行写操作的过程中,该进程可以根据该文件标识识别要访问的目标文件。当进程访问文件***时,进程中维护有该进程访问的所有打开的文件的描述信息。以文件标识为索引可以找到目标数据待迁移到的文件的描述信息,并在该文件的描述信息中找到该文件在内存设备中的物理起始地址。
根据第二方面的第四种可能的实现方式,在第七种可能的实现方式中,计算目标数据待迁移到的文件的物理起始地址和目标数据的逻辑地址中所包括的偏移地址的和,目标数据待迁移到内存设备中的物理起始地址为该和。
第三方面,本发明实施例还提供了用于实现上述第一方面的方法的应用于计算机***的数据迁移装置。该应用于计算机***的数据迁移装置包括:确定模块、计算模块、构建模块和发送模块,其中每个模块完成特定的功能,各个模块共同配合用于实现上述第一方面以及第一方面的第一种至第七种可能的实现方式中所提供的应用于计算机***的数据迁移方法。
第四方面,本发明实施例提供了一种计算机***,该计算机***包括处理器、内存设备和外存设备。该内存设备可以是永久性存储器,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式。该内存设备中存储有目标数据,所述目标数据为需要从内存设备迁移到外存设备的数据。处理器可以为中央处理器。该处理器具体用于执行上述第一方面、第一方面的第一种至第七种可能的实现方式中所提供的应用于计算机***的数据迁移方法。
第五方面,本发明实施例还提供了一种计算机可读存储介质,该存储介质中存储有用于实现上述第一方面中所描述的应用于计算机***的数据迁移方法的指令或软件模块。
第六方面,本发明实施例还提供了用于实现上述第二方面的方法的应用于计算机***的数据迁移装置。该应用于计算机***的数据迁移装置包括:确定模块、计算模块、构建模块和发送模块,其中每个模块完成特定的功能,各个模块共同配合实现上述第二方面、第二方面的第一种至第七种可能的实现方式中所提供的应用于计算机***的数据迁移方法。
第七方面,本发明实施例提供了一种计算机***,该计算机***包括处理器、内存设备和外存设备。该内存设备永久性存储器,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式。该外存设备用于存储目标数据,所述目标数据为需要从外存设备迁移到内存设备的数据。处理器可以为中央处理器。该处理器具体用于执行上述第二方面、第二方面的第一种可能的实现方式至第七种可能的实现方式中所提供的应用于计算机***的数据迁移方法。
第八方面,本发明实施例还提供一种计算机可读存储介质,该存储介质中存储有用于实现上述第二方面、第二方面的第一种可能的实现方式至第七种可能的实现方式中所描述的应用于计算机***的数据迁移方法的指令或软件模块。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍。
图1为本发明的计算机***的一个实施例的结构示意图;
图2为本发明实施例的应用于计算机***的数据迁移方法的一个实施例的结构示意图;
图3为内存设备的访问方式为卷访问方式时的地址计算方法的一个实施例的流程示意图;
图4为内存设备的访问方式为文件访问方式时的地址计算方法的一个实施例的流程示意图;
图5为本发明实施例的应用于计算机***的数据迁移方法的另一个实施例的结构示意图;
图6为本发明的应用于计算机***的数据迁移装置的一个实施例的结构示意图;
图7为本发明的应用于计算机***的数据迁移装置的另一个实施例的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。
为便于理解,下面对本发明中的一些概念进行解释。
DMA是一种无需处理器的参与就可以让外在设备和***内存之间进行双向数据传输的硬件机制。在DMA传输数据的过程中,要求源物理地址和目标物理地址分别是连续的。但在某些计算机体系中,连续的存储器地址在物理上不一定是连续的,因此DMA传输要分成多次完成。针对这个问题,一种解决方法是使用SGL描述物理上不连续的存储空间,然后把该SGL的信息发送至DAM引擎。DMA引擎在传输完一块物理连续的数据后,不用发起中断,而是根据SGL来传输下一块物理上连续的数据,直到传输完毕后再发起一次中断。
如图1所示,图1为本发明的计算机***的一个实施例的结构示意图。计算机***包括处理器11、动态随机存储器(Dynamic Random Access Memory,DRAM)12、非易失性存储器(Non-Volatile Memory,NVM)13、主机总线适配器(Host Bus Adapter,HBA)14和外存设备15。
其中,处理器11可以是中央处理器(Central Processing Unit,CPU)。CPU11是计算机***的核心,CPU11可以调用计算机***中不同的软件程序实现不同的功能。例如,CPU11能够实现对内存设备12和外存设备15的访问。可以理解的是,在本发明实施例中,CPU仅仅是处理器11的一个示例。除了CPU外,处理器11还可以是其他特定集成电路(Application Specific Integrated Circuit,ASIC),或者是被配置成实施本发明实施例的一个或多个集成电路。
DRAM 12通过双倍速率同步(Double Data Rate,DDR)总线和处理器11进行通信。处理器11能够高速访问DRAM 12,对DRAM 12中的任一存储单元进行读或写操作。DRAM 12具有访问速度快的优点,因此通常DRAM作为主内存使用。通常DRAM 12用来存放操作***中各种正在运行的软件、输入和输出数据以及与外存交换的信息等。然而,DRAM 12是易失性的,当计算机关闭电源后,DRAM 12中的信息将不再保存。本领域技术人员可以知道,DRAM是易失性内存的一种,实际应用中还可以采用其他的随机存储器(Random Access Memory,RAM)作为计算机***的内存。例如,还可以采用静态随机存储器(Static Random AccessMemory,SRAM)作为计算机***的内存。
NVM13通过DDR总线和处理器11进行通信,与DRAM12共同作为计算机***100的内存。需注意的是,下文中所描述的内存设备指的是图1所示架构图中的NVM13。由于新型NVM都具有访问速度快且具有非易失性的特点,并且,这些新型NVM能够按字节(Byte)寻址,将数据以位(bit)为单位写入非易失性存储器中,因而能够作为内存使用。与DRAM 12相比,由于NVM13具有非易失性的特点,从而能够更好的保存数据。在本发明实施例中,NVM 13被配置为永久性存储器,根据这种方式,即使在计算机***掉电的情况下存储于NVM13中的数据也不会丢失。在本发明实施例中,计算机***中的操作***访问该永久性存储器的访问方式可以为卷(volume)访问方式或文件(file)访问方式。其中,在卷访问方式中,永久性存储器对外展现为多个逻辑卷。在文件访问方式中,永久性存储器对外展现为包括多个文件的文件***。
外存设备15的存储介质需要具有非易失性的特点,当计算机关闭电源后,存储于外存的数据仍然会被保存。并且,外存设备的存储容量较大。作为外存设备的存储器可以是磁盘、固态硬盘(Solid State Drives,SSD)、机械硬盘(Hard Disk Drive,HDD)、光盘、存储阵列等其他能够存储数据的非易失性的存储设备。外存设备15和HBA 13通过串行连接小型计算机***接口(英文:Small Computer System Interface;缩写:SCSI)接口(英文:Serial Attached SCSI,缩写:SAS)链路连接,处理器和HBA通过外设互联标准总线(Peripheral Component Interconnect Express,PCI-E)连接。HBA 13包括DMA引擎,该DMA引擎用于实现数据在与该HBA 13连接的外存设备和内存设备之间的传输。
实际应用中,当内存设备为永久性存储器时,在通过DMA的方式将内存设备中的数据迁移到外存设备的情况下,由于CPU所看到存储在内存设备中的目标数据的地址为逻辑地址(也即虚拟地址),而不是实际的物理地址。那么CPU不能根据目标数据的逻辑地址生成SGL,而是先将目标数据从内存设备中迁移到RAM中,再根据该目标数据在RAM中的物理地址生成SGL,从而使DMA引擎能够根据生成的SGL将数据从非易失的内存设备迁移到外存设备中。
可以理解的是,图1提供的计算机***架构图仅仅是NVM作为内存的一种应用场景。实际应用中,计算机***的内存也可以只包括NVM而不包括DRAM。由于在本发明实施例中,主要涉及将作为永久性存储器的内存设备的数据迁移到外存设备的应用场景,因此,在本发明实施例中不对具体的计算机***的结构进行限定,只要是包括内存设备为永久性存储器的计算机***即可。
请参阅图2,图2为本发明的应用于计算机***的数据迁移方法的一个实施例的流程示意图。图2所示的数据迁移方法可以应用于图1所示的计算机***中。如图2所示,本实施例中的应用于计算机***的数据迁移方法包括:
201、确定目标数据的第一地址。
本实施例中,目标数据存储在图1所示计算机***的内存设备中,并需要从内存设备迁移到外存设备中。第一地址为所述目标数据在内存设备中的逻辑地址。
当所述内存设备的访问方式为卷访问方式时,内存设备呈现给处理器的是多个逻辑卷。第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据所属的逻辑卷的标识。计算机***中存有映射表,该映射表记录了每个卷标识对应的逻辑卷的物理起始地址和长度。
具体举例来说,一个128GB的内存设备包括两个逻辑卷,该两个逻辑卷的ID分别为1和2,ID为1的逻辑卷的物理地址为0~64GB,ID为2的逻辑卷的物理地址为64GB~128GB。当目标数据存储在该内存设备中物理地址为66GB~72GB处时,该目标数据的第一地址包括逻辑卷的ID2、偏移地址2GB和长度6GB。
当所述内存设备的访问方式为文件访问方式时,内存设备呈现给处理器的是用于管理多个文件的文件***。第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据所属的文件在文件***中的标识,其中,文件标识可以是一些数字或其他文件描述符(或者文件句柄)。
202、根据所述第一地址计算所述目标数据在所述内存设备中的物理地址。
下面以所述内存设备的访问方式为卷访问方式为例对其中一种的计算方法进行举例说明。如图3所示,图3为内存设备的访问方式为卷访问方式时的地址计算方法的一个实施例的流程示意图。该地址计算方法包括:
S31、根据所述卷标识确定所述目标数据所属的逻辑卷在所述内存设备中的物理起始地址。
具体的,在步骤201中所描述的映射表中通过目标数据所在的逻辑卷的ID查询该逻辑卷的物理起始地址。例如,paddr_start_vol=volume_table[v_id],其中,volume_table[]为查询映射表的函数,v_id为目标数据所属的逻辑卷的ID,paddr_start_vol为目标数据所属的逻辑卷的物理起始地址。
S32、根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址。
具体的,第一地址中包括的偏移地址为v_addr,m_addr为目标数据在所述内存设备中的物理起始地址,那么m_addr=paddr_start_vol+v_addr。
S33、根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
计算出目标数据在所述内存设备中的物理起始地址m_addr后,确定所述目标数据在内存设备中的物理地址包括m_addr和所述目标数据的长度。
具体举例来说,目标数据的第一地址包括逻辑卷的ID2、偏移地址2GB和长度6GB。那么可根据该逻辑卷的ID2在步骤201中所举例的内存设备对应的映射表中查询到该ID对应的逻辑卷的物理起始地址为64GB。由于第一地址中包括目标数据的偏移地址为2GB,那么可计算出目标数据在所述内存设备中的物理起始地址为64GB+2GB=66GB。目标数据的长度是已知的,因此目标数据在所述内存设备中的的物理地址包括物理起始地址66GB和数据长度2GB。
下面以所述内存设备的访问方式为文件访问方式为例对其中一种的计算方法进行举例说明。
如图4所示,图4为内存设备的访问方式为文件访问方式时的地址计算方法的一个实施例的流程示意图。该地址计算方法包括:
S41、根据所述文件标识获取所述目标数据所属的文件在所述内存设备中的物理起始地址。
实际应用中,在所述内存设备中构建文件***的过程中,计算机***中存有映射表,该映射表记录了每个文件标识对应的文件的全路径信息,该全路径信息包括该文件的物理起始地址。在本步骤中,可以根据所述文件标识以及文件***中存储的映射表获得所述目标数据所属的文件在所述内存设备中的物理起始地址。
或者,当处理器中的进程根据目标数据的逻辑地址访问文件***时,操作***会先打开进程要访问的目标数据所在的目标文件,然后再对打开的目标文件进行读操作。在操作***打开目标文件的过程中,操作***会调用内核,内核会为该进程访问的目标文件分配一个文件标识。文件标识是当前进程识别目标文件的唯一标识。在对目标文件进行读操作的过程中,该进程可以根据该文件标识识别要访问的目标文件。当进程访问文件***时,进程中维护有该进程访问的所有打开的文件的描述信息,以文件标识为索引可以找到目标数据所属的文件的描述信息,并在该文件的描述信息中找到该文件在所述内存设备中的物理起始地址。
S42、根据所述文件的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址。
具体的,所述目标数据在所述内存设备中的物理起始地址为所述文件的物理起始地址和所述偏移地址的和。
S43、根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
计算出目标数据在所述内存设备中的物理起始地址m_addr后,确定所述目标数据在内存设备中的物理地址包括m_addr和所述目标数据的长度。
以上描述仅为对“根据所述第一地址计算所述目标数据在所述内存设备中的物理地址”的举例,并不作限制。
203、构建散布表,所述散布表包括所述物理地址。
将目标数据在所述内存设备中的物理地址填写到散布表中。具体的,获取sg_list指针,根据DMA规范填写SGL信息,其中,将目标数据在内存设备中的物理地址填入sg_list指针中。
举例来说,目标数据在内存设备中的物理地址包括22GB~34GB、39GB~44GB、56GB~78GB,那么依次将各物理地址填入sg_list指针中。
204、向DMA引擎发送迁移指令,所述迁移指令中包括所述散布表的信息。
构建好SGL后,为将目标数据迁移到外存设备中,处理器需向外存设备所连接的HBA中的DMA引擎发送迁移指令,其中,该迁移指令中包括目标数要迁移到外存设备中的地址以及SGL的信息,该SGL的信息包括目标数据在内存设备中的物理地址,该迁移指令用于指示DMA引擎根据SGL中的物理地址从内存设备中读取目标数据,并根据目标数要迁移到外存设备中的地址将目标数据写入外存设备中。
本实施例中,处理器通过根据目标数据在内存设备的逻辑地址计算目标数据在内存设备中的物理地址,这样,可直接根据该目标数据在内存设备中的物理地址生成SGL,而无需将目标数据从内存设备读取到RAM后,再根据目标数据在RAM中的物理地址构建SGL,由于减少了对RAM的操作,因此减少了对内存控制器的访问次数,进而减少了对内存控制器的带宽的影响。
上面对将目标数据从操作***中的内存设备迁移到外存设备的方法,下面对就将目标数据从操作***中的外存设备传输到内存设备的方法进行描述。
如图5所示,图5为本发明的应用于计算机***的数据迁移方法的一个实施例的流程示意图。图5所示的数据迁移方法也可以应用于图1所示的计算机***中。如图5所示,本实施例中的应用于计算机***的数据迁移方法包括:
501、确定目标数据的第一地址。
本实施例中,目标数据存储在图1所示计算机***的外存设备中,并需要从外存设备迁移到内存设备中。第一地址为所述目标数据待迁移到所述内存设备中的目的地址。由于内存设备为非易失性存储器,所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式,因此第一地址为逻辑地址。具体解释可参考步骤201中的解释说明,在此不再赘述。
502、根据所述第一地址计算所述目标数据待迁移到所述内存设备中的物理地址。
本实施例中,计算物理地址的方法可参考步骤202的解释说明,在此不再赘述。
503、构建散布表,所述散布表包括所述物理地址。
将目标数据待迁移到所述内存设备中的物理地址填写到散布表中。具体的,获取sg_list指针,根据DMA规范填写SGL信息,其中,将目标数据待迁移到所述内存设备中的物理地址填入sg_list指针中。
举例来说,目标数据待迁移到所述内存设备中的物理地址包括22GB~34GB、39GB~44GB、56GB~78GB,那么依次将各物理地址填入sg_list指针中。
504、向DMA引擎发送迁移指令,所述迁移指令包括所述散布表的信息。
构建好SGL后,为将目标数据从外存设备迁移到内存设备中,处理器需向该外存设备所连接的HBA中的DMA引擎发送指示,该指示包括SGL的信息,该迁移指令用于指示DMA引擎从外存设备中读取目标数据,并根据SGL中的物理地址将目标数据写入内存设备中。
现有技术中,由于构建SGL时需要根据物理地址来构建,因此将外存设备的数据迁移到内存设备中时需要先根据SGL将数据先传输到RAM中,再从RAM写到内存设备中;本实施例中,通过根据目标数据待迁移到所述内存设备中的逻辑地址计算对应的物理地址,这样可以根据该物理地址构建散布表,使得DMA引擎可以根据该散布表直接将目标数据写入到内存设备中,由于减少了对RAM的操作,因此减少了对内存控制器的访问次数,进而减少了对内存控制器的带宽的影响。
进一步的,本实施例中,内存设备的访问模式为卷访问模式或者文件访问模式,在将目标数据迁移到内存设备后,目标数据在内存设备中的地址采用的是逻辑地址。因此,处理器在向DMA引擎发送迁移指令之后,还需根据目标数据在目标内存设备中物理地址计算对应的逻辑地址,下面对处理器根据所述目标数据在内存设备中的物理地址计算对应的逻辑地址的方法进行说明。具体的,以内存设备的访问模式为卷访问模式为例。
首先,根据所述目标数据待迁移到的逻辑卷在所述内存设备中的物理起始地址确定所述逻辑卷的卷标识。具体的,在步骤201中所描述的映射表中通过该目标数据待迁移到内存设备中的物理起始地址查询该目标数据待迁移到的逻辑卷的ID。
其次,根据所述逻辑卷的卷标识和所述目标数据在所述内存设备中的物理起始地址计算偏移地址。确定逻辑卷的卷标识后,可在映射表中查询到该逻辑卷的物理起始地址。由于所述目标数据在所述内存设备中的物理起始地址为该逻辑卷的物理起始地址和偏移地址的和,因此偏移地址为所述目标数据在所述内存设备中的物理起始地址减去该逻辑卷的物理起始地址得到的差。
根据所述逻辑卷的卷标识、偏移地址和所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的逻辑地址。
当内存设备的访问方式为文件访问方式时,将所述目标数据在内存设备中的物理地址计算对应的逻辑地址的方法可以参考以上举例,只是在查询目标数据待迁移到的文件的文件标识时是在用于记录文件***中的映射表中进行查询。
上面对本发明实施例中的应用于计算机***的数据迁移方法进行了描述,下面对本发明实施例中的应用于计算机***的数据迁移装置进行描述,其中应用于计算机***的数据迁移装置用于执行上述应用于计算机***的数据迁移方法。
请参阅图6,图6为本发明的应用于计算机***的数据迁移装置的一个实施例的结构示意图。本实施例中,应用于计算机***的数据迁移装置600包括:
确定模块601,用于确定目标数据的第一地址,其中,所述目标数据为需要从内存设备迁移到外存设备的数据,所述第一地址为所述目标数据在内存设备中的逻辑地址,所述内存设备为永久性存储器PM,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
计算模块602,用于根据所述第一地址计算所述目标数据在所述内存设备中的物理地址;
构建模块603,用于构建散布表,所述散布表包括所述目标数据在所述内存设备中的物理地址;
发送模块604,用于向直接内存存取DMA引擎发送迁移指令,所述迁移指令中包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址从所述内存设备中获取所述目标数据,并将所述目标数据写到外存设备中。
可选的,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据所属的逻辑卷的标识,所述计算模块具体用于:
根据所述卷标识确定所述目标数据所属的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
可选的,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据所属的文件在文件***中的标识;所述计算模块具体用于:
根据所述文件标识获取所述目标数据所属的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
对本实施例中的应用于计算机***的数据迁移装置的具体说明可参考图2至图4所示实施例中的描述,在此不再赘述。
请参阅图7,图7为本发明的数据传输装置的一个实施例的结构示意图。本实施例中,数据传输装置700包括:
确定模块701,确定待迁移的目标数据的第一地址,其中,所述目标数据为需要从外存设备迁移到内存设备的数据,所述第一地址为所述内存设备中的地址,所述第一地址为逻辑地址,所述内存设备为为永久性存储器,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
计算模块702,根据所述第一地址计算所述目标数据待迁移到所述内存设备中的物理地址;
构建模块703,构建散布表,所述散布表包括所述物理地址;
发送模块704,向DMA引擎发送迁移指令,所述迁移指令包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址将所述目标数据写到所述内存设备中。
可选的,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据待迁移到的逻辑卷的标识,所述计算模块具体用于:
根据所述卷标识确定所述目标数据待迁移到的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
可选的,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据待迁移到的文件***中的标识,所述计算模块具体用于:
根据所述文件标识获取所述目标数据待迁移到的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
对本实施例中的应用于计算机***的数据迁移装置的具体说明可参考图5所示实施例中的描述,在此不再赘述。
上面从单元化功能实体的角度对本发明实施例中的应用于计算机***的数据迁移装置进行了描述,下面从硬件处理的角度对本发明实施例中的应用于计算机***的数据迁移装置进行描述。
本发明中的应用于计算机***的数据迁移装置的一个具体实施例为图2所示计算机***中的处理器,该处理器用于采用图2至图5所示实施例中的方法来构建散布表并向DMA引擎发送迁移指令,以指示DMA引擎根据该迁移指令将计算机***中的外存设备中的数据迁移到内存设备中,或者指示DMA引擎根据该迁移指令将计算机***中的内存设备的数据迁移到外存设备中。
在本申请所提供的几个实施例中,应该理解到,所揭露的***,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的。另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个模块单独物理存在,也可以两个或两个以上模块集成在一个模块中。上述集成的模块既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。
所述集成的模块如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。

Claims (18)

1.一种应用于计算机***的数据迁移方法,其特征在于,包括:
确定目标数据的第一地址,其中,所述目标数据为需要从内存设备迁移到外存设备的数据,所述第一地址为所述目标数据在内存设备中的逻辑地址,所述内存设备为永久性存储器PM,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
根据所述第一地址计算所述目标数据在所述内存设备中的物理地址;
构建散布表,所述散布表包括所述目标数据在所述内存设备中的物理地址;
向直接内存存取DMA引擎发送迁移指令,所述迁移指令中包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址从所述内存设备中获取所述目标数据,并将所述目标数据写到外存设备中。
2.根据权利要求1所述的方法,其特征在于,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据所属的逻辑卷的标识,所述根据所述第一地址计算所述目标数据在所述内存设备中的物理地址,包括:
根据所述卷标识确定所述目标数据所属的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
3.根据权利要求1所述的方法,其特征在于,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据所属的文件在文件***中的标识;所述根据所述第一地址计算所述目标数据在所述内存设备中的物理地址,包括:
根据所述文件标识获取所述目标数据所属的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
4.一种应用于计算机***的数据迁移方法,其特征在于,包括:
确定待迁移的目标数据的第一地址,其中,所述目标数据为需要从外存设备迁移到内存设备的数据,所述第一地址为所述内存设备中的地址,所述第一地址为逻辑地址,所述内存设备为永久性存储器,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
根据所述第一地址计算所述目标数据待迁移到所述内存设备中的物理地址;
构建散布表,所述散布表包括所述物理地址;
向DMA引擎发送迁移指令,所述迁移指令包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址将所述目标数据写到所述内存设备中。
5.根据权利要求4所述的方法,其特征在于,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据待迁移到的逻辑卷的标识,所述根据所述第一地址计算所述目标数据待迁移到所述内存设备中的物理地址,包括:
根据所述卷标识确定所述目标数据待迁移到的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
6.根据权利要求5所述的方法,其特征在于,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据待迁移到的文件***中的标识,所述根据所述第一地址计算所述目标数据待迁移到所述内存设备中的物理地址,包括:
根据所述文件标识获取所述目标数据待迁移到的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
7.一种应用于计算机***的数据迁移装置,其特征在于,包括:
确定模块,用于确定目标数据的第一地址,其中,所述目标数据为需要从内存设备迁移到外存设备的数据,所述第一地址为所述目标数据在内存设备中的逻辑地址,所述内存设备为永久性存储器PM,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
计算模块,用于根据所述第一地址计算所述目标数据在所述内存设备中的物理地址;
构建模块,用于构建散布表,所述散布表包括所述目标数据在所述内存设备中的物理地址;
发送模块,用于向直接内存存取DMA引擎发送迁移指令,所述迁移指令中包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址从所述内存设备中获取所述目标数据,并将所述目标数据写到外存设备中。
8.根据权利要求7所述的装置,其特征在于,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据所属的逻辑卷的标识,所述计算模块具体用于:
根据所述卷标识确定所述目标数据所属的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
9.根据权利要求7所述的装置,其特征在于,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据所属的文件在文件***中的标识;所述计算模块具体用于:
根据所述文件标识获取所述目标数据所属的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
10.一种应用于计算机***的数据迁移装置,其特征在于,包括:
确定模块,确定待迁移的目标数据的第一地址,其中,所述目标数据为需要从外存设备迁移到内存设备的数据,所述第一地址为所述内存设备中的地址,所述第一地址为逻辑地址,所述内存设备为为永久性存储器,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
计算模块,根据所述第一地址计算所述目标数据待迁移到所述内存设备中的物理地址;
构建模块,构建散布表,所述散布表包括所述物理地址;
发送模块,向DMA引擎发送迁移指令,所述迁移指令包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址将所述目标数据写到所述内存设备中。
11.根据权利要求10所述的装置,其特征在于,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据待迁移到的逻辑卷的标识,所述计算模块具体用于:
根据所述卷标识确定所述目标数据待迁移到的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
12.根据权利要求10所述的装置,其特征在于,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据待迁移到的文件***中的标识,所述计算模块具体用于:
根据所述文件标识获取所述目标数据待迁移到的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
13.一种计算机***,其特征在于,包括:
内存设备,所述内存设备中存储有目标数据,所述目标数据为需要从内存设备迁移到外存设备的数据,其中,所述内存设备为永久性存储器PM,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
处理器,用于:
确定所述目标数据的第一地址,其中,所述第一地址为所述目标数据在内存设备中的逻辑地址;
根据所述第一地址计算所述目标数据在所述内存设备中的物理地址;
构建散布表,所述散布表包括所述目标数据在所述内存设备中的物理地址;
向直接内存存取DMA引擎发送迁移指令,所述迁移指令中包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址从所述内存设备中获取所述目标数据,并将所述目标数据写到外存设备中。
14.根据权利要求13的计算机***,其特征在于,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据所属的逻辑卷的标识,所述处理器具体用于:
根据所述卷标识确定所述目标数据所属的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
15.根据权利要求13所述的计算机***,其特征在于,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据所属的文件在文件***中的标识;所述处理器具体用于:
根据所述文件标识获取所述目标数据所属的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据在所述内存设备中的物理起始地址;
根据所述目标数据在所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据的物理地址。
16.一种计算机***,其特征在于,包括:
内存设备,所述内存设备为永久性存储器,所述计算机***中的操作***访问所述内存设备的访问方式为卷VOLUME访问方式或文件FILE访问方式;
外存设备,用于存储目标数据,所述目标数据为需要从外存设备迁移到内存设备的数据;
处理器,用于:
根据所述第一地址计算所述目标数据待迁移到所述内存设备中的物理地址,其中,所述第一地址为所述内存设备中的地址,所述第一地址为逻辑地址;
构建散布表,所述散布表包括所述物理地址;
向DMA引擎发送迁移指令,所述迁移指令包括所述散布表的信息,所述迁移指令用于指示所述DMA引擎根据所述物理地址将所述目标数据写到所述内存设备中。
17.根据权利要求16所述的计算机***,其特征在于,当所述内存设备的访问方式为卷访问方式时,所述第一地址包括卷标识、偏移地址及长度,所述卷标识为所述目标数据待迁移到的逻辑卷的标识,所述处理器具体用于:
根据所述卷标识确定所述目标数据待迁移到的逻辑卷在所述内存设备中的物理起始地址;
根据所述逻辑卷的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
18.根据权利要求16所述的计算机***,其特征在于,当所述内存设备的访问方式为文件访问方式时,所述第一地址包括文件标识、偏移地址及长度,所述文件标识为所述目标数据待迁移到的文件***中的标识,所述处理器具体用于:
根据所述文件标识获取所述目标数据待迁移到的文件在所述内存设备中的物理起始地址;
根据所述文件的物理起始地址和所述偏移地址计算所述目标数据待迁移到所述内存设备中的物理起始地址;
根据所述目标数据待迁移到所述内存设备中的物理起始地址以及所述目标数据的长度确定所述目标数据待迁移到所述内存设备中的物理地址。
CN201580061176.0A 2015-12-03 2015-12-03 应用于计算机***的数据迁移方法和装置、计算机*** Active CN107111452B (zh)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/CN2015/096285 WO2017092002A1 (zh) 2015-12-03 2015-12-03 应用于计算机***的数据迁移方法和装置、计算机***

Publications (2)

Publication Number Publication Date
CN107111452A true CN107111452A (zh) 2017-08-29
CN107111452B CN107111452B (zh) 2020-01-10

Family

ID=58796043

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201580061176.0A Active CN107111452B (zh) 2015-12-03 2015-12-03 应用于计算机***的数据迁移方法和装置、计算机***

Country Status (4)

Country Link
US (1) US10740018B2 (zh)
EP (1) EP3361385A4 (zh)
CN (1) CN107111452B (zh)
WO (1) WO2017092002A1 (zh)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112292660A (zh) * 2019-05-13 2021-01-29 华为技术有限公司 一种调度存储器中数据的方法、数据调度设备及***
CN113282239A (zh) * 2021-05-21 2021-08-20 维沃移动通信有限公司 数据迁移方法、存储器及控制器
WO2021208089A1 (zh) * 2020-04-17 2021-10-21 华为技术有限公司 存储器的管理方法和控制装置
CN113687779A (zh) * 2021-07-29 2021-11-23 济南浪潮数据技术有限公司 数据迁移方法、装置、电子设备及可读存储介质
CN113821458A (zh) * 2021-09-18 2021-12-21 日立楼宇技术(广州)有限公司 一种数据操作方法、装置、计算机设备和存储介质
CN115659994B (zh) * 2022-12-09 2023-03-03 深圳市人马互动科技有限公司 人机交互***中的数据处理方法及相关装置

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11256437B2 (en) 2018-11-19 2022-02-22 Micron Technology, Inc. Data migration for memory operation
US11163473B2 (en) * 2018-11-19 2021-11-02 Micron Technology, Inc. Systems, devices, techniques, and methods for data migration
US11182090B2 (en) 2018-11-19 2021-11-23 Micron Technology, Inc. Systems, devices, and methods for data migration
CN112540941A (zh) * 2019-09-21 2021-03-23 华为技术有限公司 一种数据转发芯片及服务器
US11537479B2 (en) * 2020-04-29 2022-12-27 Memverge, Inc. Memory image capture
CN112486410B (zh) * 2020-11-23 2024-03-26 华南师范大学 一种持久性内存文件读写方法、***、装置及存储介质

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6021462A (en) * 1997-08-29 2000-02-01 Apple Computer, Inc. Methods and apparatus for system memory efficient disk access to a raid system using stripe control information
US20020144027A1 (en) * 2001-03-27 2002-10-03 Schmisseur Mark A. Multi-use data access descriptor
US20090164691A1 (en) * 2007-12-20 2009-06-25 Hsun-Wen Wang Io processor
CN101539894A (zh) * 2009-05-04 2009-09-23 成都市华为赛门铁克科技有限公司 一种将计算机外部设备接入计算机***的方法和装置
US20090292861A1 (en) * 2008-05-23 2009-11-26 Netapp, Inc. Use of rdma to access non-volatile solid-state memory in a network storage system
CN102480516A (zh) * 2010-11-30 2012-05-30 英业达股份有限公司 网际网络小型电脑界面的数据单元的解析方法
CN102567244A (zh) * 2011-12-13 2012-07-11 清华大学 闪存和磁盘转换存取方法
CN104579695A (zh) * 2013-10-23 2015-04-29 杭州华三通信技术有限公司 一种数据转发装置和方法
CN104965757A (zh) * 2015-01-21 2015-10-07 深圳市腾讯计算机***有限公司 虚拟机热迁移的方法、虚拟机迁移管理装置及***

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3217002B2 (ja) 1996-11-19 2001-10-09 株式会社日立製作所 デジタルスタジオ装置およびその制御方法
US8549252B2 (en) 2005-12-13 2013-10-01 Emc Corporation File based volumes and file systems
US9223706B2 (en) * 2013-07-02 2015-12-29 Infinidat Ltd. System, method and a non-transitory computer readable medium for a pre-fetch operation
US9256373B1 (en) * 2014-05-19 2016-02-09 Emc Corporation Invulnerable data movement for file system upgrade

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6021462A (en) * 1997-08-29 2000-02-01 Apple Computer, Inc. Methods and apparatus for system memory efficient disk access to a raid system using stripe control information
US20020144027A1 (en) * 2001-03-27 2002-10-03 Schmisseur Mark A. Multi-use data access descriptor
US20090164691A1 (en) * 2007-12-20 2009-06-25 Hsun-Wen Wang Io processor
US20090292861A1 (en) * 2008-05-23 2009-11-26 Netapp, Inc. Use of rdma to access non-volatile solid-state memory in a network storage system
CN101539894A (zh) * 2009-05-04 2009-09-23 成都市华为赛门铁克科技有限公司 一种将计算机外部设备接入计算机***的方法和装置
CN102480516A (zh) * 2010-11-30 2012-05-30 英业达股份有限公司 网际网络小型电脑界面的数据单元的解析方法
CN102567244A (zh) * 2011-12-13 2012-07-11 清华大学 闪存和磁盘转换存取方法
CN104579695A (zh) * 2013-10-23 2015-04-29 杭州华三通信技术有限公司 一种数据转发装置和方法
CN104965757A (zh) * 2015-01-21 2015-10-07 深圳市腾讯计算机***有限公司 虚拟机热迁移的方法、虚拟机迁移管理装置及***

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112292660A (zh) * 2019-05-13 2021-01-29 华为技术有限公司 一种调度存储器中数据的方法、数据调度设备及***
CN112292660B (zh) * 2019-05-13 2022-05-31 华为技术有限公司 一种调度存储器中数据的方法、数据调度设备及***
WO2021208089A1 (zh) * 2020-04-17 2021-10-21 华为技术有限公司 存储器的管理方法和控制装置
CN113282239A (zh) * 2021-05-21 2021-08-20 维沃移动通信有限公司 数据迁移方法、存储器及控制器
CN113687779A (zh) * 2021-07-29 2021-11-23 济南浪潮数据技术有限公司 数据迁移方法、装置、电子设备及可读存储介质
CN113687779B (zh) * 2021-07-29 2024-02-23 济南浪潮数据技术有限公司 数据迁移方法、装置、电子设备及可读存储介质
CN113821458A (zh) * 2021-09-18 2021-12-21 日立楼宇技术(广州)有限公司 一种数据操作方法、装置、计算机设备和存储介质
CN113821458B (zh) * 2021-09-18 2023-09-05 日立楼宇技术(广州)有限公司 一种数据操作方法、装置、计算机设备和存储介质
CN115659994B (zh) * 2022-12-09 2023-03-03 深圳市人马互动科技有限公司 人机交互***中的数据处理方法及相关装置

Also Published As

Publication number Publication date
WO2017092002A1 (zh) 2017-06-08
US10740018B2 (en) 2020-08-11
US20180267739A1 (en) 2018-09-20
EP3361385A1 (en) 2018-08-15
CN107111452B (zh) 2020-01-10
EP3361385A4 (en) 2018-11-21

Similar Documents

Publication Publication Date Title
CN107111452A (zh) 应用于计算机***的数据迁移方法和装置、计算机***
US11029853B2 (en) Dynamic segment allocation for write requests by a storage system
CN102681952B (zh) 将数据写入存储设备的方法与存储设备
US20140149706A1 (en) Storage device and data transfering method thereof
US11604594B2 (en) Apparatus, system and method for offloading data transfer operations between source and destination storage devices to a hardware accelerator
US10216418B2 (en) Storage apparatus and method for autonomous space compaction
WO2018194846A1 (en) Data processing performance enhancement for neural networks using a virtualized data iterator
CN109324754A (zh) 与主机接合的储存装置以及操作主机和储存装置的方法
CN107301455A (zh) 用于卷积神经网络的混合立方体存储***及加速计算方法
CN109196829A (zh) 远程存储器操作
CN105468291B (zh) 动态及静态磨损均衡控制方法及装置
CN104781794B (zh) 用于非易失性存储器中的数据结构的暂时和持久状态之间的原地改变
CN106484628A (zh) 基于事务的混合存储器模块
KR101747966B1 (ko) 자율 서브시스템 아키텍처
US11042328B2 (en) Storage apparatus and method for autonomous space compaction
CN109299190A (zh) 分布式存储***中处理对象的元数据的方法及装置
KR20110028211A (ko) 자율 메모리 아키텍처
CN109164976A (zh) 利用写缓存优化存储设备性能
CN103605833B (zh) 一种对存储阵列***的性能进行仿真的方法及装置
CN104331525B (zh) 基于重复数据删除的共享方法
CN104252423B (zh) 基于多内核处理器的一致性处理方法和装置
CN106557277B (zh) 磁盘阵列的读方法及装置
CN110515872A (zh) 直接内存存取方法、装置、专用计算芯片及异构计算***
CN115048034A (zh) 用于sgl的存储空间映射方法及其装置
US9632950B2 (en) Storage control device controlling access to a storage device and access controlling method of a storage device

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant