1 | /*
|
---|
2 | * TOPPERS PROJECT Home Network Working Group Software
|
---|
3 | *
|
---|
4 | * Copyright (C) 2020 Cores Co., Ltd. Japan
|
---|
5 | *
|
---|
6 | * 上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
|
---|
7 | * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
|
---|
8 | * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
|
---|
9 | * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
|
---|
10 | * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
|
---|
11 | * スコード中に含まれていること.
|
---|
12 | * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
|
---|
13 | * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
|
---|
14 | * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
|
---|
15 | * の無保証規定を掲載すること.
|
---|
16 | * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
|
---|
17 | * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
|
---|
18 | * と.
|
---|
19 | * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
|
---|
20 | * 作権表示,この利用条件および下記の無保証規定を掲載すること.
|
---|
21 | * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
|
---|
22 | * 報告すること.
|
---|
23 | * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
|
---|
24 | * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
|
---|
25 | * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
|
---|
26 | * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
|
---|
27 | * 免責すること.
|
---|
28 | *
|
---|
29 | * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
|
---|
30 | * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
|
---|
31 | * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
|
---|
32 | * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
|
---|
33 | * の責任を負わない.
|
---|
34 | *
|
---|
35 | * @(#) $Id: elf.c 443 2020-07-14 10:49:28Z coas-nagasima $
|
---|
36 | */
|
---|
37 |
|
---|
38 | #include <string.h>
|
---|
39 | #include <elf.h>
|
---|
40 |
|
---|
41 | #define FVECT_SECT __attribute__ ((section (".proginf")))
|
---|
42 |
|
---|
43 | void _start_c(long *args);
|
---|
44 | extern int __start_text, __end_text;
|
---|
45 | extern int __start_rodata, __end_rodata;
|
---|
46 | extern int __start_data, __end_data, __start_idata;
|
---|
47 | extern int __start_bss, __end_bss;
|
---|
48 |
|
---|
49 | typedef struct TProgInf {
|
---|
50 | Elf32_Ehdr ehdr;
|
---|
51 | Elf32_Phdr phdr[3];
|
---|
52 | Elf32_Shdr shdr[4];
|
---|
53 | Elf32_Shdr str_shdr;
|
---|
54 | char shstrtab[sizeof("\0.text\0.rodata\0.data\0.bss\0.shstrtab")];
|
---|
55 | } TProgInf;
|
---|
56 |
|
---|
57 | const TProgInf ProgInf FVECT_SECT = {
|
---|
58 | {
|
---|
59 | .e_ident = { ELFMAG0, ELFMAG1, ELFMAG2, ELFMAG3, ELFCLASS32, ELFDATA2LSB, EV_CURRENT },
|
---|
60 | .e_type = ET_EXEC,
|
---|
61 | .e_machine = EM_ARM,
|
---|
62 | .e_version = EV_CURRENT,
|
---|
63 | .e_entry = (Elf32_Addr)&_start_c,
|
---|
64 | .e_phoff = (Elf32_Off)&((TProgInf *)0)->phdr,
|
---|
65 | .e_shoff = (Elf32_Off)&((TProgInf *)0)->shdr,
|
---|
66 | .e_flags = (Elf32_Word)(EF_ARM_EABI_VER5 | NT_ARM_VFP),
|
---|
67 | .e_ehsize = (Elf32_Half)sizeof(Elf32_Ehdr),
|
---|
68 | .e_phentsize = (Elf32_Half)sizeof(Elf32_Phdr),
|
---|
69 | .e_phnum = (Elf32_Half)(sizeof(ProgInf.phdr) / sizeof(Elf32_Phdr)),
|
---|
70 | .e_shentsize = (Elf32_Half)sizeof(Elf32_Shdr),
|
---|
71 | .e_shnum = (Elf32_Half)(sizeof(ProgInf.shdr) / sizeof(Elf32_Shdr)) + 1,
|
---|
72 | .e_shstrndx = (Elf32_Half)(sizeof(ProgInf.shdr) / sizeof(Elf32_Shdr)),
|
---|
73 | },
|
---|
74 | {
|
---|
75 | {
|
---|
76 | .p_type = (Elf32_Word)PT_LOAD,
|
---|
77 | .p_offset = (Elf32_Off)&((TProgInf *)0)->phdr[0],
|
---|
78 | .p_vaddr = (Elf32_Addr)&__start_text,
|
---|
79 | .p_paddr = (Elf32_Addr)&__start_text,
|
---|
80 | .p_filesz = (Elf32_Word)&__end_text/* - (Elf32_Addr)&__start_text*/,
|
---|
81 | .p_memsz = (Elf32_Word)&__end_text/* - (Elf32_Addr)&__start_text*/,
|
---|
82 | .p_flags = (Elf32_Word)(PF_X | PF_R),
|
---|
83 | .p_align = (Elf32_Word)8,
|
---|
84 | },
|
---|
85 | {
|
---|
86 | .p_type = (Elf32_Word)PT_LOAD,
|
---|
87 | .p_offset = (Elf32_Off)&((TProgInf *)0)->phdr[1],
|
---|
88 | .p_vaddr = (Elf32_Addr)&__start_rodata,
|
---|
89 | .p_paddr = (Elf32_Addr)&__start_rodata,
|
---|
90 | .p_filesz = (Elf32_Word)&__end_rodata/* - (Elf32_Addr)&__start_rodata*/,
|
---|
91 | .p_memsz = (Elf32_Word)&__end_rodata/* - (Elf32_Addr)&__start_rodata*/,
|
---|
92 | .p_flags = (Elf32_Word)(PF_R),
|
---|
93 | .p_align = (Elf32_Word)8,
|
---|
94 | },
|
---|
95 | {
|
---|
96 | .p_type = (Elf32_Word)PT_LOAD,
|
---|
97 | .p_offset = (Elf32_Off)&((TProgInf *)0)->phdr[2],
|
---|
98 | .p_vaddr = (Elf32_Addr)&__start_data,
|
---|
99 | .p_paddr = (Elf32_Addr)&__start_idata,
|
---|
100 | .p_filesz = (Elf32_Word)&__end_data/* - (Elf32_Addr)&__start_data*/,
|
---|
101 | .p_memsz = (Elf32_Word)&__end_data/* - (Elf32_Addr)&__start_data*/,
|
---|
102 | .p_flags = (Elf32_Word)(PF_W | PF_R),
|
---|
103 | .p_align = (Elf32_Word)8,
|
---|
104 | }
|
---|
105 | },
|
---|
106 | {
|
---|
107 | {
|
---|
108 | .sh_name = (Elf32_Word)1,
|
---|
109 | .sh_type = (Elf32_Word)SHT_PROGBITS,
|
---|
110 | .sh_flags = (Elf32_Word)(SHF_ALLOC | SHF_EXECINSTR),
|
---|
111 | .sh_addr = (Elf32_Addr)&__start_text,
|
---|
112 | .sh_offset = (Elf32_Off)&__start_text/* - (Elf32_Off)&ProgInf*/,
|
---|
113 | .sh_size = (Elf32_Word)&__end_text/* - (Elf32_Off)&__start_text*/,
|
---|
114 | .sh_link = (Elf32_Word)0,
|
---|
115 | .sh_info = (Elf32_Word)0,
|
---|
116 | .sh_addralign = (Elf32_Word)8,
|
---|
117 | .sh_entsize = (Elf32_Word)0,
|
---|
118 | },
|
---|
119 | {
|
---|
120 | .sh_name = (Elf32_Word)7,
|
---|
121 | .sh_type = (Elf32_Word)SHT_PROGBITS,
|
---|
122 | .sh_flags = (Elf32_Word)(SHF_ALLOC),
|
---|
123 | .sh_addr = (Elf32_Addr)&__start_rodata,
|
---|
124 | .sh_offset = (Elf32_Off)&__start_rodata/* - (Elf32_Off)&ProgInf*/,
|
---|
125 | .sh_size = (Elf32_Word)&__end_rodata/* - (Elf32_Off)&__start_rodata*/,
|
---|
126 | .sh_link = (Elf32_Word)0,
|
---|
127 | .sh_info = (Elf32_Word)0,
|
---|
128 | .sh_addralign = (Elf32_Word)8,
|
---|
129 | .sh_entsize = (Elf32_Word)0,
|
---|
130 | },
|
---|
131 | {
|
---|
132 | .sh_name = (Elf32_Word)15,
|
---|
133 | .sh_type = (Elf32_Word)SHT_PROGBITS,
|
---|
134 | .sh_flags = (Elf32_Word)(SHF_ALLOC | SHF_WRITE),
|
---|
135 | .sh_addr = (Elf32_Addr)&__start_data,
|
---|
136 | .sh_offset = (Elf32_Off)&__start_idata/* - (Elf32_Off)&ProgInf*/,
|
---|
137 | .sh_size = (Elf32_Word)&__end_data/* - (Elf32_Off)&__start_data*/,
|
---|
138 | .sh_link = (Elf32_Word)0,
|
---|
139 | .sh_info = (Elf32_Word)0,
|
---|
140 | .sh_addralign = (Elf32_Word)8,
|
---|
141 | .sh_entsize = (Elf32_Word)0,
|
---|
142 | },
|
---|
143 | {
|
---|
144 | .sh_name = (Elf32_Word)21,
|
---|
145 | .sh_type = (Elf32_Word)SHT_NOBITS,
|
---|
146 | .sh_flags = (Elf32_Word)(SHF_ALLOC | SHF_WRITE),
|
---|
147 | .sh_addr = (Elf32_Addr)&__start_bss,
|
---|
148 | .sh_offset = (Elf32_Off)&__start_bss/* - (Elf32_Off)&ProgInf*/,
|
---|
149 | .sh_size = (Elf32_Word)&__end_bss/* - (Elf32_Off)&__start_bss*/,
|
---|
150 | .sh_link = (Elf32_Word)0,
|
---|
151 | .sh_info = (Elf32_Word)0,
|
---|
152 | .sh_addralign = (Elf32_Word)8,
|
---|
153 | .sh_entsize = (Elf32_Word)0,
|
---|
154 | }
|
---|
155 | },
|
---|
156 | {
|
---|
157 | .sh_name = (Elf32_Word)26,
|
---|
158 | .sh_type = (Elf32_Word)SHT_STRTAB,
|
---|
159 | .sh_flags = (Elf32_Word)0,
|
---|
160 | .sh_addr = (Elf32_Addr)0,
|
---|
161 | .sh_offset = (Elf32_Off)&((TProgInf *)0)->shstrtab,
|
---|
162 | .sh_size = (Elf32_Word)sizeof(ProgInf.shstrtab),
|
---|
163 | .sh_link = (Elf32_Word)0,
|
---|
164 | .sh_info = (Elf32_Word)0,
|
---|
165 | .sh_addralign = (Elf32_Word)1,
|
---|
166 | .sh_entsize = (Elf32_Word)0,
|
---|
167 | },
|
---|
168 | "\0.text\0.rodata\0.data\0.bss\0.shstrtab"
|
---|
169 | };
|
---|