- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我尝试写一个非常简单的操作系统来更好地理解基本原理。我需要实现用户空间 malloc。所以一开始我想在我的 linux 机器上实现和测试它。
起初我通过以下方式实现了sbrk()函数
void* sbrk( int increment ) {
return ( void* )syscall(__NR_brk, increment );
}
但是这段代码不起作用。相反,当我使用 os 提供的 sbrk 时,它工作正常。
我尝试使用 sbrk() 的另一个实现
static void *sbrk(signed increment)
{
size_t newbrk;
static size_t oldbrk = 0;
static size_t curbrk = 0;
if (oldbrk == 0)
curbrk = oldbrk = brk(0);
if (increment == 0)
return (void *) curbrk;
newbrk = curbrk + increment;
if (brk(newbrk) == curbrk)
return (void *) -1;
oldbrk = curbrk;
curbrk = newbrk;
return (void *) oldbrk;
}
sbrk 从此函数调用
static Header *morecore(unsigned nu)
{
char *cp;
Header *up;
if (nu < NALLOC)
nu = NALLOC;
cp = sbrk(nu * sizeof(Header));
if (cp == (char *) -1)
return NULL;
up = (Header *) cp;
up->s.size = nu; // ***Segmentation fault
free((void *)(up + 1));
return freep;
}
这段代码也行不通,在线 (***) 我得到段错误。哪里出了问题?
谢谢大家。我已经使用 sbrk 的新实现解决了我的问题。给定的代码工作正常。
void* __sbrk__(intptr_t increment)
{
void *new, *old = (void *)syscall(__NR_brk, 0);
new = (void *)syscall(__NR_brk, ((uintptr_t)old) + increment);
return (((uintptr_t)new) == (((uintptr_t)old) + increment)) ? old :
(void *)-1;
}
最佳答案
第一个 sbrk
应该有一个 long increment
。而你忘记处理错误(并设置errno
)
第二个sbrk
函数没有改变address space (正如 sbrk
所做的那样)。您可以使用 mmap
来更改它(但是使用 mmap
而不是 sbrk
不会将内核的数据段结束 View 更新为 sbrk
确实如此)。您可以使用 cat/proc/1234/maps
查询 pid 1234 进程的地址空间)。甚至从程序内部读取(例如使用 fopen
&fgets
)/proc/self/maps
。
顺便说一句,sbrk
已过时(大多数 malloc 实现使用 mmap
),并且根据定义每个 system call (在 syscalls(2) 中列出)由内核执行(对于 sbrk
,内核 保持“数据段”限制!)。所以你无法避免内核,我什至不明白你为什么要模拟任何系统调用。几乎根据定义,您不能模拟系统调用,因为它们是从用户应用程序与内核交互的唯一方式。从用户应用程序来看,每个系统调用都是一个原子基本操作(由单个 SYSENTER
机器指令完成,机器寄存器中有适当的内容)。
你可以使用 strace(1)了解您正在运行的程序完成的实际系统调用。
顺便说一句,GNU libc
是 free software .你可以查看它的源代码。 musl-libc是一个更简单的 libc其代码更具可读性。
最后用 gcc -Wall -Wextra -g
编译并使用 gdb
调试器(如果你愿意,你甚至可以查询寄存器)。也许阅读 x86/64-ABI specification和 Linux Assembly HowTo .
关于linux - 为什么我执行的 sbrk 系统调用不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28825329/
#include #include void *my_malloc(size_t size){ void *p; void *q; p = sbrk(0); /* If sbrk fails,
我的分配代码是 dat* data = NULL; data = sbrk(SIZE); if((int) data != -1){ return data }else{ printf("N
我想知道是否有人已经看到 sbrk(0) 失败? 我的意思是,如果你能达到这个功能,你显然之前就有访问内存的权限,所以检查当前的中断位置应该没问题,对吧? 编辑:例如,我应该考虑错误异常吗? 最佳答案
当 sbrk() 返回指向堆起始地址的指针时,地址是升序还是降序?例如,如果我有一个从地址 1 到 10 的 10 字节堆,sbrk() 会返回指向地址 10 或 1 的指针吗? 类似地,堆地址往往会
我在使用 sbrk 释放内存时遇到了问题。我向 sbrk 传递了一个负值,但它不会减少堆的开始。这是代码 int main(int argc, char** argv) { void * a
我正在尝试了解 sbrk 的工作原理。 这是我的小代码: int main() { printf("end of the break : %p\n", sbrk(0)); prin
因此,作为挑战和性能,我正在用汇编语言编写一个简单的服务器。我知道的唯一方法是通过系统调用。 (通过 int 0x80)显然,我将需要比在汇编或加载时分配的内存更多的内存,所以我阅读并决定我想使用 s
在32位Linux系统上,一个进程最多可以访问4GB的虚拟地址空间;然而,在保留其中任何一项方面,进程似乎在不同程度上是保守的。因此,使用 malloc 的程序偶尔会通过系统调用 sbrk/brk 增
我写了这个malloc的小版本(没有 free): #include #include #include #define word_size sizeof(intptr_t) #define a
我正在尝试在我的 mac(运行 Sierra)上构建一个大型 binutils 文件,每次尝试构建时,都会出现错误,提示“sbrk 已弃用”。我尝试在 Makefile 中的 CFLAGS 中添加“-
好的,所以我有一个看起来像的结构 typedef struct meta { size_t size; struct meta* next; struct meta* prev
我有一个游戏引擎,我想快速查看它使用了多少堆,所以我实现了这两个小例程 static void * start_memory = 0; unsigned long System::memoryUsag
我想知道是否有比malloc/free低一级的跨平台分配器。 例如,我想要一些在 Linux 中简单地调用 sbrk 并在 Windows 中调用 VirtualAlloc 的东西(可能还有两个类似的
以下是一个简单的 malloc 实现的代码。链表由用于内存管理的头指针和尾指针启动。现在在函数中,只有一个调用在列表未初始化时实现,即列表的头部被初始化。一旦我将底层指针返回到 main,程序就会给出
我的程序很简单, ... #define TO_INT(a) (*(int *)a) void *pool_head; void *pool_tail; ... pool_head = sbrk(BU
我尝试写一个非常简单的操作系统来更好地理解基本原理。我需要实现用户空间 malloc。所以一开始我想在我的 linux 机器上实现和测试它。 起初我通过以下方式实现了sbrk()函数 void* sb
我正在尝试创建我自己的 malloc 函数,但我还没有完成。这是我的代码的相关部分: mymalloc.h : #pragma once #include typedef struct METADA
我正在尝试使用 sbrk 系统调用请求一个内存页并将该页分成小块,但我的代码总是遇到一些无效内存: void sbrkBlocks() { int *b = sbrk(0); if(s
我想弄清楚可以使用 malloc() 为进程分配多少内存。 所以要点是: start = sbrk(0); malloc(1); /* so space is given to the data se
我有一个自定义分配器函数,它使用 sbrk() 来获取内存。当不再需要它时,如何释放它? 对于 malloc() 是否有等同于 free() 的函数? 还是我必须使用 brk() 来设置数据段的结尾?
我是一名优秀的程序员,十分优秀!