Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hexdae/toolchains_riscv_gnu
RISC-V bazel toolchains for GCC compilation
https://github.com/hexdae/toolchains_riscv_gnu
bare-metal bazel gcc riscv toolchain
Last synced: about 2 months ago
JSON representation
RISC-V bazel toolchains for GCC compilation
- Host: GitHub
- URL: https://github.com/hexdae/toolchains_riscv_gnu
- Owner: hexdae
- License: mit
- Created: 2023-01-29T05:35:59.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-04-05T21:48:19.000Z (9 months ago)
- Last Synced: 2024-08-06T10:17:20.923Z (5 months ago)
- Topics: bare-metal, bazel, gcc, riscv, toolchain
- Language: Starlark
- Homepage:
- Size: 148 KB
- Stars: 9
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-bazel - hexdae/toolchains_riscv_gnu - RISC-V toolchain (Tooling / Toolchains)
README
The goal of the project is to make cross compilation toolchains readily
available (and customizable) for bazel developers.If this project was useful to you, give it a ⭐️ and I'll keep improving it!
## Features
- [MODULE and WORKSPACE support](https://github.com/hexdae/toolchains_riscv_gnu/releases)
- [Direct access to gcc tools](#direct-access-to-gcc-tools)
- [Custom toolchain support](./examples/toolchain)
- [Select GCC version](#module)
- [Examples](./examples)
- Remote execution support
- Linux, MacOS, Windows## Use the toolchain from this repo
## .bazelrc
And this to your `.bazelrc`
```bash
# .bazelrc# Build using platforms by default
build --incompatible_enable_cc_toolchain_resolution
```## MODULE
```python
bazel_dep(name = "toolchains_riscv_gnu", version = "")riscv_toolchain = use_extension("@toolchains_riscv_gnu//:extensions.bzl", "riscv_toolchain")
riscv_toolchain.riscv_none_elf()
use_repo(riscv_toolchain, "riscv_none_elf")register_toolchains("@riscv_none_elf//toolchain:all")
```## WORKSPACE
Add this git repository to your WORKSPACE to use the compiler
```python
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
name = "rules_cc",
sha256 = "2037875b9a4456dce4a79d112a8ae885bbc4aad968e6587dca6e64f3a0900cdf",
strip_prefix = "rules_cc-0.0.9",
urls = ["https://github.com/bazelbuild/rules_cc/releases/download/0.0.9/rules_cc-0.0.9.tar.gz"],
)load("@bazel_tools//tools/build_defs/repo:git.bzl", "git_repository")
git_repository(
name = "toolchains_riscv_gnu",
remote = "https://github.com/hexdae/toolchains_riscv_gnu",
branch = "main",
)load("@toolchains_riscv_gnu//:deps.bzl", "riscv_none_elf_deps")
riscv_none_elf_deps()
register_toolchains("@riscv_none_elf//toolchain:all")
```Now Bazel will automatically use `riscv-none-elf-gcc` as a compiler.
## Custom toolchain
If you want to bake certain compiler flags in to your toolchain, you can define
a custom toolchain in your repo.In a BUILD file:
```python
# path/to/toolchains/BUILDload("@riscv_none_elf//toolchain:toolchain.bzl", "riscv_none_elf_toolchain")
riscv_none_elf_toolchain(
name = "custom_toolchain",
target_compatible_with = [
"",
],
copts = [
"",
],
linkopts = [
"",
],
)
```And in your WORKSPACE / MODULE file:
```python
register_toolchains("//path/to/toolchains:all")
```Be careful about registering the default toolchains when using a custom one
## Direct access to gcc tools
If you need direct access to `gcc` tools, they are available as `@riscv_none_elf//:`. For example, the following `genrules` could be used to produce `.bin` and `.hex` artifacts from a generic `.out` target.
```python
cc_binary(
name = "target.out"
srcs = [...],
deps = [...],
copts = [...],
...
)genrule(
name = "bin",
srcs = [":target.out"],
outs = ["target.bin"],
cmd = "$(execpath @riscv_none_elf//:objcopy) -O binary $< $@",
tools = ["@riscv_none_elf//:objcopy"],
)genrule(
name = "hex",
srcs = [":target.out"],
outs = ["target.hex"],
cmd = "$(execpath @riscv_none_elf//:objcopy) -O ihex $< $@",
tools = ["@riscv_none_elf//:objcopy"],
)
```## Remote execution
This toolchain is compatible with remote execution, see [`remote.yml`](.github/workflows/remote.yml)