diff options
author | Brendan Jackman <[email protected]> | 2021-01-14 18:17:49 +0000 |
---|---|---|
committer | Alexei Starovoitov <[email protected]> | 2021-01-14 18:34:29 -0800 |
commit | 981f94c3e92146705baf97fb417a5ed1ab1a79a5 (patch) | |
tree | 3e9cd30902659db0e4de8f9afad972f259d9dcf9 /tools/perf/scripts/python/flamegraph.py | |
parent | 462910670e4ac91509829c5549bd0227668176fb (diff) |
bpf: Add bitwise atomic instructions
This adds instructions for
atomic[64]_[fetch_]and
atomic[64]_[fetch_]or
atomic[64]_[fetch_]xor
All these operations are isomorphic enough to implement with the same
verifier, interpreter, and x86 JIT code, hence being a single commit.
The main interesting thing here is that x86 doesn't directly support
the fetch_ version these operations, so we need to generate a CMPXCHG
loop in the JIT. This requires the use of two temporary registers,
IIUC it's safe to use BPF_REG_AX and x86's AUX_REG for this purpose.
Signed-off-by: Brendan Jackman <[email protected]>
Signed-off-by: Alexei Starovoitov <[email protected]>
Acked-by: Yonghong Song <[email protected]>
Link: https://lore.kernel.org/bpf/[email protected]
Diffstat (limited to 'tools/perf/scripts/python/flamegraph.py')
0 files changed, 0 insertions, 0 deletions