arch_specific_insnRegular
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 ✅