diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2025-03-15 15:40:42 -1000 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2025-03-15 15:40:42 -1000 | 
| commit | cd3a56ac2d132beea747f7b41cc085c82fe2eac0 (patch) | |
| tree | a86cb89a89d32a6f8d38308e405ff8f2a0685dd0 /scripts/generate_rust_analyzer.py | |
| parent | eb88e6bfbc0a975e08a18c39d1138d3e6cdc00a5 (diff) | |
| parent | a1eb95d6b5f4cf5cc7b081e85e374d1dd98a213b (diff) | |
Merge tag 'rust-fixes-6.14-3' of git://git.kernel.org/pub/scm/linux/kernel/git/ojeda/linux
Pull rust fixes from Miguel Ojeda:
 "Toolchain and infrastructure:
   - Disallow BTF generation with Rust + LTO
   - Improve rust-analyzer support
  'kernel' crate:
   - 'init' module: remove 'Zeroable' implementation for a couple types
     that should not have it
   - 'alloc' module: fix macOS failure in host test by satisfying POSIX
     alignment requirement
   - Add missing '\n's to 'pr_*!()' calls
  And a couple other minor cleanups"
* tag 'rust-fixes-6.14-3' of git://git.kernel.org/pub/scm/linux/kernel/git/ojeda/linux:
  scripts: generate_rust_analyzer: add uapi crate
  scripts: generate_rust_analyzer: add missing include_dirs
  scripts: generate_rust_analyzer: add missing macros deps
  rust: Disallow BTF generation with Rust + LTO
  rust: task: fix `SAFETY` comment in `Task::wake_up`
  rust: workqueue: add missing newline to pr_info! examples
  rust: sync: add missing newline in locked_by log example
  rust: init: add missing newline to pr_info! calls
  rust: error: add missing newline to pr_warn! calls
  rust: docs: add missing newline to printing macro examples
  rust: alloc: satisfy POSIX alignment requirement
  rust: init: fix `Zeroable` implementation for `Option<NonNull<T>>` and `Option<KBox<T>>`
  rust: remove leftover mentions of the `alloc` crate
Diffstat (limited to 'scripts/generate_rust_analyzer.py')
| -rwxr-xr-x | scripts/generate_rust_analyzer.py | 71 | 
1 files changed, 42 insertions, 29 deletions
| diff --git a/scripts/generate_rust_analyzer.py b/scripts/generate_rust_analyzer.py index aa8ea1a4dbe5..adae71544cbd 100755 --- a/scripts/generate_rust_analyzer.py +++ b/scripts/generate_rust_analyzer.py @@ -57,14 +57,26 @@ def generate_crates(srctree, objtree, sysroot_src, external_src, cfgs):          crates_indexes[display_name] = len(crates)          crates.append(crate) -    # First, the ones in `rust/` since they are a bit special. -    append_crate( -        "core", -        sysroot_src / "core" / "src" / "lib.rs", -        [], -        cfg=crates_cfgs.get("core", []), -        is_workspace_member=False, -    ) +    def append_sysroot_crate( +        display_name, +        deps, +        cfg=[], +    ): +        append_crate( +            display_name, +            sysroot_src / display_name / "src" / "lib.rs", +            deps, +            cfg, +            is_workspace_member=False, +        ) + +    # NB: sysroot crates reexport items from one another so setting up our transitive dependencies +    # here is important for ensuring that rust-analyzer can resolve symbols. The sources of truth +    # for this dependency graph are `(sysroot_src / crate / "Cargo.toml" for crate in crates)`. +    append_sysroot_crate("core", [], cfg=crates_cfgs.get("core", [])) +    append_sysroot_crate("alloc", ["core"]) +    append_sysroot_crate("std", ["alloc", "core"]) +    append_sysroot_crate("proc_macro", ["core", "std"])      append_crate(          "compiler_builtins", @@ -75,7 +87,7 @@ def generate_crates(srctree, objtree, sysroot_src, external_src, cfgs):      append_crate(          "macros",          srctree / "rust" / "macros" / "lib.rs", -        [], +        ["std", "proc_macro"],          is_proc_macro=True,      ) @@ -85,27 +97,28 @@ def generate_crates(srctree, objtree, sysroot_src, external_src, cfgs):          ["core", "compiler_builtins"],      ) -    append_crate( -        "bindings", -        srctree / "rust"/ "bindings" / "lib.rs", -        ["core"], -        cfg=cfg, -    ) -    crates[-1]["env"]["OBJTREE"] = str(objtree.resolve(True)) +    def append_crate_with_generated( +        display_name, +        deps, +    ): +        append_crate( +            display_name, +            srctree / "rust"/ display_name / "lib.rs", +            deps, +            cfg=cfg, +        ) +        crates[-1]["env"]["OBJTREE"] = str(objtree.resolve(True)) +        crates[-1]["source"] = { +            "include_dirs": [ +                str(srctree / "rust" / display_name), +                str(objtree / "rust") +            ], +            "exclude_dirs": [], +        } -    append_crate( -        "kernel", -        srctree / "rust" / "kernel" / "lib.rs", -        ["core", "macros", "build_error", "bindings"], -        cfg=cfg, -    ) -    crates[-1]["source"] = { -        "include_dirs": [ -            str(srctree / "rust" / "kernel"), -            str(objtree / "rust") -        ], -        "exclude_dirs": [], -    } +    append_crate_with_generated("bindings", ["core"]) +    append_crate_with_generated("uapi", ["core"]) +    append_crate_with_generated("kernel", ["core", "macros", "build_error", "bindings", "uapi"])      def is_root_crate(build_file, target):          try: | 
