Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add clangd wrapper script #17

Open
wants to merge 5 commits into
base: main
Choose a base branch
from

Conversation

septatrix
Copy link
Contributor

@septatrix septatrix commented Nov 18, 2024

It might also make sense to add the following content to suppress warnings which appear because the compile_commands.json is based on GCC and not Clang

# See https://github.com/xuwd1/vscode-kernelmod-guide/blob/master/.clangd
CompileFlags:
  Add: -Wno-unknown-warning-option
  Remove: [--hack*, --ibt,--orc,--retpoline,--rethunk,--sls,--static-call,--uaccess,--link,--module,-mpreferred-stack*,-mindirect-branch*,-fno-allow-store*,-fconserve-stack,-mrecord-mcount,-ftrivial-auto*]

PS: Some way of getting .clang-tidy in there (or simply referring to the default one provided by the kernel) would also be great

Copy link
Contributor Author

@septatrix septatrix left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Apart from two small changes where I had to hardcode something in the mkosi.clangd file this is now the setup I got working this evening. I also opened systemd/mkosi#3206 which I think would allow us to make this a lot cleaner and avoid some of the current problems

mkosi.build.chroot Outdated Show resolved Hide resolved
modules/kernel/mkosi.build.chroot Show resolved Hide resolved
@septatrix septatrix force-pushed the feature/clangd-wrapper branch from 175385f to 09d9965 Compare November 19, 2024 00:01
@septatrix
Copy link
Contributor Author

septatrix commented Nov 19, 2024

PS: Some way of getting .clang-tidy in there (or simply referring to the default one provided by the kernel) would also be great

I now got .clang-tidy working (simply copy the one from the kernel tree to the working directory beforehand) but that moves it to the host and thus always results in a dirty git state... It seems like it should also be possible to pick it up based on the file being edited (clangd/vscode-clangd#367) but I am not sure if path-mappings interfere with that or if simply did not put it in the correct place yet.


PS: Well, no it is no longer working. I am not really sure what I changed - maybe it was some fluke due to leftover files from a previous run

@septatrix septatrix changed the title Add clangd wrapper script WIP: Add clangd wrapper script Nov 19, 2024
@septatrix septatrix marked this pull request as draft November 19, 2024 10:43
@septatrix septatrix changed the title WIP: Add clangd wrapper script Add clangd wrapper script Nov 19, 2024
@septatrix septatrix force-pushed the feature/clangd-wrapper branch 3 times, most recently from ff63747 to 39cc63d Compare November 22, 2024 10:31
@septatrix
Copy link
Contributor Author

Rebased to use systemd/mkosi#3216 which makes this a decent bit cleaner as the other build scripts no longer get in our way

modules/kernel/mkosi.clangd Show resolved Hide resolved
Comment on lines 30 to 32
# This currently puts the clang-format on the host :/
# And also DOES NOT WORK... :|
cp kernel/.clang-format $SRCDIR
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should parse the first argument as the source dir to run clangd in and cd into it before invoking clangd

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

And omit the --compile-commands-dir then such that clangd picks it up from the current dir? I am not sure if that really works as well as we hope it does. It also means that we would need to put the compile DB of the kernel under the kernel sources which makes it impossible to reuse the same kernel source for multiple mkosi-kernel projects.

--compile-commands-dir="$BUILDDIR" \
--path-mappings="\
$BUILD_SOURCE_MAPPINGS,\
$BUILD_DIRECTORY/=$BUILDDIR/,\
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should map to $BUILDDIR/$1 if we pass the source dir to run clangd in as the first argument

Comment on lines +22 to +60
# This neglects build sources which have an absolute path as a target
# but that would make the jq filter more complex
# and can still added later if someone has a need for this.
BUILD_SOURCE_MAPPINGS="$(jq -r '[
.BuildSources[]
| .Source + "/='"$SRCDIR"'/" + .Target
] | join(",")' "$MKOSI_CONFIG")"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should pass this when invoking mkosi with this script as the beginning. You can map the current working directory to /work/src/$1 if the source dir is passed as the first argument

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I see no reason why we should simply map all dirs for which we have information available. Only mapping a single one will also be difficult because we do not know which of the BuildSources it is. And passing it via CLI does not work because we need to also know the path outside the build sandbox, not only inside. For systemd this works because there is only a single build source usually configured and that is generally $PWD on the host

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@septatrix I would make the assumption that $PWD when mkosi.clangd is invoked outside of mkosi is the path outside the sandbox. And the target path inside the sandbox is what's passed in as $1

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But the path inside the sandbox will always be one of BuildSources, same for $PWD - except for dubious cases where one uses mkosi-kernel as a clangd provider for a different source tree which I think we do not need to support.
Unless I am missing something the current jq filter covers a subset of all mappins which make sense by manually passing them - it just does it automatically for you and for all of them

set -eu

if [ -z "${MKOSI_CONFIG-}" ]; then
exec mkosi \
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We shouldn't assume this script is invoked from the mkosi-kernel source directory. So this should use the BASH_SOURCE magic to figure out the directory this script is located in and then pass that to --directory with ../.. to make sure we run mkosi in the right directory

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No we indeed shouldn't and that's also why I resolve the path to the build script below. However, I would assume it's more likely that the user wants mkosi to scan the config from the current dir than from mkosi-kernel (e.g. when including the latter)?

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think that's the more unlikely scenario.

The more likely scenario is that a user has a separate kernel tree open in their editor and wants to run clangd from mkosi-kernel within that editor workspace. And that means $PWD will not be the mkosi-kernel repository and instead we should chdir() to it with --directory

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In that case they can simply create a dummy mkosi.conf with an include statement for mkosi-kernel or prepend env --chdir ... to the invocation of the clangd wrapper script. If we always chdir to the mkosi-kernel directory we would make it completely impossible to use mkosi-kernel with Include= whereas the current state makes that trivial all while your scenario is still quite simple

@septatrix
Copy link
Contributor Author

Regarding .clang-format I seem to have figured out what's going on: The --path-mapping are not applied during lookup of the format config. Thus clangd searches the tree upwards from /home/$USER/.../kernel. The only solution I see so far is putting the .clang-format file at the root - and reporting this upstream

@septatrix
Copy link
Contributor Author

I have now put the compile commands DB under $BUILDDIR which makes it easier to use when multiple projects share the same build source with different localversions but sadly makes the clangd wrapper script a bit more convoluted because we have to determine the $BUILDDIR there now

@septatrix septatrix marked this pull request as ready for review November 29, 2024 14:51
@septatrix
Copy link
Contributor Author

Any preference whether we should run the clangd from the tools tree or the build packages?

@septatrix septatrix force-pushed the feature/clangd-wrapper branch from 8c99796 to 4f270bc Compare January 8, 2025 18:41
@septatrix septatrix force-pushed the feature/clangd-wrapper branch from 4f270bc to 35fc80f Compare January 9, 2025 17:49
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants