source: mainline/kernel/meson.build@ dd65f4f7

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since dd65f4f7 was c21d4d6, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 6 years ago

Add copyright headers for new files

Most are a copy of the headers that were present in original Makefiles.

  • Property mode set to 100644
File size: 6.3 KB
Line 
1#
2# Copyright (c) 2005 Martin Decky
3# All rights reserved.
4#
5# Redistribution and use in source and binary forms, with or without
6# modification, are permitted provided that the following conditions
7# are met:
8#
9# - Redistributions of source code must retain the above copyright
10# notice, this list of conditions and the following disclaimer.
11# - Redistributions in binary form must reproduce the above copyright
12# notice, this list of conditions and the following disclaimer in the
13# documentation and/or other materials provided with the distribution.
14# - The name of the author may not be used to endorse or promote products
15# derived from this software without specific prior written permission.
16#
17# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27#
28
29
30arch_src = []
31
32# Fills arch_src.
33subdir('arch' / KARCH)
34
35# Defines genarch_src.
36subdir('genarch')
37
38# Defines generic_src, instrumentable_src.
39subdir('generic')
40
41# Defines test_src
42subdir('test')
43
44## Cross-platform assembly to start a symtab.data section
45#
46symtab_section = '.section symtab.data, "a", ' + atsign + 'progbits;'
47
48kernel_include_dirs = include_directories(
49 'generic/include',
50 'genarch/include',
51 'arch' / KARCH / 'include',
52 '..' / 'abi' / 'arch' / KARCH / 'include',
53 '..' / 'abi' / 'include',
54 'test',
55)
56
57kernel_defs = [
58 '-imacros', meson.build_root() / 'config.h',
59 '-D_HELENOS_SOURCE',
60 '-DKERNEL',
61 '-DHELENOS_RELEASE=' + HELENOS_RELEASE,
62 '-DHELENOS_COPYRIGHT=' + HELENOS_COPYRIGHT,
63 '-DHELENOS_CODENAME=' + HELENOS_CODENAME,
64 '-D__@0@_BITS__'.format(meson.get_cross_property('bits')),
65]
66
67# Preprocess linker script using C preprocessor.
68kernel_ldscript = custom_target('_link.ld',
69 input: 'arch' / KARCH / '_link.ld.in',
70 output: '_link.ld',
71 command: [
72 cc.cmd_array(),
73 arch_kernel_c_args,
74 kernel_defs,
75 '-I' + meson.current_source_dir() / 'arch' / KARCH / 'include',
76 '-D__ASSEMBLER__',
77 '-D__LINKER__',
78 '-E',
79 '-P',
80 '-x', 'c',
81 '@INPUT@',
82 ],
83 capture: true,
84 build_by_default: true,
85)
86
87kernel_link_args = arch_kernel_link_args + [
88 '-Wl,--nmagic',
89 '-T', meson.current_build_dir() / '_link.ld',
90]
91
92if CONFIG_LTO
93 kernel_link_args += [ '-flto' ]
94endif
95
96if CONFIG_STRIP_BINARIES
97 # TODO: do this after disassembling
98 kernel_link_args += [ '-s' ]
99endif
100
101kernel_c_args = arch_kernel_c_args + kernel_defs + [
102 '-ffreestanding',
103 # TODO: remove this flag
104 cc.get_supported_arguments([ '-Wno-cast-function-type' ]),
105]
106
107if CONFIG_LTO
108 kernel_c_args += [ '-flto' ]
109endif
110
111if cc.get_id() == 'clang'
112 kernel_c_args += [
113 '-fno-stack-protector',
114 '-fno-PIC',
115 '-mllvm', '-asm-macro-max-nesting-depth=1000',
116 ]
117endif
118
119instrumentables = static_library('instrumentables', instrumentable_src,
120 include_directories: kernel_include_dirs,
121 implicit_include_directories: false,
122 c_args: kernel_c_args + (CONFIG_TRACE ? [ '-finstrument-functions' ] : []),
123 pic: false,
124)
125
126noninstrumentables = static_library('noninstrumentables', arch_src, genarch_src, generic_src, test_src,
127 include_directories: kernel_include_dirs,
128 implicit_include_directories: false,
129 c_args: kernel_c_args,
130 pic: false,
131)
132
133all_kernel_objects = [ instrumentables, noninstrumentables ]
134
135# We iterate the build several times to get symbol table right.
136# Three times is sufficient to get correct even symbols after symtab.
137
138if CONFIG_SYMTAB
139 # Iterate build three times.
140 iterations = [ 1, 2, 3 ]
141
142 # Generates symbol table information as an object file.
143 genmap = find_program('tools/genmap.py')
144
145 # Symbol table dump needed for genmap.
146 kernel_syms = custom_target('kernel_syms.txt',
147 input: all_kernel_objects,
148 output: 'kernel_syms.txt',
149 command: [ objdump, '-t', '@INPUT@' ],
150 capture: true,
151 )
152else
153 # Build just once.
154 iterations = [ 1 ]
155endif
156
157# Empty symbol map for first iteration.
158kernel_map_S = custom_target('empty_map.S',
159 output: 'empty_map.S',
160 capture: true,
161 command: [ 'echo', kernel_as_prolog + symtab_section ],
162)
163
164foreach iter : iterations
165 is_last = (iter == iterations.length())
166 kernel_name = 'kernel.@0@.elf'.format(iter)
167 kernel_map_name = kernel_name + '.map'
168 kernel_map_path = meson.current_build_dir() / kernel_map_name
169
170 kernel_elf = executable(kernel_name, kernel_map_S,
171 include_directories: kernel_include_dirs,
172 implicit_include_directories: false,
173 c_args: kernel_c_args,
174 link_args: kernel_c_args + kernel_link_args + [
175 '-Wl,-Map,' + kernel_map_path,
176 ],
177 link_depends: kernel_ldscript,
178 link_whole: all_kernel_objects,
179 pie: false,
180 )
181
182 # Generate symbol table if this is not the final iteration.
183 if not is_last
184
185 # TODO: Teach kernel to read its own ELF symbol table and get rid of this nonsense.
186 # Need to first make sure all architectures (even future ones with dumb bootloaders) can use ELF formatted kernel.
187
188 kernel_map_bin = custom_target(kernel_map_name + '.bin',
189 output: kernel_map_name + '.bin',
190 input: [ kernel_elf, kernel_syms ],
191 command: [ genmap, kernel_map_path, '@INPUT1@', '@OUTPUT@' ],
192 )
193
194 kernel_map_S_name = kernel_name + '.map.S'
195
196 kernel_map_S = custom_target(kernel_map_S_name,
197 input: kernel_map_bin,
198 output: kernel_map_S_name,
199 capture: true,
200 command: [ 'echo', kernel_as_prolog + symtab_section + ' .incbin "@INPUT@"' ],
201 )
202 endif
203endforeach
204
205rd_init_binaries += [[ kernel_elf, 'boot/kernel.elf' ]]
206
207install_files += [[ 'boot', kernel_elf.full_path(), 'kernel.elf' ]]
208install_deps += [ kernel_elf ]
209
210kernel_disasm = custom_target('kernel.elf.disasm',
211 command: [ objdump, '-S', '@INPUT@' ],
212 input: kernel_elf,
213 output: 'kernel.elf.disasm',
214 capture: true,
215 build_by_default: true,
216)
217
218# TODO: Add configuration option for installing debug files
219if false
220 install_files += [[ 'boot', kernel_disasm.full_path(), 'kernel.elf.disasm' ]]
221 install_deps += [ kernel_disasm ]
222endif
Note: See TracBrowser for help on using the repository browser.