CN104809039B - 基于物理内存分配映射的内存检测方法 - Google Patents
基于物理内存分配映射的内存检测方法 Download PDFInfo
- Publication number
- CN104809039B CN104809039B CN201510201575.4A CN201510201575A CN104809039B CN 104809039 B CN104809039 B CN 104809039B CN 201510201575 A CN201510201575 A CN 201510201575A CN 104809039 B CN104809039 B CN 104809039B
- Authority
- CN
- China
- Prior art keywords
- physical memory
- memory
- test program
- user space
- kernel module
- 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.)
- Active
Links
Landscapes
- Techniques For Improving Reliability Of Storages (AREA)
- For Increasing The Reliability Of Semiconductor Memories (AREA)
Abstract
本发明提供一种基于物理内存分配映射的内存检测方法,包括:用户态测试程序向内核模块请求分配物理内存,所述内核模块对物理内存进行检索,分配空闲的待测物理内存给所述用户态测试程序;所述内核模块将所述待测物理内存映射到所述用户态测试程序的地址空间;所述用户态测试程序通过运行内存检测算法对所述待测物理内存进行读写校验测试;当所述读写校验测试出错时,根据所述映射获取出错物理内存地址,根据所述出错物理内存地址查找到内存插槽。本发明通过将物理内存分配映射技术与内存检测技术结合,实现了对内存进行高效并行检测处理,并准确有效地对出错位置进行定位,具有检测效率高、定位准确、应用范围广等优点。
Description
技术领域
本发明涉及内存检测技术领域,尤其涉及一种基于物理内存分配映射的内存检测方法。
背景技术
现有的内存检测方法通常基于两种应用环境:一种基于BIOS环境,另一种基于OS环境。
基于BIOS环境的检测方法的运行环境相对单纯,且更贴近底层硬件,通常测试效果较好,错误定位较为准确。但是由于受限运行环境,难以执行并行化处理,因此测试效率通常相对较低。同时也不太适合执行更大规模的整合测试。
基于OS环境的检测方法基于OS环境,通常灵活性较好适合于大规模应用,但因为存在物理内存信息被OS以逻辑形式屏蔽的缺陷,通常检测效果较差,通常可以发现问题的存在,但是无法定位到具体的位置。
以检测工具memtester为例,虽然其程序声称可以实现基于物理内存的分配测试,但实际上该检测工具所采用的技术手段是映射/dev/mem设备文件,该方法在稍早一些的发行版本中出于安全性的考虑已被禁止使用,因此并不能实现相关功能。
发明内容
在下文中给出关于本发明的简要概述,以便提供关于本发明的某些方面的基本理解。应当理解,这个概述并不是关于本发明的穷举性概述。它并不是意图确定本发明的关键或重要部分,也不是意图限定本发明的范围。其目的仅仅是以简化的形式给出某些概念,以此作为稍后论述的更详细描述的前序。
本发明提供一种能执行并行处理,并实现准确定位的基于物理内存分配映射的内存检测方法。
本发明提供一种基于物理内存分配映射的内存检测方法,包括:
用户态测试程序向内核模块请求分配物理内存,所述内核模块对物理内存进行检索,分配空闲的待测物理内存给所述用户态测试程序;
所述内核模块将所述待测物理内存映射到所述用户态测试程序的地址空间;
所述用户态测试程序通过运行内存检测算法对所述待测物理内存进行读写校验测试;
当所述读写校验测试出错时,根据所述映射获取出错物理内存地址,根据所述出错物理内存地址查找到内存插槽。
本发明提供的基于物理内存分配映射的内存检测方法通过将物理内存分配映射技术与内存检测技术结合起来,实现了对内存进行高效并行检测处理,并准确有效地对出错位置进行定位,同时还可以采用多种内存检测算法进行检测,应用范围较为广泛,使用更灵活。综上所述,本发明基于物理内存分配映射的内存检测方法具有检测效率高、定位准确、应用范围广等优点。
附图说明
参照下面结合附图对本发明实施例的说明,会更加容易地理解本发明的以上和其它目的、特点和优点。附图中的部件只是为了示出本发明的原理。在附图中,相同的或类似的技术特征或部件将采用相同或类似的附图标记来表示。
图1为本发明基于物理内存分配映射的内存检测方法一种实施方式的流程示意图。
图2为本发明基于物理内存分配映射的内存检测方法一种实施方式中步骤S20的流程示意图。
图3为本发明基于物理内存分配映射的内存检测方法一种优选实施方式中步骤S20的流程示意图。
图4为本发明基于物理内存分配映射的内存检测方法一种实施方式中步骤S40的流程示意图。
图5为本发明基于物理内存分配映射的内存检测方法一种实施方式中步骤S80的流程示意图。
图6为本发明基于物理内存分配映射的内存检测方法一种优选实施方式中,在一个60核处理器的环境中启动60个测试线程测试60G内存的内存分配占用状况的示意图。
图7为本发明基于物理内存分配映射的内存检测方法一种优选实施方式中,用户态测试程序的地址空间的逻辑地址与物理内存地址的对应关系示意图。
图8为本发明基于物理内存分配映射的内存检测方法一种优选实施方式中,出错物理内存地址与SMBIOS信息对应关系示意图。
具体实施方式
下面参照附图来说明本发明的实施例。在本发明的一个附图或一种实施方式中描述的元素和特征可以与一个或更多个其它附图或实施方式中示出的元素和特征相结合。应当注意,为了清楚的目的,附图和说明中省略了与本发明无关的、本领域普通技术人员已知的部件和处理的表示和描述。
图1为本发明基于物理内存分配映射的内存检测方法一种实施方式的流程示意图。
如图1所示,在本实施方式中,本发明基于物理内存分配映射的内存检测方法包括:
S20:用户态测试程序向内核模块请求分配物理内存,所述内核模块对物理内存进行检索,分配空闲的待测物理内存给所述用户态测试程序。
S40:所述内核模块将所述待测物理内存映射到所述用户态测试程序的地址空间。
S60:所述用户态测试程序通过运行内存检测算法对所述待测物理内存进行读写校验测试。
S80:当所述读写校验测试出错时,根据所述映射获取出错物理内存地址,根据所述出错物理内存地址查找到内存插槽。
图2为本发明基于物理内存分配映射的内存检测方法一种实施方式中步骤S20的流程示意图。
如图2所示,步骤S20包括:
S23:用户态测试程序向内核模块请求分配物理内存。
S25:所述内核模块扫描物理内存使用状况信息,锁定当前状况为空闲的待测物理内存,将所述待测物理内存的页号返回给所述用户态测试程序。
S27:所述内核模块更新所述物理内存使用状况信息。
优选地,当所述用户态测试程序运行在多核处理器环境下时,所述用户态测试程序通过每个处理器核心发起一个测试线程。所述步骤S25还包括:所述内核模块将所述待测物理内存平均分配给所述测试线程。
图6为本发明基于物理内存分配映射的内存检测方法一种优选实施方式中,在一个60核处理器的环境中启动60个测试线程测试60G内存的内存分配占用状况的示意图。如图6所示,在测试过程中内核模块将60G内存分配给所述测试线程。
图3为图2所示步骤S20的优选实施方式的流程示意图。
相较于图2所示步骤S20,图3所示步骤S20还包括:
S21:加载支持物理内存相关操作的内核模块进入系统内核空间。
图4为本发明基于物理内存分配映射的内存检测方法一种实施方式中步骤S40的流程示意图。
如图4所示,在本实施方式中,步骤S40包括:
S43:所述用户态测试程序发送所述页号和映射请求至所述内核模块。
S45:所述内核模块以所述页号作为参数对页表进行配置,完成所述待测物理内存对所述用户态测试程序的地址空间的映射。
优选地,所述步骤S60中,所述测试线程各自运行所述内存检测算法,并行对各自分配到的待测物理内存进行读写校验测试。
所述读写校验测试包括对所述待测物理内存分别进行写操作和读操作并进行比对校验,当比对结果一致时校验结果为正常,当比对结果不一致时校验结果为错误。
图5为本发明基于物理内存分配映射的内存检测方法一种实施方式中步骤S80的流程示意图。
如图5所示,在本实施方式中,步骤S80包括:
S83:当所述读写校验测试出错时,根据所述映射获取出错物理内存地址。
S85:将所述出错物理内存地址与SMBIOS信息进行比对,得到所述出错物理内存地址对应的内存插槽。
图7为完成所述映射后,所述地址空间的逻辑地址和所述待测物理内存的物理地址的对应关系示意图。图8为出错物理内存地址与SMBIOS信息对应关系示意图。
如图7和图8所示,通过校验出错的逻辑地址,和所述逻辑地址与所述物理的对应关系,获得出错物理内存地址。在图8所示示例中,当出错物理内存地址在“0x00000000000”(图中所示starting address)与“0x0007FFFFFFF”(图中所示ending address)之间时,找到相对应的type20中的物理设备句柄(physical device handle)0x0024,从而在对应的句柄0x0024中找到定位信息(locator):CPU0_DimmA0,最终准确定位到出错的内存插槽。
综上所述,本发明提供的基于物理内存分配映射的内存检测方法通过将物理内存分配映射技术与内存检测技术结合起来,实现了对内存进行高效并行检测处理,并准确有效地对出错位置进行定位,同时还可以采用多种内存检测算法进行检测,应用范围较为广泛,使用更灵活。本发明具有检测效率高、定位准确、应用范围广等优点。
最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。
Claims (4)
1.一种基于物理内存分配映射的内存检测方法,其特征在于,包括:
用户态测试程序向内核模块请求分配物理内存,所述内核模块对物理内存进行检索,分配空闲的待测物理内存给所述用户态测试程序;
所述内核模块将所述待测物理内存映射到所述用户态测试程序的地址空间;
所述用户态测试程序通过运行内存检测算法对所述待测物理内存进行读写校验测试;
当所述读写校验测试出错时,根据所述映射获取出错物理内存地址,根据所述出错物理内存地址查找到内存插槽,所述根据所述出错物理内存地址查找到内存插槽包括:根据出错物理内存地址找到相对应的type20中的物理设备句柄(physical device handle)0x0024,从而在对应的句柄0x0024中找到定位信息(locator):CPU0_DimmA0,最终准确定位到出错的内存插槽;
所述“用户态测试程序向内核模块请求分配物理内存,所述内核模块对物理内存进行检索,分配空闲的待测物理内存给所述用户态测试程序”包括:
加载支持物理内存相关操作的内核模块进入系统内核空间;
用户态测试程序向内核模块请求分配物理内存;
所述内核模块扫描物理内存使用状况信息,锁定当前状况为空闲的待测物理内存,将所述待测物理内存的页号返回给所述用户态测试程序,当所述用户态测试程序运行在多核处理器环境下,所述用户态测试程序通过每个处理器核心发起一个测试线程,所述内核模块将所述待测物理内存平均分配给所述测试线程;
所述内核模块更新所述物理内存使用状况信息。
2.根据权利要求1所述的内存检测方法,其特征在于,所述“所述内核模块将所述待测物理内存映射到所述用户态测试程序的地址空间”包括:
所述用户态测试程序发送所述页号和映射请求至所述内核模块;
所述内核模块以所述页号作为参数对页表进行配置,完成所述待测物理内存对所述用户态测试程序的地址空间的映射。
3.根据权利要求1所述的内存检测方法,其特征在于,所述测试线程各自运行所述内存检测算法,并行对各自分配到的待测物理内存进行读写校验测试。
4.根据权利要求3所述的内存检测方法,其特征在于,所述读写校验测试包括对所述待测物理内存分别进行写操作和读操作并进行比对校验,当比对结果一致时校验结果为正常,当比对结果不一致时校验结果为错误。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510201575.4A CN104809039B (zh) | 2015-04-24 | 2015-04-24 | 基于物理内存分配映射的内存检测方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510201575.4A CN104809039B (zh) | 2015-04-24 | 2015-04-24 | 基于物理内存分配映射的内存检测方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN104809039A CN104809039A (zh) | 2015-07-29 |
CN104809039B true CN104809039B (zh) | 2019-01-01 |
Family
ID=53693884
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201510201575.4A Active CN104809039B (zh) | 2015-04-24 | 2015-04-24 | 基于物理内存分配映射的内存检测方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN104809039B (zh) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105824730A (zh) * | 2016-03-16 | 2016-08-03 | 北京珠穆朗玛移动通信有限公司 | 一种硬件诊断修复方法及装置 |
CN108132860A (zh) * | 2016-12-01 | 2018-06-08 | 英业达科技有限公司 | 依存储器模块的物理地址范围测试存储器的系统及方法 |
TWI620191B (zh) * | 2016-12-13 | 2018-04-01 | 英業達股份有限公司 | 依記憶體模組之物理位址範圍測試記憶體之系統及方法 |
CN108984423B (zh) * | 2017-05-31 | 2020-10-27 | 龙芯中科技术有限公司 | 一种系统级芯片的地址空间验证方法和系统 |
CN107402813B (zh) * | 2017-06-21 | 2020-10-30 | 泰州市元和达电子科技有限公司 | 一种资源分配的方法及移动终端、计算机可读存储介质 |
CN109901956A (zh) * | 2017-12-08 | 2019-06-18 | 英业达科技有限公司 | 内存整体测试的系统及其方法 |
CN111221685A (zh) * | 2018-11-26 | 2020-06-02 | 中兴通讯股份有限公司 | 一种物理内存检测方法、装置、设备及可读存储介质 |
CN113821369A (zh) * | 2021-11-23 | 2021-12-21 | 苏州浪潮智能科技有限公司 | 一种内存巡检的方法、装置及介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040181656A1 (en) * | 2003-03-10 | 2004-09-16 | Dell Products L.P. | System and method for testing memory during boot operation idle periods |
CN1932773A (zh) * | 2005-09-16 | 2007-03-21 | 英业达股份有限公司 | 物理存储器的测试方法 |
CN1991770A (zh) * | 2005-12-28 | 2007-07-04 | 英业达股份有限公司 | Linux系统下物理内存的测试方法 |
CN101055533A (zh) * | 2007-05-28 | 2007-10-17 | 中兴通讯股份有限公司 | 一种多线程处理器动态内存管理系统及方法 |
CN102841832A (zh) * | 2011-06-24 | 2012-12-26 | 鸿富锦精密工业(深圳)有限公司 | 出错内存条定位系统及方法 |
-
2015
- 2015-04-24 CN CN201510201575.4A patent/CN104809039B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040181656A1 (en) * | 2003-03-10 | 2004-09-16 | Dell Products L.P. | System and method for testing memory during boot operation idle periods |
CN1932773A (zh) * | 2005-09-16 | 2007-03-21 | 英业达股份有限公司 | 物理存储器的测试方法 |
CN1991770A (zh) * | 2005-12-28 | 2007-07-04 | 英业达股份有限公司 | Linux系统下物理内存的测试方法 |
CN101055533A (zh) * | 2007-05-28 | 2007-10-17 | 中兴通讯股份有限公司 | 一种多线程处理器动态内存管理系统及方法 |
CN102841832A (zh) * | 2011-06-24 | 2012-12-26 | 鸿富锦精密工业(深圳)有限公司 | 出错内存条定位系统及方法 |
Also Published As
Publication number | Publication date |
---|---|
CN104809039A (zh) | 2015-07-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104809039B (zh) | 基于物理内存分配映射的内存检测方法 | |
KR101025407B1 (ko) | 테스트 데이터 처리 디바이스 및 방법, 테스트 장치 및 컴퓨터 판독가능 매체 | |
US9529692B2 (en) | Memory management tools | |
US9501408B2 (en) | Efficient validation of coherency between processor cores and accelerators in computer systems | |
CN109901956A (zh) | 内存整体测试的系统及其方法 | |
US11257565B2 (en) | Management of test resources to perform testing of memory components under different temperature conditions | |
US20130305252A1 (en) | Method and system for heterogeneous filtering framework for shared memory data access hazard reports | |
JP2007220284A (ja) | 改善された冗長性分析のためのメモリデバイスの欠陥サマリデータの削減 | |
CN106980571A (zh) | 一种测试用例集的构建方法和设备 | |
US11101015B2 (en) | Multi-dimensional usage space testing of memory components | |
CN109271789A (zh) | 恶意进程检测方法、装置、电子设备及存储介质 | |
US10558391B2 (en) | Data processing system and data processing method | |
CN104504331B (zh) | 虚拟化安全检测方法与系统 | |
KR101848450B1 (ko) | 도커 기반의 매니코어 관리 방법 및 이를 수행하는 도커 기반의 매니코어 관리 장치 | |
US9812221B1 (en) | Multi-core cache coherency built-in test | |
US8819494B2 (en) | Automatically changing parts in response to tests | |
US9703599B2 (en) | Assignment control method, system, and recording medium | |
EP3097480A1 (en) | A pattern based configuration method for minimizing the impact of component failures | |
CN104239170A (zh) | Pci设备测试方法及系统 | |
US20220229777A1 (en) | Data storage system with multiple-size object allocator for disk cache | |
US8639978B2 (en) | Topology independent network-based automation infrastructure | |
TWI620191B (zh) | 依記憶體模組之物理位址範圍測試記憶體之系統及方法 | |
KR102179399B1 (ko) | 다양한 속성들에 근거한 스마트 입/출력 스트림 검출 | |
US10503557B2 (en) | Method of processing OpenCL kernel and computing device therefor | |
US9606732B2 (en) | Verification of serialization of storage frames within an address space via multi-threaded programs |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
EXSB | Decision made by sipo to initiate substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |