Revert "build: Misc manual fixes to prepare for Bazel 9"

This reverts commit fead74625f8e67aaf57564a735a01967771e9238.

Reason for revert: error: unknown warning option '-Wno-volatile' [-Werror,-Wunknown-warning-option] downstream.

Original change's description:
> build: Misc manual fixes to prepare for Bazel 9
>
> - Add a C++ options warning filter to turn off -Wvolatile, as
>   that occurs in Zephyr when built with a C++ compiler.
> - Load py_library from rules_python in the one place that didn't do
>   so, as Bazel 9 stop defining it.
> - Load cc_library from @rules_cc when generating the version library.
>
> Test: cd examples/hello_bazel && ./pw default
> Test: cd examples/nrf52 && ./pw default
> Bug: 491945168
> Change-Id: I1a20fa686e8e45177960137dbe84562cd9afab0b
> Reviewed-on: https://pigweed-review.googlesource.com/c/zephyr/zephyr-bazel/+/386626

TBR=pigweed-scoped@luci-project-accounts.iam.gserviceaccount.com,yichengli@google.com,android-build-ayeaye@system.gserviceaccount.com,lpique@google.com

No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: 491945168
Change-Id: I8aaaf236c94fb1a4d9b03f2e07fce2dce0f4929b
Reviewed-on: https://pigweed-review.googlesource.com/c/zephyr/zephyr-bazel/+/387061
4 files changed
tree: d2c353d546edcb1420880c1e113fd3ba9c6841b4
  1. .vscode/
  2. bazel/
  3. bazel_overlay/
  4. docs/
  5. examples/
  6. modules/
  7. pw_chrono_zephyr/
  8. pw_digital_io_zephyr/
  9. pw_spi_zephyr/
  10. pw_sync_zephyr/
  11. pw_thread_zephyr/
  12. scripts/
  13. third_party/
  14. tools/
  15. .bazelversion
  16. .gitignore
  17. AUTHORS
  18. BUILD.bazel
  19. CONTRIBUTING.md
  20. generate_diff.py
  21. kconfig.bzl
  22. LICENSE
  23. MODULE.bazel
  24. MODULE.bazel.lock
  25. OWNERS
  26. pw
  27. README.md
  28. setup.bzl
  29. WORKSPACE
README.md

Zephyr-Bazel

The way this repository works is by overlaying itself on top of Zephyr. To get started, first make sure you have Bazel‘s skylib version 1.7.1 or greater. If you don’t have it, you can use:

http_archive(
    name = "bazel_skylib",
    sha256 = "bc283cdfcd526a52c3201279cda4bc298652efa898b10b4db0837dc51652756f",
    urls = [
        "https://mirror.bazel.build/github.com/bazelbuild/bazel-skylib/releases/download/1.7.1/bazel-skylib-1.7.1.tar.gz",
        "https://github.com/bazelbuild/bazel-skylib/releases/download/1.7.1/bazel-skylib-1.7.1.tar.gz",
    ],
)

load("@bazel_skylib//:workspace.bzl", "bazel_skylib_workspace")

bazel_skylib_workspace()

Usage in WORKSPACE

To grab the zephyr-bazel repo, use a git_repository rule in your WORKSPACE, such as:

git_repository(
    name = "zephyr-bazel",
    remote = "https://pigweed.googlesource.com/zephyr/zephyr-bazel",
    branch = "main",
)

Once you have @zephyr-bazel, we can load the patch rule to generate the Zephyr diff that will augment Zephyr to include the BUILD.zephyr rules.

load("@zephyr-bazel//:setup.bzl", "create_zephyr_patch_file")

create_zephyr_patch_file(
    name = "zephyr-patch",
    filename = "patch.diff",
    # This is optional, use it to see what's going on under the hood
    debug = True,
)

We now have a diff file at @zephyr-patch//:patch.diff. We're ready to load Zephyr.

git_repository(
    name = "zephyr",
    remote = "https://github.com/zephyrproject-rtos/zephyr.git",
    branch = "main",
    patches = [
        "@zephyr-patch//:patch.diff",
    ],
)

The final step will be to load Zephyr's python dependencies:

load("@rules_python//python:pip.bzl", "pip_parse")

pip_parse(
    name = "py_deps",
    python_interpreter_target = interpreter,
    requirements_lock = "@@zephyr//:scripts/requirements-base.txt",
)

load("@py_deps//:requirements.bzl", zephyr_install_deps = "install_deps")

zephyr_install_deps()

Usage in bzlmod

To use zephyr-bazel in bzlmod, first add it as a dependency in your project's MODULE.bazel:

bazel_dep(name = "zephyr-bazel")
git_override(
    module_name = "zephyr-bazel",
    remote = "https://pigweed.googlesource.com/zephyr/zephyr-bazel",
    branch = "main",
)

Then use the zephyr_patch_file module extension to generate a patch file and a Bazel repo with the patch file applied:

zephyr_patch_file = use_extension("@zephyr-bazel//:setup.bzl", "zephyr_patch_file")
use_repo(zephyr_patch_file, "zephyr")

pip is required by the patched zephyr repo, so your project needs to inject it:

pip = use_extension("@rules_python//python/extensions:pip.bzl", "pip")
# Load the Zephyr pip requirements
pip.parse(
    hub_name = "pip",
    python_version = "3.11",
    requirements_lock = "@zephyr//:scripts/requirements-base.txt",
)
use_repo(pip, "pip")

inject_repo(zephyr_patch_file, "pip")

Application

In your main application, you can now use the Zephyr utilities for building your app.

load("@zephyr//:defs.bzl", "dts_cc_library")

dts_cc_library(
    name = "app_native_sim_dts",
    dts_lib = "@zephyr//boards/native/native_sim:native_sim",
)

cc_binary(
    ...
    deps = [
        ...
        "@zephyr//:zephyr",
    ] + select({
        "@platform//cpu:x86_64": [
            ":app_native_sim_dts",
            "@zephyr//include:posix",
        ],
    }),
    copts = select({
        "@platform//cpu:x86_64": [
            "-DCONFIG_ARCH_POSIX=1",
        ],
    }),
)

Examples

There is currently just 1 example, you can run it via:

$ cd examples/hello_dts
$ bazel run :app

Or, you can run the tests via:

$ cd examples/hello_dts
$ bazel test //...