xref: /aosp_15_r20/build/soong/rust/config/riscv64_device.go (revision 333d2b3687b3a337dbcca9d65000bca186795e39)
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