1*333d2b36SAndroid Build Coastguard Worker// Copyright 2022 The Android Open Source Project 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 "strings" 19*333d2b36SAndroid Build Coastguard Worker 20*333d2b36SAndroid Build Coastguard Worker "android/soong/android" 21*333d2b36SAndroid Build Coastguard Worker) 22*333d2b36SAndroid Build Coastguard Worker 23*333d2b36SAndroid Build Coastguard Workervar ( 24*333d2b36SAndroid Build Coastguard Worker Riscv64RustFlags = []string{ 25*333d2b36SAndroid Build Coastguard Worker "-C force-frame-pointers=y", 26*333d2b36SAndroid Build Coastguard Worker } 27*333d2b36SAndroid Build Coastguard Worker Riscv64ArchFeatureRustFlags = map[string][]string{ 28*333d2b36SAndroid Build Coastguard Worker "riscv64": { 29*333d2b36SAndroid Build Coastguard Worker "-C target-feature=+V,+Zba,+Zbb,+Zbs", 30*333d2b36SAndroid Build Coastguard Worker }, 31*333d2b36SAndroid Build Coastguard Worker } 32*333d2b36SAndroid Build Coastguard Worker Riscv64LinkFlags = []string{} 33*333d2b36SAndroid Build Coastguard Worker 34*333d2b36SAndroid Build Coastguard Worker Riscv64ArchVariantRustFlags = map[string][]string{"": {}} 35*333d2b36SAndroid Build Coastguard Worker) 36*333d2b36SAndroid Build Coastguard Worker 37*333d2b36SAndroid Build Coastguard Workerfunc init() { 38*333d2b36SAndroid Build Coastguard Worker registerToolchainFactory(android.Android, android.Riscv64, Riscv64ToolchainFactory) 39*333d2b36SAndroid Build Coastguard Worker 40*333d2b36SAndroid Build Coastguard Worker pctx.StaticVariable("Riscv64ToolchainRustFlags", strings.Join(Riscv64RustFlags, " ")) 41*333d2b36SAndroid Build Coastguard Worker pctx.StaticVariable("Riscv64ToolchainLinkFlags", strings.Join(Riscv64LinkFlags, " ")) 42*333d2b36SAndroid Build Coastguard Worker 43*333d2b36SAndroid Build Coastguard Worker for variant, rustFlags := range Riscv64ArchVariantRustFlags { 44*333d2b36SAndroid Build Coastguard Worker pctx.StaticVariable("Riscv64"+variant+"VariantRustFlags", 45*333d2b36SAndroid Build Coastguard Worker strings.Join(rustFlags, " ")) 46*333d2b36SAndroid Build Coastguard Worker } 47*333d2b36SAndroid Build Coastguard Worker 48*333d2b36SAndroid Build Coastguard Worker} 49*333d2b36SAndroid Build Coastguard Worker 50*333d2b36SAndroid Build Coastguard Workertype toolchainRiscv64 struct { 51*333d2b36SAndroid Build Coastguard Worker toolchain64Bit 52*333d2b36SAndroid Build Coastguard Worker toolchainRustFlags string 53*333d2b36SAndroid Build Coastguard Worker} 54*333d2b36SAndroid Build Coastguard Worker 55*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) RustTriple() string { 56*333d2b36SAndroid Build Coastguard Worker return "riscv64-linux-android" 57*333d2b36SAndroid Build Coastguard Worker} 58*333d2b36SAndroid Build Coastguard Worker 59*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) ToolchainLinkFlags() string { 60*333d2b36SAndroid Build Coastguard Worker // Prepend the lld flags from cc_config so we stay in sync with cc 61*333d2b36SAndroid Build Coastguard Worker return "${config.DeviceGlobalLinkFlags} ${cc_config.Riscv64Lldflags} ${config.Riscv64ToolchainLinkFlags}" 62*333d2b36SAndroid Build Coastguard Worker} 63*333d2b36SAndroid Build Coastguard Worker 64*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) ToolchainRustFlags() string { 65*333d2b36SAndroid Build Coastguard Worker return t.toolchainRustFlags 66*333d2b36SAndroid Build Coastguard Worker} 67*333d2b36SAndroid Build Coastguard Worker 68*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) RustFlags() string { 69*333d2b36SAndroid Build Coastguard Worker return "${config.Riscv64ToolchainRustFlags}" 70*333d2b36SAndroid Build Coastguard Worker} 71*333d2b36SAndroid Build Coastguard Worker 72*333d2b36SAndroid Build Coastguard Workerfunc (t *toolchainRiscv64) Supported() bool { 73*333d2b36SAndroid Build Coastguard Worker return true 74*333d2b36SAndroid Build Coastguard Worker} 75*333d2b36SAndroid Build Coastguard Worker 76*333d2b36SAndroid Build Coastguard Workerfunc (toolchainRiscv64) LibclangRuntimeLibraryArch() string { 77*333d2b36SAndroid Build Coastguard Worker return "riscv64" 78*333d2b36SAndroid Build Coastguard Worker} 79*333d2b36SAndroid Build Coastguard Worker 80*333d2b36SAndroid Build Coastguard Workerfunc Riscv64ToolchainFactory(arch android.Arch) Toolchain { 81*333d2b36SAndroid Build Coastguard Worker archVariant := arch.ArchVariant 82*333d2b36SAndroid Build Coastguard Worker 83*333d2b36SAndroid Build Coastguard Worker toolchainRustFlags := []string{ 84*333d2b36SAndroid Build Coastguard Worker "${config.Riscv64ToolchainRustFlags}", 85*333d2b36SAndroid Build Coastguard Worker "${config.Riscv64" + archVariant + "VariantRustFlags}", 86*333d2b36SAndroid Build Coastguard Worker } 87*333d2b36SAndroid Build Coastguard Worker 88*333d2b36SAndroid Build Coastguard Worker toolchainRustFlags = append(toolchainRustFlags, deviceGlobalRustFlags...) 89*333d2b36SAndroid Build Coastguard Worker 90*333d2b36SAndroid Build Coastguard Worker for _, feature := range arch.ArchFeatures { 91*333d2b36SAndroid Build Coastguard Worker toolchainRustFlags = append(toolchainRustFlags, Riscv64ArchFeatureRustFlags[feature]...) 92*333d2b36SAndroid Build Coastguard Worker } 93*333d2b36SAndroid Build Coastguard Worker 94*333d2b36SAndroid Build Coastguard Worker return &toolchainRiscv64{ 95*333d2b36SAndroid Build Coastguard Worker toolchainRustFlags: strings.Join(toolchainRustFlags, " "), 96*333d2b36SAndroid Build Coastguard Worker } 97*333d2b36SAndroid Build Coastguard Worker} 98