linux 64位 地址分配,强制内存分配在64位Linux上从较高地址(> 4GB)分配

博客探讨了在Linux环境中如何强制内存分配在4GB以上的策略,类似于Windows上的VirtualAlloc和MEM_TOP_DOWN选项。作者尝试使用mmap()和链接器脚本,但未成功实现目标。提供的代码示例展示了使用mmap()进行内存映射的尝试,但并未能确保分配的内存位于高位地址。
摘要由CSDN通过智能技术生成

这就是我想要做的:

我有一个为64位Linux构建的库。

然后我创建了一个链接该库的应用程序。

我想确保在运行应用程序时,从库中分配的内存始终位于较高位置(> 4GB)。

在Windows上,用户可以强制分配从较低地址之前的较高地址进行分配以进行测试,在调用VirtualAlloc时指定MEM_TOP_DOWN或将以下注册表值设置为0x100000:

HKEY_LOCAL_MACHINE \ System \ CurrentControlSet \ Control \ Session Manager \ Memory Management \ AllocationPreference

我想知道Linux上是否有类似的策略。我理解Linux内存管理与Window不同,但我发现了一些线索,比如使用mmap()或链接器脚本。但我未能实现这一目标。有人可以提供更多信息吗?

#include

#include

#include

#include

#define handle_error(msg) \

do { perror(msg); exit(EXIT_FAILURE); } while (0)

int main()

{

void *addr1=0, *addr2=0;

long sz = sysconf(_SC_PAGE_SIZE); // get page size

size_t length = sz*1000*1000; // 1,000,000 pages

int fd = -1;

printf("page size = %ld\n", sz);

// find some available address

int *p = (int*)malloc(sizeof(int));

long start = (long)p + sizeof(int);

free(p); // free it anyway

start += (sz-(start % sz)); // page alignment

printf("start = 0x%lx\n", start);

// mmap fixed

addr1 = mmap((void*)start, length, PROT_NONE,

MAP_PRIVATE|MAP_NORESERVE|MAP_ANONYMOUS|MAP_FIXED, fd, 0);

if (addr1 == MAP_FAILED)

handle_error("mmap");

printf("first map: %tx\n", addr1);

//msync(addr1, length, 0);

// another mmap

addr2 = mmap(NULL, sz*10, PROT_NONE,

MAP_ANONYMOUS|MAP_PRIVATE, fd, 0);

if (addr2 == MAP_FAILED)

handle_error("mmap");

printf("second map: 0x%tx\n", addr2);

// test whether the memory is still available

p = (int*)malloc(sizeof(int)*10);

printf("allocated address: 0x%tx\n", p);

return 0;

}

输出:

page size = 4096

start = 0x1d77000

first map: 1d77000

second map: 0x7f5f26c2f000

allocated address: 0x1d76030

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值