我正在编写一个早期的内核堆,以在最终堆运行之前管理一些内存分配。当我为结构指针分配一个地址(其他没有使用的地址)时,它起作用了,当我尝试为结构成员分配值时,问题就来了。
在回答之前,请记住,我没有可以使用的任何C库。通过远程使用QEMU和gdb进行调试。
//The struct
typedef struct mem_block{
mblock_t *prev;
boolean used;
size_t size;
mblock_t *next;
} mblock_t;
//The file-local pointer(before its init)
mblock_t *eheap=NULL;
//Function that assigns the values
mblock_t *init_early_heap(address_t start, size_t size){
if(eheap==NULL){
if(size < sizeof(mblock_t)){
PANIC("Available memory below EHEAP requirement");
}
eheap = (mblock_t*)HEAP_START_ADDRESS;
eheap->prev = NULL;
eheap->next = NULL;
eheap->size = (size_t)(size - sizeof(mblock_t));
eheap->used = false;
print("\nCreated Early Heap at ");
print_hex_long(eheap);
print("\nSize in bytes: ");
print(itos(eheap->size));NL;
}
return eheap;
}
函数返回后,我得到一个指向地址0xC0000000和未触及的成员的指针,因为eheap-> size为0(函数中的size参数为非0)。
答案 0 :(得分:0)
发现的问题:无法读取QEMU中的整个地址空间(A20亮),可以使用低位地址正常工作。 上面的C代码是正确的,现在问题仍然存在于QEMU / GRUB。