1*333d2b36SAndroid Build Coastguard Worker// Copyright 2022 Google Inc. All rights reserved. 2*333d2b36SAndroid Build Coastguard Worker// 3*333d2b36SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License"); 4*333d2b36SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License. 5*333d2b36SAndroid Build Coastguard Worker// You may obtain a copy of the License at 6*333d2b36SAndroid Build Coastguard Worker// 7*333d2b36SAndroid Build Coastguard Worker// http://www.apache.org/licenses/LICENSE-2.0 8*333d2b36SAndroid Build Coastguard Worker// 9*333d2b36SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software 10*333d2b36SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS, 11*333d2b36SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*333d2b36SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and 13*333d2b36SAndroid Build Coastguard Worker// limitations under the License. 14*333d2b36SAndroid Build Coastguard Worker 15*333d2b36SAndroid Build Coastguard Workerpackage config 16*333d2b36SAndroid Build Coastguard Worker 17*333d2b36SAndroid Build Coastguard Workerimport ( 18*333d2b36SAndroid Build Coastguard Worker "fmt" 19*333d2b36SAndroid Build Coastguard Worker "strings" 20*333d2b36SAndroid Build Coastguard Worker 21*333d2b36SAndroid Build Coastguard Worker "android/soong/android" 22*333d2b36SAndroid Build Coastguard Worker) 23*333d2b36SAndroid Build Coastguard Worker 24*333d2b36SAndroid Build Coastguard Workervar ( 25*333d2b36SAndroid Build Coastguard Worker riscv64Cflags = []string{ 26*333d2b36SAndroid Build Coastguard Worker // Help catch common 32/64-bit errors. (This is duplicated in all 64-bit 27*333d2b36SAndroid Build Coastguard Worker // architectures' cflags.) 28*333d2b36SAndroid Build Coastguard Worker "-Werror=implicit-function-declaration", 29*333d2b36SAndroid Build Coastguard Worker // This is already the driver's Android default, but duplicated here (and 30*333d2b36SAndroid Build Coastguard Worker // below) for ease of experimentation with additional extensions. 31*333d2b36SAndroid Build Coastguard Worker "-march=rv64gcv_zba_zbb_zbs", 32*333d2b36SAndroid Build Coastguard Worker // TODO: remove when qemu V works (https://gitlab.com/qemu-project/qemu/-/issues/1976) 33*333d2b36SAndroid Build Coastguard Worker // (Note that we'll probably want to wait for berberis to be good enough 34*333d2b36SAndroid Build Coastguard Worker // that most people don't care about qemu's V performance either!) 35*333d2b36SAndroid Build Coastguard Worker "-mno-implicit-float", 36*333d2b36SAndroid Build Coastguard Worker } 37*333d2b36SAndroid Build Coastguard Worker 38*333d2b36SAndroid Build Coastguard Worker riscv64ArchVariantCflags = map[string][]string{} 39*333d2b36SAndroid Build Coastguard Worker 40*333d2b36SAndroid Build Coastguard Worker riscv64Ldflags = []string{ 41*333d2b36SAndroid Build Coastguard Worker // This is already the driver's Android default, but duplicated here (and 42*333d2b36SAndroid Build Coastguard Worker // above) for ease of experimentation with additional extensions. 43*333d2b36SAndroid Build Coastguard Worker "-march=rv64gcv_zba_zbb_zbs", 44*333d2b36SAndroid Build Coastguard Worker // TODO: remove when clang default changed (https://github.com/google/android-riscv64/issues/124) 45*333d2b36SAndroid Build Coastguard Worker "-Wl,-mllvm -Wl,-jump-is-expensive=false", 46*333d2b36SAndroid Build Coastguard Worker } 47*333d2b36SAndroid Build Coastguard Worker 48*333d2b36SAndroid Build Coastguard Worker riscv64Lldflags = append(riscv64Ldflags, 49*333d2b36SAndroid Build Coastguard Worker "-Wl,-z,max-page-size=4096", 50*333d2b36SAndroid Build Coastguard Worker ) 51*333d2b36SAndroid Build Coastguard Worker 52*333d2b36SAndroid Build Coastguard Worker riscv64Cppflags = []string{} 53*333d2b36SAndroid Build Coastguard Worker 54*333d2b36SAndroid Build Coastguard Worker riscv64CpuVariantCflags = map[string][]string{} 55*333d2b36SAndroid Build Coastguard Worker) 56*333d2b36SAndroid Build Coastguard Worker 57*333d2b36SAndroid Build Coastguard Workerconst () 58*333d2b36SAndroid Build Coastguard Worker 59*333d2b36SAndroid Build Coastguard Workerfunc init() { 60*333d2b36SAndroid Build Coastguard Worker 61*333d2b36SAndroid Build Coastguard Worker pctx.StaticVariable("Riscv64Ldflags", strings.Join(riscv64Ldflags, " ")) 62*333d2b36SAndroid Build Coastguard Worker pctx.StaticVariable("Riscv64Lldflags", strings.Join(riscv64Lldflags, " ")) 63*333d2b36SAndroid Build Coastguard Worker 64*333d2b36SAndroid Build Coastguard Worker pctx.StaticVariable("Riscv64Cflags", strings.Join(riscv64Cflags, " ")) 65*333d2b36SAndroid Build Coastguard Worker pctx.StaticVariable("Riscv64Cppflags", strings.Join(riscv64Cppflags, " ")) 66*333d2b36SAndroid Build Coastguard Worker} 67*333d2b36SAndroid Build Coastguard Worker 68*333d2b36SAndroid Build Coastguard Workervar ( 69*333d2b36SAndroid Build Coastguard Worker riscv64ArchVariantCflagsVar = map[string]string{} 70*333d2b36SAndroid Build Coastguard Worker 71*333d2b36SAndroid Build Coastguard Worker riscv64CpuVariantCflagsVar = map[string]string{} 72*333d2b36SAndroid Build Coastguard Worker 73*333d2b36SAndroid Build Coastguard Worker riscv64CpuVariantLdflags = map[string]string{} 74*333d2b36SAndroid Build Coastguard Worker) 75*333d2b36SAndroid Build Coastguard Worker 76*333d2b36SAndroid Build Coastguard Workertype toolchainRiscv64 struct { 77*333d2b36SAndroid Build Coastguard Worker toolchainBionic 78*333d2b36SAndroid Build Coastguard Worker toolchain64Bit 79*333d2b36SAndroid Build Coastguard Worker 80*333d2b36SAndroid Build Coastguard Worker ldflags string 81*333d2b36SAndroid Build Coastguard Worker lldflags string 82*333d2b36SAndroid Build Coastguard Worker toolchainCflags string 83*333d2b36SAndroid Build Coastguard Worker} 84*333d2b36SAndroid Build Coastguard Worker 85*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) Name() string { 86*333d2b36SAndroid Build Coastguard Worker return "riscv64" 87*333d2b36SAndroid Build Coastguard Worker} 88*333d2b36SAndroid Build Coastguard Worker 89*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) IncludeFlags() string { 90*333d2b36SAndroid Build Coastguard Worker return "" 91*333d2b36SAndroid Build Coastguard Worker} 92*333d2b36SAndroid Build Coastguard Worker 93*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) ClangTriple() string { 94*333d2b36SAndroid Build Coastguard Worker return "riscv64-linux-android" 95*333d2b36SAndroid Build Coastguard Worker} 96*333d2b36SAndroid Build Coastguard Worker 97*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) Cflags() string { 98*333d2b36SAndroid Build Coastguard Worker return "${config.Riscv64Cflags}" 99*333d2b36SAndroid Build Coastguard Worker} 100*333d2b36SAndroid Build Coastguard Worker 101*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) Cppflags() string { 102*333d2b36SAndroid Build Coastguard Worker return "${config.Riscv64Cppflags}" 103*333d2b36SAndroid Build Coastguard Worker} 104*333d2b36SAndroid Build Coastguard Worker 105*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) Ldflags() string { 106*333d2b36SAndroid Build Coastguard Worker return t.ldflags 107*333d2b36SAndroid Build Coastguard Worker} 108*333d2b36SAndroid Build Coastguard Worker 109*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) Lldflags() string { 110*333d2b36SAndroid Build Coastguard Worker return t.lldflags 111*333d2b36SAndroid Build Coastguard Worker} 112*333d2b36SAndroid Build Coastguard Worker 113*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) ToolchainCflags() string { 114*333d2b36SAndroid Build Coastguard Worker return t.toolchainCflags 115*333d2b36SAndroid Build Coastguard Worker} 116*333d2b36SAndroid Build Coastguard Worker 117*333d2b36SAndroid Build Coastguard Workerfunc (toolchainRiscv64) LibclangRuntimeLibraryArch() string { 118*333d2b36SAndroid Build Coastguard Worker return "riscv64" 119*333d2b36SAndroid Build Coastguard Worker} 120*333d2b36SAndroid Build Coastguard Worker 121*333d2b36SAndroid Build Coastguard Workerfunc riscv64ToolchainFactory(arch android.Arch) Toolchain { 122*333d2b36SAndroid Build Coastguard Worker switch arch.ArchVariant { 123*333d2b36SAndroid Build Coastguard Worker case "": 124*333d2b36SAndroid Build Coastguard Worker default: 125*333d2b36SAndroid Build Coastguard Worker panic(fmt.Sprintf("Unknown Riscv64 architecture version: %q", arch.ArchVariant)) 126*333d2b36SAndroid Build Coastguard Worker } 127*333d2b36SAndroid Build Coastguard Worker 128*333d2b36SAndroid Build Coastguard Worker toolchainCflags := []string{riscv64ArchVariantCflagsVar[arch.ArchVariant]} 129*333d2b36SAndroid Build Coastguard Worker toolchainCflags = append(toolchainCflags, 130*333d2b36SAndroid Build Coastguard Worker variantOrDefault(riscv64CpuVariantCflagsVar, arch.CpuVariant)) 131*333d2b36SAndroid Build Coastguard Worker 132*333d2b36SAndroid Build Coastguard Worker extraLdflags := variantOrDefault(riscv64CpuVariantLdflags, arch.CpuVariant) 133*333d2b36SAndroid Build Coastguard Worker return &toolchainRiscv64{ 134*333d2b36SAndroid Build Coastguard Worker ldflags: strings.Join([]string{ 135*333d2b36SAndroid Build Coastguard Worker "${config.Riscv64Ldflags}", 136*333d2b36SAndroid Build Coastguard Worker extraLdflags, 137*333d2b36SAndroid Build Coastguard Worker }, " "), 138*333d2b36SAndroid Build Coastguard Worker lldflags: strings.Join([]string{ 139*333d2b36SAndroid Build Coastguard Worker "${config.Riscv64Lldflags}", 140*333d2b36SAndroid Build Coastguard Worker extraLdflags, 141*333d2b36SAndroid Build Coastguard Worker }, " "), 142*333d2b36SAndroid Build Coastguard Worker toolchainCflags: strings.Join(toolchainCflags, " "), 143*333d2b36SAndroid Build Coastguard Worker } 144*333d2b36SAndroid Build Coastguard Worker} 145*333d2b36SAndroid Build Coastguard Worker 146*333d2b36SAndroid Build Coastguard Workerfunc init() { 147*333d2b36SAndroid Build Coastguard Worker registerToolchainFactory(android.Android, android.Riscv64, riscv64ToolchainFactory) 148*333d2b36SAndroid Build Coastguard Worker} 149