arch_specific_insn
Regular
4.4
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
int boostable;
bool if_modifier;
};
4.8
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
int boostable;
bool if_modifier;
};
4.10
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
int boostable;
bool if_modifier;
};
4.13
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
4.15
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
4.18
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
5.0
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
5.3
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
5.4
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
5.8
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
5.11
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
int tp_len;
};
5.13
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
unsigned int boostable;
unsigned char size;
unsigned char opcode;
struct (anon) jcc;
struct (anon) loop;
struct (anon) indirect;
s32 rel32;
void (*emulate_op)(struct kprobe *, struct pt_regs *);
int tp_len;
};
5.15
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
unsigned int boostable;
unsigned char size;
unsigned char opcode;
struct (anon) jcc;
struct (anon) loop;
struct (anon) indirect;
s32 rel32;
void (*emulate_op)(struct kprobe *, struct pt_regs *);
int tp_len;
};
5.19
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
unsigned int boostable;
unsigned char size;
unsigned char opcode;
struct (anon) jcc;
struct (anon) loop;
struct (anon) indirect;
s32 rel32;
void (*emulate_op)(struct kprobe *, struct pt_regs *);
int tp_len;
};
6.2
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
unsigned int boostable;
unsigned char size;
unsigned char opcode;
struct (anon) jcc;
struct (anon) loop;
struct (anon) indirect;
s32 rel32;
void (*emulate_op)(struct kprobe *, struct pt_regs *);
int tp_len;
};
6.5
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
unsigned int boostable;
unsigned char size;
unsigned char opcode;
struct (anon) jcc;
struct (anon) loop;
struct (anon) indirect;
s32 rel32;
void (*emulate_op)(struct kprobe *, struct pt_regs *);
int tp_len;
};
6.8
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
unsigned int boostable;
unsigned char size;
unsigned char opcode;
struct (anon) jcc;
struct (anon) loop;
struct (anon) indirect;
s32 rel32;
void (*emulate_op)(struct kprobe *, struct pt_regs *);
int tp_len;
};
arm64
: ✅struct arch_specific_insn {
struct arch_probe_insn api;
};
armhf
: Absent ⚠️
ppc64el
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
int boostable;
};
riscv64
: Absent ⚠️
aws
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
azure
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
gcp
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
lowlatency
: ✅struct arch_specific_insn {
kprobe_opcode_t *insn;
bool boostable;
bool if_modifier;
};
Regular
4.4
and 4.8
✅
4.8
and 4.10
✅
4.10
and 4.13
⚠️int boostable
➡️ bool boostable
4.13
and 4.15
✅
4.15
and 4.18
✅
4.18
and 5.0
✅
5.0
and 5.3
✅
5.3
and 5.4
✅
5.4
and 5.8
✅
5.8
and 5.11
⚠️int tp_len
5.11
and 5.13
⚠️unsigned char size
unsigned char opcode
struct (anon) jcc
struct (anon) loop
struct (anon) indirect
s32 rel32
void (*emulate_op)(struct kprobe *, struct pt_regs *)
bool if_modifier
bool boostable
➡️ unsigned int boostable
5.13
and 5.15
✅
5.15
and 5.19
✅
5.19
and 6.2
✅
6.2
and 6.5
✅
6.5
and 6.8
✅
amd64
and arm64
⚠️struct arch_probe_insn api
kprobe_opcode_t *insn
bool boostable
bool if_modifier
amd64
and ppc64el
⚠️bool if_modifier
bool boostable
➡️ int boostable
generic
and aws
✅
generic
and azure
✅
generic
and gcp
✅
generic
and lowlatency
✅