blob: b235ae1413d17d3baba31e42535ef0836345e7af [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
Rick Chenf94c44e2017-12-26 13:55:52 +08002#
3# (C) Copyright 2000-2002
4# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5#
6# Copyright (c) 2017 Microsemi Corporation.
7# Padmarao Begari, Microsemi Corporation <padmarao.begari@microsemi.com>
8#
9# Copyright (C) 2017 Andes Technology Corporation
10# Rick Chen, Andes Technology Corporation <rick@andestech.com>
11#
Rick Chenf94c44e2017-12-26 13:55:52 +080012
13ifeq ($(CROSS_COMPILE),)
14CROSS_COMPILE := riscv32-unknown-linux-gnu-
15endif
16
1732bit-emul := elf32lriscv
1864bit-emul := elf64lriscv
19
20ifdef CONFIG_32BIT
Bin Mengce7a8e02018-09-26 06:55:13 -070021PLATFORM_CPPFLAGS += -march=rv32ima -mabi=ilp32
Rick Chenf94c44e2017-12-26 13:55:52 +080022PLATFORM_LDFLAGS += -m $(32bit-emul)
Bin Mengce7a8e02018-09-26 06:55:13 -070023CFLAGS_EFI += -march=rv32ima -mabi=ilp32
Alexander Graf493d1e82018-04-23 07:59:45 +020024EFI_LDS := elf_riscv32_efi.lds
Rick Chenf94c44e2017-12-26 13:55:52 +080025endif
26
27ifdef CONFIG_64BIT
Bin Mengce7a8e02018-09-26 06:55:13 -070028PLATFORM_CPPFLAGS += -march=rv64ima -mabi=lp64
Rick Chenf94c44e2017-12-26 13:55:52 +080029PLATFORM_LDFLAGS += -m $(64bit-emul)
Bin Mengce7a8e02018-09-26 06:55:13 -070030CFLAGS_EFI += -march=rv64ima -mabi=lp64
Alexander Graf493d1e82018-04-23 07:59:45 +020031EFI_LDS := elf_riscv64_efi.lds
Rick Chenf94c44e2017-12-26 13:55:52 +080032endif
33
34CONFIG_STANDALONE_LOAD_ADDR = 0x00000000 \
35 -T $(srctree)/examples/standalone/riscv.lds
36
37PLATFORM_CPPFLAGS += -ffixed-gp -fpic
Bin Mengce7a8e02018-09-26 06:55:13 -070038PLATFORM_RELFLAGS += -fno-common -gdwarf-2 -ffunction-sections
39LDFLAGS_u-boot += --gc-sections -static -pie
Alexander Graf493d1e82018-04-23 07:59:45 +020040
41EFI_CRT0 := crt0_riscv_efi.o
42EFI_RELOC := reloc_riscv_efi.o