Tamir Duberstein
572d047e37
test: avoid lossy string conversions
...
We can be strict in tests.
1 year ago
Tamir Duberstein
ff8c124770
Merge pull request #763 from aya-rs/lints
...
aya: deny various allow-by-default lints
1 year ago
Tamir Duberstein
fb00fa13f3
Merge pull request #762 from aya-rs/remove-workaround
...
integration-test: Remove cargo symlink workaround
1 year ago
Tamir Duberstein
ca2e43d318
integration-test: Remove cargo symlink workaround
...
https://github.com/rust-lang/cargo/pull/12369 fixed this bug and was
picked up in https://github.com/rust-lang/rust/pull/114027 .
1 year ago
Tamir Duberstein
abda239d63
aya: deny various allow-by-default lints
...
Notably:
- clippy::use_self: replaced many T with Self.
- single_use_lifetimes: removed some single use lifetimes.
- unreachable_pub: removed some unreachable pub items.
- unused_crate_dependencies: removed unused futures,parking_lot deps.
- unused_qualifications: found a potential `crate` vs `$crate` bug.
- let_underscore_drop: not enabled, seems to trigger false positives.
- missing_copy_implementations: not enabled, unclear if we want this.
- unsafe_op_in_unsafe_fn: not enabled, unclear if we want this.
- unused_results: not enabled, needs many fixes (but I think wanted).
1 year ago
vadorovsky
1fa1241ccb
Merge pull request #764 from aya-rs/fix-docs
...
aya: fix docs build
1 year ago
Tamir Duberstein
b91d90d6b9
github: build qemu from source if bad signature
...
See https://github.com/Homebrew/homebrew-core/issues/140244 .
1 year ago
Tamir Duberstein
9ff1bf3d3b
aya: fix docs build
...
Appease the new lint rustdoc::redundant_explicit_links that was added in
https://github.com/rust-lang/rust/pull/113167 .
1 year ago
Tamir Duberstein
47a09a4ec9
Merge pull request #761 from aya-rs/mac-broken-qemu
...
Fix macOS CI
1 year ago
Tamir Duberstein
756e6b979a
github: brew reinstall qemu
...
See https://github.com/Homebrew/homebrew-core/pull/139492 .
1 year ago
Tamir Duberstein
9ba0b04207
github: use gnubin rather than bespoke symlinks
1 year ago
Tamir Duberstein
1d5f764d07
Merge pull request #758 from aya-rs/map-fd-not-option
...
aya: MapData::fd is non-optional
1 year ago
Tamir Duberstein
a31544b6e7
maps: BloomFilter::insert takes &mut self
...
This is consistent with all the other maps.
1 year ago
Tamir Duberstein
89bc255f1d
aya: MapData::fd is non-optional
...
The primary driver of change here is that `MapData::create` is now a
factory function that returns `Result<Self, _>` rather than mutating
`&mut self`. The remaining changes are consequences of that change, the
most notable of which is the removal of several errors which are no
longer possible.
1 year ago
Tamir Duberstein
c7b5cd5eb5
Merge pull request #757 from aya-rs/attach-fd-owned
...
programs: `ProgramData::attach_prog_fd` is owned
1 year ago
Tamir Duberstein
3d68fa32cb
aya: use RAII to close FDs
1 year ago
Tamir Duberstein
ae6526e59b
programs: `ProgramData::attach_prog_fd` is owned
...
This prevents a file descriptor leak when extensions are used.
This is an API breaking change.
Updates #612 .
1 year ago
Tamir Duberstein
8b3a93161d
xtask: bless API with new nightly
1 year ago
dependabot[bot]
befa55eafc
Merge pull request #755 from aya-rs/dependabot/cargo/num_enum-0.7
1 year ago
dependabot[bot]
623cfd89bf
build(deps): update num_enum requirement from 0.6 to 0.7
...
Updates the requirements on [num_enum](https://github.com/illicitonion/num_enum ) to permit the latest version.
- [Commits](https://github.com/illicitonion/num_enum/compare/0.6.0...0.6.1 )
---
updated-dependencies:
- dependency-name: num_enum
dependency-type: direct:production
...
Signed-off-by: dependabot[bot] <support@github.com>
1 year ago
dependabot[bot]
9b72d6d260
Merge pull request #754 from aya-rs/dependabot/cargo/object-0.32
1 year ago
dependabot[bot]
d0838a7688
build(deps): update object requirement from 0.31 to 0.32
...
Updates the requirements on [object](https://github.com/gimli-rs/object ) to permit the latest version.
- [Changelog](https://github.com/gimli-rs/object/blob/master/CHANGELOG.md )
- [Commits](https://github.com/gimli-rs/object/compare/0.31.0...0.31.1 )
---
updated-dependencies:
- dependency-name: object
dependency-type: direct:production
...
Signed-off-by: dependabot[bot] <support@github.com>
1 year ago
Tamir Duberstein
e813a054ad
Merge pull request #744 from aya-rs/programfd-borrowed
...
programs: `ProgramFd` is owned
1 year ago
Tamir Duberstein
504fd1df0a
programs: `ProgramFd` is owned
...
`ProgramData::fd` is now a `ProgramFd`. This means that `ProgramData`
now closes the file descriptor on drop. In the future we might consider
making `ProgramFd` hold a `BorrowedFd` but this requires API design work
due to overlapping borrows.
Since `ProgramFd` is no longer `Copy`, update methods to take it by
reference to allow callers to use it multiple times as they are
accustomed to doing.
`ProgramFd` is now returned by reference and implements `try_clone` to
allow callers to avoid file descriptor cloning when desired.
This is an API breaking change.
Updates #612 .
1 year ago
Tamir Duberstein
7874ad99f7
Merge pull request #756 from aya-rs/wget
...
github: fix CI
1 year ago
Tamir Duberstein
6740c43a02
github: update 6.4.0 URLs
...
Seems the previous spin was pulled.
1 year ago
Tamir Duberstein
89eafd139d
github: use gxargs on macOS
...
`xargs -P0` always exits 0 on macOS, even on error.
1 year ago
Tamir Duberstein
47a8a4b878
github: reduce wget verbosity, remove -q
...
This allows errors to be shown; -q hides *all* output, which is not what
we want.
1 year ago
Andrew Stoycos
bcc9743254
Merge pull request #637 from astoycos/helpers
...
Add more helpful methods to `ProgramInfo`
1 year ago
Andrew Stoycos
e1a556894c
aya: add helper methods for ProgramInfo
...
- Add helper methods to get useful information from the ProgramInfo
object which is returned by the `loaded_programs()` API. Specifically
this code mirrors the `bpftool prog` command in terms of useful fields.
- Add a new API macro to each aya `Program` type to allow us to fetch
its accompanying `ProgramInfo` metadata after its been loaded.
- Add a new ProgramInfo constructor that builds a new instance using
a raw fd.
- Add a smoke test for the loaded_programs() API as well as
all the relevant methods on the ProgramInfo type.
Signed-off-by: Andrew Stoycos <astoycos@redhat.com>
1 year ago
Dave Tucker
03c5012db2
Merge pull request #702 from dave-tucker/mapdata-btffd
...
aya: Don't store btf_fd in MapData
1 year ago
Dave Tucker
8ce1c00ad8
Merge pull request #749 from dave-tucker/clang-format
...
.github: Add clang-format
1 year ago
Tamir Duberstein
7f98e419e6
Merge pull request #748 from aya-rs/btf_obj_fd-owned
...
programs: Plug attach_btf_obj_fd leak
1 year ago
Tamir Duberstein
d88ca62aaa
programs: Plug attach_btf_obj_fd leak
...
`ProgramData::attach_btf_obj_fd` is now owned. This means that
`ProgramData` now closes the file descriptor on drop.
Updates #612 .
1 year ago
Dave Tucker
db975e9778
aya: Don't store bpf_fd in MapData
...
This is only used in create and therefore can be passed
as a parameter.
Signed-off-by: Dave Tucker <dave@dtucker.co.uk>
1 year ago
Dave Tucker
02124002c8
.github: Add clang-format
...
Signed-off-by: Dave Tucker <dave@dtucker.co.uk>
1 year ago
Dave Tucker
c0a08276a6
Merge pull request #750 from dave-tucker/public-api-bless
1 year ago
Dave Tucker
d85afe78f9
xtask: Fix aya public-api
...
Changes to the bitflags crate changed some of our public api signature.
Signed-off-by: Dave Tucker <dave@dtucker.co.uk>
1 year ago
Tamir Duberstein
5bc922af23
Merge pull request #747 from aya-rs/helpers
...
sys: add map_ids to bpf_prog_get_info_by_fd
1 year ago
Tamir Duberstein
5ac186299b
sys: refactor btf_obj_get_info_by_fd to share code
1 year ago
Tamir Duberstein
c7a19bcefb
sys: add map_ids to bpf_prog_get_info_by_fd
...
Allows the caller to pass a slice which the kernel will populate with
map ids used by the program.
1 year ago
Tamir Duberstein
68bf8818ec
Merge pull request #745 from aya-rs/even-more-aggro-kp-handling
...
xtask: watch for kernel panic in stdout too
1 year ago
Tamir Duberstein
7e14214f47
xtask: add noapic to kernel parameters
...
This might prevent some kernel panics.
1 year ago
Tamir Duberstein
de65ba0067
xtask: watch for kernel panic in stdout too
...
Seems unclear whether kernel panics go to stdout or stderr, so do them
both.
1 year ago
Tamir Duberstein
90cf13163b
Merge pull request #743 from aya-rs/avoid-vec-ksyms
...
util: avoid vector allocation when parsing ksyms
1 year ago
Tamir Duberstein
5138c731a9
util: avoid vector allocation when parsing ksyms
1 year ago
Alessandro Decina
0c0cf70deb
Merge pull request #740 from addisoncrump/main
...
Revisit the stack trace API to remove resolution support
1 year ago
Addison Crump
ed777273b1
nuclear option: no symbol resolution in the crate
1 year ago
Tamir Duberstein
fbbf191bd3
Merge pull request #738 from aya-rs/kill-qemu-better
...
xtask: watch for kernel panics on stderr
1 year ago
Tamir Duberstein
58ba66c003
xtask: watch for kernel panics on stderr
...
It seems these go to stderr, not stdout. Use `Ctrl-A x` to shut QEMU
down if a panic is seen.
1 year ago