I am trying to modify the behaviour of a userspace function during runtime using ebpf uprobes. bpf_override_return is used in kprobes to override the return value, is it possible to use it in uprobes/uretprobes?
Is it possible to use bpf_override_return in uprobes/uretprobes?
197 Views Asked by imawful At
2
There are 2 best solutions below
0
Yunwei 123
On
There is another userspace eBPF runtime, https://github.com/eunomia-bpf/bpftime which can be compatible with kernel eBPF uprobe and supports override userspace functions and this helper. Maybe you can have a try?
See the examples in https://github.com/eunomia-bpf/bpftime/tree/master/example/error-inject (It's experimental, though)
Related Questions in LINUX
- Is there some way to use printf to print a horizontal list of decrementing hex digits in NASM assembly on Linux
- Why does Hugo generate different taxonomy-related HTML on different OS's?
- Writes in io_uring do not advance the file offset
- Why `set -o pipefail` gives different output even though the pipe is not failing
- what really controls the permissions: UID or eUID?
- Compiling eBPF program in Docker fails due to missing '__u64' type
- Docker container unable to make HTTPS requests to external API
- Whow to use callback_query_handler in Python 3.10
- Create kea runtime directory at startup in Yocto image
- Problem on CPU scheduling algorithms in OS
- How to copy files into the singularity sandbox?
- Android kernel error: undefined reference to `get_hw_version_platform'
- Is there a need for BPF Linux namespace?
- Error when trying to execute a binary compiled in a Kali Linux machine on an Ubuntu system
- Issue with launching application after updating ElectronJs to version 28.0.0 on Windows and Linux
Related Questions in HOOK
- How to modify HTML in WordPress core file
- I want to use toilet to modify hook_function
- Is there a way to add a pre-hook in R?
- Vite / Rollup Static Asset Copy Hook
- Mouse hook with non-English language results in extremely laggy mouse
- Retrieve Extra parameters from Airflow Connection
- In Wordpress, I want to filter the content when a page is updated or created
- Is it possible to hook a non-configurable property like window.location.hostname, in JavaScript?
- Is there a WordPress hook that fires before post.php, from which I can get the post ID?
- Woocommerce - Hide other shipping methods if free shipping is available not working properly
- Woocommerce 8.6.1 checkout form hooks not fired
- Storing Individual Quiz Answers in LearnPress Plugin - WordPress
- runing a feature with after hooks in cucumber
- Modify redis.Cmder content in hook
- IAT hook is not working with notepad.exe on Windows
Related Questions in INSTRUMENTATION
- Setup sentry to only log transactions occuring on a specific subpage
- How can I modify the core api in java ?
- OpenJDK Tracking ReentrantLock lock and unlock
- How to lookup the function addresses of ALL functions instrumented with gcc -finstrument-functions flag?
- (Instrument API, Agent)My ClassFileTransformer's transform method fails to recognize a specific class in Springboot
- Initializing Non-Primtive Field by ByteBuddy in Aspect
- EF Core connection pool metrics in Prometheus
- Why IntelPin tool build gets linker error when using wincrypt functions?
- Is it possible to use bpf_override_return in uprobes/uretprobes?
- Memory trace of a function and all the functions called by it
- Overhead of pintool with no instrumentation done
- How can I determine which CMake targets were added by a command?
- Compilation failure on custom class with package java.util
- How to inject a script in html pages without touching the application code in ASP.NET Core
- .NET command line dynamic profiler not capturing data
Related Questions in EBPF
- How to monitor the traffic of Android applications uploading images?
- R2 max value is outside of the allowed memory range after explicit bounds checking
- invalid access to map value, value_size=128 off=0 size=0; libbpf: prog 'xdp_parser_func': failed to load: -13
- ebpf not displaying output with tracing_pipe
- ebpf: about the kfuncs call and MAX_BPF_STACK
- Ebpf: Invalid access to map value, with weird compiled code
- Ebpf Kernel Code: permission denied: invalid access to map value
- Invalid access to packet while iterating over packet in eBPF program , with “bpf_trace_printk”
- Where are the "hooks" for BPF functions defined?
- How to iterate vm_area in bpf/bcc program?
- BCC tool execute failed on Android by debianfs
- unknown type name ‘GElf_Nhdr’; did you mean ‘GElf_Shdr’?
- ebpf hook some points, after running for a while. the system is hang ,is kernel bug?
- How do I initialize/reinitialize BPF_MAP_TYPE_PERCPU_HASH entry to zero for all CPUs?
- BPF per CPU array is not zero initialized?
Related Questions in UPROBE
- Pid filter is working for uprobes but not uretprobes
- bpf_override_return not working with uretprobes
- How to obtain connection information in a uprobe to SSL_write?
- Is it possible to use bpf_override_return in uprobes/uretprobes?
- Can `bpf_probe_write_user` cause segmentation fault?
- Is it possible to modify const parameters of a function using ebpf uprobes?
- maximum number of uprobe /kprobe that can be attached using libbpf
- adding code to bpf _kernel.c file for uprobe SEC routines (libbpf +c)
- Get sizeof internal go struct
- Why is uprobe unaffected by ASLR?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
uprobes share the BPF infrastructure of kprobes so yes, you should be able to call
bpf_override_returnfrom uprobe BPF programs. Note you'll needCONFIG_BPF_KPROBE_OVERRIDEin your kernel config.The bcc project has a list of which helpers are allowed from which program types at https://github.com/iovisor/bcc/blob/master/docs/kernel-versions.md.
To check yourself which program type allow for a given helper, you can run the following on the kernel sources:
Here we see that
bpf_override_returncan be called from kprobe programs only.