source: mainline/meson/arch/arm64/meson.build@ 06f10ac

serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 06f10ac was 06f10ac, checked in by Martin Decky <martin@…>, 4 years ago

Implement support for HiKey 960

Initial support for the 96Boards HiKey 960 board.

  • The kernel identity mapping has been extended to 4 GiB. The initial bootstrap mapping maps 3 GiB as nornal memory and the next 1 GiB as device memory to support early UART debugging output.
  • The istate_t has been padded in order to preserve the stack pointer alignment invariant.

The current implementation is limited to UP and UART input/output.

  • Property mode set to 100644
File size: 2.6 KB
Line 
1#
2# Copyright (c) 2015 Petr Pavlu
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
29arch_uspace_c_args = [ '-D__LE__', '-fno-omit-frame-pointer' ]
30arch_kernel_c_args = arch_uspace_c_args + [ '-march=armv8-a+nofp+nosimd', '-mgeneral-regs-only' ]
31arch_kernel_link_args = [ '-nostdlib' ]
32arch_uspace_link_args = [ '-nostdlib', '-lgcc' ]
33
34# UEFI binaries should be relocatable, the EFI boot service LoadImage() will
35# rebase the boot file using the .reloc information in the image if it cannot
36# load the binary at its preferred address. The ARM64 port does not provide this
37# information in its PE file (that would require manually creating it) but
38# instead the boot code is compiled with the -fpic option and the bootloader
39# relocates itself at runtime.
40#
41# N.B. The UEFI guarantees for AArch64 that during boot time the primary
42# processor is in the execution mode that has unaligned access enabled. The
43# -mstrict-align option is therefore not needed.
44arch_boot_c_args = arch_uspace_c_args + [ '-fpic', '-fvisibility=hidden', '-fno-function-sections' ]
45arch_boot_link_args = [ '-Wl,-shared', '-Wl,--no-gc-sections' ]
46
47if MACHINE == 'virt'
48 rd_essential += [
49 'drv/char/pl011',
50 'drv/intctl/gicv2',
51 'drv/platform/arm64virt',
52 ]
53endif
54
55if MACHINE == 'hikey960'
56 rd_essential += [
57 'drv/char/pl011',
58 'drv/intctl/gicv2',
59 'drv/platform/hikey960',
60 ]
61endif
Note: See TracBrowser for help on using the repository browser.