Commit Graph

2000 Commits (77b1c6194c8f9bb69ffc6a60c3b8189b73e00e8f)
 

Author SHA1 Message Date
Tamir Duberstein 77b1c6194c Add support for Flow Dissector programs
Closes #216.

Co-authored-by: Zenna Allwein <zrallwein@gmail.com>
Signed-off-by: Tamir Duberstein <tamird@gmail.com>
2 weeks ago
x0rw 34a3d6c27b Update README.md
CgroupSkb::attach() requires three parameters
3 weeks ago
Dave Tucker 29f4f2b780
Merge pull request #1160 from dave-tucker/modprobe 3 weeks ago
Dave Tucker abe5f743a3 feat: Refactor init into test-distro
The init module contains a small init system for running our integration
tests against a kernel. While we don't need a full-blown linux distro,
we do need some utilities.

Once such utility is `modprobe` which allows us to load kernel modules.
Rather than create a new module for this utility, I've instead
refactored `init` into `test-distro` which is a module that contains
multiple binaries.

The xtask code has been adjusted to ensure these binaries are inserted
into the correct places in our cpio archive, as well as bringing in the
kernel modules.

Signed-off-by: Dave Tucker <dave@dtucker.co.uk>
3 weeks ago
Tamir Duberstein 3edc36af9d aya: remove unhelpful comment 3 weeks ago
Tamir Duberstein f890bb3dce integration-test: kernel_assert anti-condition
Rather than emitting a warning, assert the inverse of the condition when
the current kernel version is lower than required. This strengthens the
assertions made by our tests (provided we run them over kernel versions
before and after the listed version, which is not yet the case).
3 weeks ago
Tamir Duberstein 509032f195 integration-test: use scopeguard over panic hook 3 weeks ago
Tamir Duberstein b8f0c56d15 integration-test: avoid Option::is_some_and
These are just pointless.
3 weeks ago
Tamir Duberstein 1320aa1a28 integration-test: fix typo 3 weeks ago
Tamir Duberstein 49a828ec56 taplo: reorder-keys
Group non-workspace keys before workspace ones for readability.
3 weeks ago
Tamir Duberstein 1ff2c0a2d2 Cargo.toml: sort dependencies 3 weeks ago
Tamir Duberstein 0153bdd950 github: update dependabot docs link 3 weeks ago
tamird 75aac18f8a public-api: regenerate 3 weeks ago
WANG Rui e3aa47f0db Update octorust to 0.10 3 weeks ago
Michal Rostecki f48b5a4a84 aya: Ensure that truncated map names are NULL terminated
Limit of map names in eBPF is 16 bytes and they have to be NULL
terminated.

Before this change, long names were truncated to 16 bytes.
`MAP_WITH_LOOOONG_NAAAAAAAAME` would become `MAP_WITH_LOOOONG`, which
doesn't contain the NULL byte.

This change fixes that by truncating the name to 15 bytes, ensuring
that the 16th byte is NULL. `MAP_WITH_LOOOONG_NAAAAAAAAME` is truncated
to `MAP_WITH_LOOOON\0`.
4 weeks ago
tamird dcf66db845 public-api: regenerate 4 weeks ago
Tamir Duberstein a43e40ae1d introduce workspace lints, warn on unused crates
In practice this will forbid unused dependencies because we run clippy
with `--deny warnings`.

Workspace lints is a nice place to ratchet up lints through the codebase
all at once and consistently.
1 month ago
Dave Tucker 65489e1d4c
Merge pull request #1210 from dave-tucker/no-mergify-dependabot
chore: Disable mergify on dependabot PRs
1 month ago
Tamir Duberstein 22c8f783e7 programs: allow program names to be static strings 1 month ago
Dave Tucker 00b5cc5aaf chore: Disable mergify on dependabot PRs
Merging via comment isn't possible. We could merge this automatically on
green, however we'd prefer to use @dependabot merge or merge manually.

Signed-off-by: Dave Tucker <dave@dtucker.co.uk>
1 month ago
arctic-alpaca 73a34e1571 aya: Add `XskMap::unset` 1 month ago
Dave Tucker ea76e0f62d aya: parse complete entries from /proc/$pid/maps
Signed-off-by: Dave Tucker <dave@dtucker.co.uk>
Signed-off-by: Tamir Duberstein <tamird@gmail.com>
1 month ago
Tamir Duberstein de0b7cee8d Destructure 1 month ago
Tamir Duberstein 7084df68aa Add punctuation 1 month ago
Tamir Duberstein 50ae0ee099 Avoid allocations when parsing /proc/{pid}/maps 1 month ago
Tamir Duberstein 6252b4c972 aya-obj,aya-ebpf-*: hook up loongarch64
This causes rustfmt to format those files.

Squish some other conditional compilation to get rustfmt sorting.
1 month ago
Tamir Duberstein 9916092f5c codegen: tidy up
- Document the need for external rustfmt invocation.
- Remove reexports.
- Remove `write_to_file`.
- Avoid allocating strings when using bindgen to write bindings.
1 month ago
Tamir Duberstein e16f0482f8 Revert "ci: remove cross toolchain"
Turns out this was actually being used through magic.

Remove mips since it is a tier 3 target that is only supported on
nightly and dtolnay/rust-toolchain doesn't seem to handle installing
targets without std.

Exclude xtask since it depends on `ring` which doesn't build on all
targets.

Fix compilation on armv7 which had rotted.

This reverts commit d92fc95c39.
1 month ago
Tamir Duberstein 34319cba12 ci,xtask: sort architectures 1 month ago
Tamir Duberstein b18b4f7369 ci: use output rather than env
This appeases my IDE and removes annoying yellow squiggles.
1 month ago
Tamir Duberstein 56ebe1406e aya-tool: do not attempt to run rustfmt
This can be done externally. Do so in CI.

This is an attempt to resolve the inconsistency between CI and local
rustfmt in the generated bindings.

Restore running CI on generated branches; the presence of a PR is
apparently not enough.
1 month ago
tamird 2bb2302d1d aya-obj, aya-ebpf-bindings: regenerate
libbpf commit: 20ea95b4505c477af3b6ff6ce9d19cee868ddc5d
1 month ago
Tamir Duberstein f0a9f19ddc Bump edition to 2024
Change FromRawTracepointArgs::arg to return T rather than *const T which
seems to have been returning a dangling pointer.

Arguably this is not strictly necessary; edition 2024 seems to be
focused on increased strictness around unsafe code which doesn't unlock
new functionality for our users. That said, this work revealed an
apparent bug (see above) that we wouldn't otherwise catch due to
allow-by-default lints.
1 month ago
Tamir Duberstein ea5f7e3015 Reduce the scope of expected warnings
This fixes a few safety comments to avoid the warnings.
1 month ago
Tamir Duberstein 4101a5a55d Use #[expect(...)] rather than #[allow(...)]
This is stricter, and revealed a few unused allowances.
1 month ago
arctic-alpaca 015443776c replace hard-coded queue ID with queried queue ID 1 month ago
arctic-alpaca e1cb4237bd tests: add queue ID matching to AF_XDP test 1 month ago
arctic-alpaca 4d2a56ed46 tests: avoid UB in AF_XDP test
Avoid calling `MaybeUninit::uninit().assume_init_mut()` by just
initializing the memory.
1 month ago
dave-tucker ce0e93c75d aya-obj, aya-ebpf-bindings: regenerate
libbpf commit: 20ea95b4505c477af3b6ff6ce9d19cee868ddc5d
1 month ago
Dave Tucker 85c0139428
Merge pull request #1197 from heiher/xtask-loong64
chore(xtask): Add loongarch64 to codegen
1 month ago
Tamir Duberstein 27d69c35f0 aya: remove panics on indeterminate kernel version
Cache the current kernel version in a thread-local while I'm here.

Closes https://github.com/aya-rs/aya/issues/1024.
Closes https://github.com/aya-rs/aya/pull/1042.
1 month ago
Tamir Duberstein 9eefb48a0a aya: remove some copies
Replace truncation with proper NULL termination at the site of use.
1 month ago
Tamir Duberstein 7525532204 ci: remove superfluous name
It's implied from the git URL.
1 month ago
Dave Tucker 0fa300f696
Merge pull request #1141 from gth828r/1140.xdp-context-if-index-support
aya-ebpf: add ifindex support to XdpContext
1 month ago
jinlong 2fb19f3ee2 feat: Add `set` for `Array<T>`
Signed-off-by: jinlong <jinlong@tencent.com>
1 month ago
Tamir Duberstein 601c89dd23 aya-ebpf: extract insert,remove,lookup
These functions (and more) are duplicated all over the place.
1 month ago
Tim Upthegrove dc543ae44a aya-ebpf: add ifindex support to XdpContext
This change exposes the ifindex field from the underlying xdp_md
data structure to the XdpContext in Aya. The ifindex represents the
unique OS-provided index for a network interface.

Fixes #1140
1 month ago
WANG Rui 9d0bdb56e6 chore(xtask): Add loongarch64 to codegen
Signed-off-by: WANG Rui <wangrui@loongson.cn>
1 month ago
Ignacy 3edac6153e integration-test: allow llvm-objcopy env override
Allows integration tests to run where llvm-objcopy is versioned.

Closes: https://github.com/aya-rs/aya/issues/1142
1 month ago
Tamir Duberstein 89aa638e05 aya: add TODO to remove once_cell 1 month ago