| /* SPDX-License-Identifier: GPL-2.0-only */ |
| /* |
| * Copyright (C) 2000 Russell King |
| */ |
| #include <asm/vmlinux.lds.h> |
| |
| #ifdef CONFIG_CPU_ENDIAN_BE8 |
| #define ZIMAGE_MAGIC(x) ( (((x) >> 24) & 0x000000ff) | \ |
| (((x) >> 8) & 0x0000ff00) | \ |
| (((x) << 8) & 0x00ff0000) | \ |
| (((x) << 24) & 0xff000000) ) |
| #else |
| #define ZIMAGE_MAGIC(x) (x) |
| #endif |
| |
| OUTPUT_ARCH(arm) |
| ENTRY(_start) |
| SECTIONS |
| { |
| /DISCARD/ : { |
| COMMON_DISCARDS |
| *(.ARM.exidx*) |
| *(.ARM.extab*) |
| *(.note.*) |
| *(.rel.*) |
| *(.printk_index) |
| /* |
| * Discard any r/w data - this produces a link error if we have any, |
| * which is required for PIC decompression. Local data generates |
| * GOTOFF relocations, which prevents it being relocated independently |
| * of the text/got segments. |
| */ |
| *(.data) |
| } |
| |
| . = TEXT_START; |
| _text = .; |
| |
| .text : { |
| _start = .; |
| *(.start) |
| *(.text) |
| *(.text.*) |
| ARM_STUBS_TEXT |
| } |
| .table : ALIGN(4) { |
| _table_start = .; |
| LONG(ZIMAGE_MAGIC(6)) |
| LONG(ZIMAGE_MAGIC(0x5a534c4b)) |
| LONG(ZIMAGE_MAGIC(__piggy_size_addr - _start)) |
| LONG(ZIMAGE_MAGIC(_kernel_bss_size)) |
| LONG(ZIMAGE_MAGIC(TEXT_OFFSET)) |
| LONG(ZIMAGE_MAGIC(MALLOC_SIZE)) |
| LONG(0) |
| _table_end = .; |
| } |
| .rodata : { |
| *(.rodata) |
| *(.rodata.*) |
| *(.data.rel.ro) |
| *(.data.rel.ro.*) |
| } |
| .piggydata : { |
| *(.piggydata) |
| __piggy_size_addr = . - 4; |
| } |
| |
| . = ALIGN(4); |
| _etext = .; |
| |
| .got.plt : { *(.got.plt) } |
| #ifndef CONFIG_EFI_STUB |
| _got_start = .; |
| .got : { *(.got) } |
| _got_end = .; |
| #endif |
| |
| /* ensure the zImage file size is always a multiple of 64 bits */ |
| /* (without a dummy byte, ld just ignores the empty section) */ |
| .pad : { BYTE(0); . = ALIGN(8); } |
| |
| #ifdef CONFIG_EFI_STUB |
| .data : ALIGN(4096) { |
| __pecoff_data_start = .; |
| _got_start = .; |
| *(.got) |
| _got_end = .; |
| /* |
| * The EFI stub always executes from RAM, and runs strictly before the |
| * decompressor, so we can make an exception for its r/w data, and keep it |
| */ |
| *(.data.efistub .bss.efistub) |
| __pecoff_data_end = .; |
| |
| /* |
| * PE/COFF mandates a file size which is a multiple of 512 bytes if the |
| * section size equals or exceeds 4 KB |
| */ |
| . = ALIGN(512); |
| } |
| __pecoff_data_rawsize = . - ADDR(.data); |
| #endif |
| |
| _edata = .; |
| |
| /* |
| * The image_end section appears after any additional loadable sections |
| * that the linker may decide to insert in the binary image. Having |
| * this symbol allows further debug in the near future. |
| */ |
| .image_end (NOLOAD) : { |
| /* |
| * EFI requires that the image is aligned to 512 bytes, and appended |
| * DTB requires that we know where the end of the image is. Ensure |
| * that both are satisfied by ensuring that there are no additional |
| * sections emitted into the decompressor image. |
| */ |
| _edata_real = .; |
| } |
| |
| _magic_sig = ZIMAGE_MAGIC(0x016f2818); |
| _magic_start = ZIMAGE_MAGIC(_start); |
| _magic_end = ZIMAGE_MAGIC(_edata); |
| _magic_table = ZIMAGE_MAGIC(_table_start - _start); |
| |
| . = BSS_START; |
| __bss_start = .; |
| .bss : { *(.bss .bss.*) } |
| _end = .; |
| |
| . = ALIGN(8); /* the stack must be 64-bit aligned */ |
| .stack : { *(.stack) } |
| |
| PROVIDE(__pecoff_data_size = ALIGN(512) - ADDR(.data)); |
| PROVIDE(__pecoff_end = ALIGN(512)); |
| |
| STABS_DEBUG |
| DWARF_DEBUG |
| ARM_DETAILS |
| |
| ARM_ASSERTS |
| } |
| ASSERT(_edata_real == _edata, "error: zImage file size is incorrect"); |