我正在尝试在C程序中使用brk()函数。我的目标是通过检查当前程序中断(pb),直接使用它(作为较大测试的一部分)

void *current_break = sbrk(0);


执行一个malloc(用于测试,因为分配的空间足够大,有时应执行brk作为malloc的测试)

void* mallow_return = malloc(1);


然后直接使用当前地址+增量直接执行brk()(并检查是否增加了pb):

int increase = 0x01;
void * newbreak = current_break + increase;
int return_value = brk(&newbreak);


我的问题是,既不使用较大的malloc(malloc(5000;))也不使用(对齐或不对齐的)brk()来调用pb。当检查errno时,我得到一个


  无法分配内存!error (as given by strerror(errno)


有人可以看到为什么我仍然无法增加程序中断吗?

感谢您的提示!

(系统是:内核为4.19的Debian 10(破坏者))

编辑:根据要求,这是主要功能,包括:

#include <unistd.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <stdlib.h>

void main(int argc, char **argv)
{

printf("[+] Get current program break\n");
void *current_break = sbrk(0);
printf("\t[+] Current break point=\t%#x\n", current_break);


printf("[+] Malloc should call brk as well\n");
void* mallow_return = malloc(1);

printf("[+] Check if malloc changes PB\n");
void *after_break = sbrk(0);
printf("\t[+] After malloc pbreak=\t%#x\n", after_break);


int increase = 0x01;
printf("\t[+] Increasing p-break direclyby %d\n", increase);


void * newbreak = current_break + increase;
printf("\t[+] Setting break point to=\t%#x\n", newbreak);


int return_value = brk(&newbreak);

//check if error was thrown
int errornumber = errno;
if (errornumber != 0)
{
    printf("\t[+] Error: %s!\n", strerror(errornumber));
    return -1;
}

//check if pb was set now
printf("\t[?] New program break value?\t%#x\n", sbrk(0));
printf("[?] Return value of brk: %d\n", return_value);

return;
}

最佳答案

(感谢@Antii Haapala,他将其发布为评论。)

我们需要在此处删除“&”号:


int return_value = brk(&newbreak);



那条线应该很简单

int return_value = brk(newbreak);

关于c - Linux:brk()错误“无法分配内存”,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/58373192/

10-11 15:46