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?
193 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
- How do I recursively find and replace only in files named index.php on Linux webserver?
- passing text with \n as one argument in shell
- kernel module does not print packet info
- How to send ESC/POS commands to thermal printer in Linux
- (x64 Nasm) Writeline function on Linux
- How do I set the Hive user to something different than the Spark user from within a Spark program?
- Default priority of thread with SCHED_FIFO
- Calling a python function with options from shell script
- How to split a directory into parts without compressing or archiving?
- Cross compile simple standard C program on Linux for Mac
- How to offload NAPI poll function to workqueue
- python netifaces - How to get currently used network interface
- Unexpected output from function
- mingw-64 conflicting declarations when cross-compiling
- Different behavior of async with Visual Studio 2013(Windows8.1) and GCC 4.9(Ubuntu14.10)
Related Questions in HOOK
- How to make Homeslider Banner work in custom hook location
- Customize Liferay search portlet
- Modify files and commit after Branch creation in GIT via Hook
- Removing a Wordpress action added from a Plugin and than adding a new action in place of that
- In WHMCS user can login with every wrong or right password
- To Hook Web Content Search Portlet
- Overriding class signature in java
- Sonata Admin: Prevent a persist for a specific condition
- Is it posible to hook redis before key expired
- Redis hooking (publish-subscribe) under stress tests - performance under load
- Are static members in XPosed hook classes shared between processes?
- Log-in Portlet Hook
- Apache Subversion pre-commit to restrict files
- Mercurial list files from changegroup
- Taking Screeshot of extern Window which have an OpenGL ES Window inside
Related Questions in INSTRUMENTATION
- Instrumenting Jersey2.x Resources with Dropwizard
- Can a PIN tool instrument a bash script that contains code to run other commands?
- How can I profile Signed Assemblies with VS 2012
- Delete all sharedPreferences in Android
- get web application classes with javaagent?
- can LD_PRELOAD trick considered as a type of instrumentation?
- cobertura instrumentation context already initialized
- Pin app terminated abnormally due to signal 6
- UiAutomator 2.0 test from command line
- Read Java Socket connect values using bytecode instrumentation
- Android Instrumentation Test Runner: How to filter multiple test annotations
- Dynamic Bytecode Instrumentation fails without any error
- How to run instrumentation @SmallTests from terminal?
- Can change static methods at run time using java Instrumentation?
- Count number of times LOC has executed in **PROD** - for java app
Related Questions in EBPF
- How to build Linux kernel to support SO_ATTACH_BPF socket option?
- Tc bpf packet forward to other device by updating the Checksum
- What causes `bpf_perf_event_output` to return -22?
- How to cross compile bpf targets for linux arm on Mac M-series laptop?
- Tracing with eBPF tracepoint "netif_receive_skb" for multiple NICs
- Extracting UDP packet payload with eBPF tracepoints using libbpf
- XDP get packet payload
- How to get request/response body with uprobe?
- EBPF Route Table Addition or Modification
- How to access user space function argument (struct pointer) in bpf?
- How to unload bpd program using bpftool?
- How to design eBPF map for large data structures without exceeding jump complexity?
- What is the recommended way to unit test eBPF/XDP program?
- libbpf: failed to guess program from ELF section 'filter'
- I was unble to load my compiled bpf source code in to the kernel
Related Questions in UPROBE
- maximum number of uprobe /kprobe that can be attached using libbpf
- Get sizeof internal go struct
- Is it possible to modify const parameters of a function using ebpf uprobes?
- Is it possible to use bpf_override_return in uprobes/uretprobes?
- Can `bpf_probe_write_user` cause segmentation fault?
- How to obtain connection information in a uprobe to SSL_write?
- bpf_override_return not working with uretprobes
- Pid filter is working for uprobes but not uretprobes
- adding code to bpf _kernel.c file for uprobe SEC routines (libbpf +c)
- 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 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.