hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/*
 * U-Boot EFI linker script
 *
 * SPDX-License-Identifier:    BSD-2-Clause
 *
 * Modified from usr/lib32/elf_x86_64_efi.lds in gnu-efi
 */
 
OUTPUT_FORMAT("elf64-x86-64", "elf64-x86-64", "elf64-x86-64")
OUTPUT_ARCH(i386:x86-64)
ENTRY(_start)
SECTIONS
{
   image_base = .;
   .hash : { *(.hash) }    /* this MUST come first, EFI expects it */
   . = ALIGN(4096);
   .eh_frame : {
       *(.eh_frame)
   }
 
   . = ALIGN(4096);
 
   .text : {
       *(.text)
       *(.text.*)
       *(.gnu.linkonce.t.*)
   }
 
   . = ALIGN(4096);
 
   .reloc : {
       *(.reloc)
   }
 
   . = ALIGN(4096);
 
   .data : {
       *(.rodata*)
       *(.got.plt)
       *(.got)
       *(.data*)
       *(.sdata)
       /* the EFI loader doesn't seem to like a .bss section, so we stick
        * it all into .data: */
       *(.sbss)
       *(.scommon)
       *(.dynbss)
       *(.bss)
       *(COMMON)
       *(.rel.local)
 
       /* U-Boot lists and device tree */
       . = ALIGN(8);
       *(SORT(.u_boot_list*));
       . = ALIGN(8);
       *(.dtb*);
   }
 
   . = ALIGN(4096);
   .dynamic : { *(.dynamic) }
   . = ALIGN(4096);
 
   .rela : {
       *(.rela.data*)
       *(.rela.got)
       *(.rela.stab)
   }
 
   . = ALIGN(4096);
   .dynsym : { *(.dynsym) }
   . = ALIGN(4096);
   .dynstr : { *(.dynstr) }
   . = ALIGN(4096);
   .ignored.reloc : {
       *(.rela.reloc)
       *(.eh_frame)
       *(.note.GNU-stack)
   }
 
   .comment 0 : { *(.comment) }
}