我希望有人能够向我解释这个问题。我正在编写自己的操作系统,并开始编写内存管理器。编译内核时,我一直收到一个奇怪的警告。这个警告对我来说是相当矛盾的。该函数正在获取它所期望的参数类型,但是抱怨就好了。一切运行正常,我能够获得初始化内存管理器所需的信息。你能告诉我是什么导致了这个吗?
$ HOME / opt / cross / bin / i686-elf-gcc -c -ffreestanding -O2 -Wall -Wextra -std = gnu99 -ggdb -isystem src / h -o build / kernel.co src / c / kernel .C
src / c / kernel.c:在函数'kernel_main'中: src / c / kernel.c:29:2:警告:从不兼容的指针类型传递'memory_manager_initialize'的参数1
memory_manager_initialize(mboot_ptr); // wtf会导致警告吗?
在src / h / system.h:39:0中包含的文件中,来自src / h / multiboot.h:4,来自src / c / kernel.c:1:
src / h / memory.h:35:6:注意:预期'struct multiboot *'但参数类型为'struct multiboot *'
void memory_manager_initialize(struct multiboot * mboot_ptr);
这是GRUB调用的加载程序的代码。
# Declare constants used for the multiboot header
.set ALIGN, 1<<0
.set MEMINFO, 1<<1
.set MAGIC, 0x1BADB002
.set FLAGS, ALIGN | MEMINFO
.set CHECKSUM, -(MAGIC + FLAGS)
.global .multiboot
.extern code
.extern bss
.extern end
.section .multiboot
#.align 4
.long MAGIC
.long FLAGS
.long CHECKSUM
.long .multiboot
.long code
.long bss
.long end
.long _start
.section .text
.global _start
.extern kernel_main
.type _start, @function
_start:
push %esp
push %ebx
cli
call kernel_main
.hang:
jmp .hang
.size _start, . - _start
这是我内核发出警告的代码。
int kernel_main(struct multiboot *mboot_ptr, u32int initial_stack)
{
initial_esp = initial_stack;
gdt_initialize();
idt_initialize();
memset((u8int *) &interrupt_handler, 0, sizeof(isr) * 256);
enable_interrupts();
timer_initialize(100);
keyboard_initialize();
keyboard_set_handler(kernel_keyboard_handler);
vga_set_handler(kernel_vga_handler);
memset((u8int *) terminal_buffer, 0, MAX_TERMINAL_BUFFER_SIZE); // clear the terminal buffer (initalize it to 0 when we start running)
// i need to get the memory management going.
memory_manager_initialize(mboot_ptr); // wtf does this cause a warning?
被调用的函数定义为
void memory_manager_initialize(struct multiboot *mboot_ptr)
答案 0 :(得分:3)
您的结构定义为:
typedef struct {
/* Stuff */
} multiboot;
何时应定义为:
typedef struct multiboot { // Note difference in this line
/* Stuff */
} multiboot;
或memory_manager_initialize()
的函数原型出现在编译器看到struct multiboot
的定义之前。