#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
#include <errno.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <libpmem.h>
#include <sys/time.h>
//編譯運行
//g++ DRAM_NVM_Bandwidth.cpp -o DRAM_NVM_Bandwidth -lpmem
//NOTE:
//每次運行后,去PATH路徑下刪除生成的文件,才可以運行第二次。
//詳情:
//https://pmem.io/pmdk/
/* using 4k of pmem for this example */
// 1GB
#define PMEM_LEN 1073741824
// #define PMEM_LEN 16384
#define PATH "/mnt/pmem/test_lz"
int main(int argc, char *argv[])
{
struct timeval tvs,tve;
char *pmemaddr1; //這個就是NVM上的地址
char *pmemaddr2; //這個就是NVM上的地址
size_t mapped_len; //NVM文件的總大小
int is_pmem1; //是否識別為持久性內(nèi)存,1 是 ,0 否。 假如為0的話表示PATH這個地址現(xiàn)在不是在NVM上(要重新掛載一下) -命令: mount -o dax,noatime /dev/pmem0 /mnt/pmem/
int is_pmem2;
char *dramaddr1;
char *dramaddr2;
dramaddr1 = (char *)malloc(PMEM_LEN);
dramaddr2 = (char *)malloc(PMEM_LEN);
/* create a pmem file and memory map it */
if ((pmemaddr1 = (char *)pmem_map_file(PATH, PMEM_LEN, PMEM_FILE_CREATE,
0666, &mapped_len, &is_pmem1)) == NULL)
{
perror("pmem_map_file");
exit(1);
}
if ((pmemaddr2 = (char *)pmem_map_file(PATH, PMEM_LEN, PMEM_FILE_CREATE,
0666, &mapped_len, &is_pmem2)) == NULL)
{
perror("pmem_map_file");
exit(1);
}
printf("%d %d\n", is_pmem1,is_pmem2); //假如為 1 ,后面就可以用這個指針了
/* store a string to the persistent memory */
// pmem_memset_persist(pmemaddr1, '1', PMEM_LEN);
/*
***************************************************************************
************************* DRAM -> NVM *************************************
***************************************************************************
*/
memset(dramaddr1, 'b', PMEM_LEN);
gettimeofday(&tvs,NULL);
// memcpy(pmemaddr1,dramaddr,PMEM_LEN);
pmem_memcpy(pmemaddr1,dramaddr1,PMEM_LEN,0);
// pmem_memcpy_nodrain(pmemaddr1,dramaddr,PMEM_LEN);
gettimeofday(&tve,NULL);
// second
double span = tve.tv_sec-tvs.tv_sec + (tve.tv_usec-tvs.tv_usec)/1000000.0;
printf("DRAM -> NVM time: %.4f\n",span);
printf("The DRAM to NVM bandwidth is: %.4f GB/s\n",PMEM_LEN/1024/1024/1024/span);
// printf("%c\n",pmemaddr1[0]);
/*
***************************************************************************
************************* NVM -> DRAM *************************************
***************************************************************************
*/
// pmem_memset_persist(pmemaddr, '1', PMEM_LEN);
memset(pmemaddr2, 'c', PMEM_LEN);
gettimeofday(&tvs,NULL);
pmem_memcpy(dramaddr2,pmemaddr2,PMEM_LEN,0);
gettimeofday(&tve,NULL);
// second
span = tve.tv_sec-tvs.tv_sec + (tve.tv_usec-tvs.tv_usec)/1000000.0;
printf("NVM -> DRAM time: %.4f\n",span);
printf("The NVM to DRAM bandwidth is: %.4f GB/s\n",PMEM_LEN/1024/1024/1024/span);
printf("%c\n",dramaddr2[0]);
}
NVM實際測試代碼
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
相關(guān)閱讀更多精彩內(nèi)容
- 代碼覆蓋率 代碼覆蓋率是軟件測試中一個重要的評價指標。主要是指程序運行過程中,被執(zhí)行到的代碼在總代碼中的占比程度,...
- 默認的情況下,Android studio會幫助默認建立兩個不同的測試 folder - 單元測試 (就是 jav...
- 大多數(shù)測試人員認為Selenium是滿足其測試自動化需求的自動化框架。作為全球測試人員使用的開放源框架,Selen...
- 是新技術(shù)? 其實零代碼/低代碼并非什么新鮮的概念,2000年左右就開始有了。之所以在現(xiàn)有開發(fā)工具的基礎(chǔ)上設計開發(fā)平...