From 8659fc0d06f4e37a8c440a10dc0e9e651ebebd16 Mon Sep 17 00:00:00 2001 From: David Date: Tue, 13 Aug 2013 21:17:01 +1200 Subject: Bugfixe --- link.ld | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 link.ld diff --git a/link.ld b/link.ld new file mode 100644 index 0000000..0611c7e --- /dev/null +++ b/link.ld @@ -0,0 +1,36 @@ +/* The bootloader will look at this image and start execution at the symbol designated as the entry point. */ +ENTRY(_start) + +/* Tell where the various sections of the object files will be put in the final kernel image. */ +SECTIONS +{ + /* Begin putting sections at 1 MiB, a conventional place for kernels to be loaded at by the bootloader. */ + . = 1M; + + /* First put the multiboot header, as it is required to be put very early early in the image or the bootloader won't recognize the file format. Next we'll put the .text section. */ + .text BLOCK(4K) : ALIGN(4K) + { + *(.multiboot) + *(.text) + } + + /* Read-only data. */ + .rodata BLOCK(4K) : ALIGN(4K) + { + *(.rodata) + } + + /* Read-write data (initialized) */ + .data BLOCK(4K) : ALIGN(4K) + { + *(.data) + } + + /* Read-write data (uninitialized) and stack */ + .bss BLOCK(4K) : ALIGN(4K) + { + *(COMMON) + *(.bss) + *(.bootstrap_stack) + } +} -- cgit v1.1