Skip to content

Commit 8c2dcbd

Browse files
Suzuki K Poulosewildea01
authored andcommitted
arm64: Add helper to decode register from instruction
Add a helper to extract the register field from a given instruction. Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Will Deacon <will.deacon@arm.com> Cc: Mark Rutland <mark.rutland@arm.com> Reviewed-by: Catalin Marinas <catalin.marinas@arm.com> Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com> Signed-off-by: Will Deacon <will.deacon@arm.com>
1 parent c9ee0f9 commit 8c2dcbd

File tree

2 files changed

+31
-0
lines changed

2 files changed

+31
-0
lines changed

arch/arm64/include/asm/insn.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -332,6 +332,8 @@ bool aarch64_insn_is_branch(u32 insn);
332332
u64 aarch64_insn_decode_immediate(enum aarch64_insn_imm_type type, u32 insn);
333333
u32 aarch64_insn_encode_immediate(enum aarch64_insn_imm_type type,
334334
u32 insn, u64 imm);
335+
u32 aarch64_insn_decode_register(enum aarch64_insn_register_type type,
336+
u32 insn);
335337
u32 aarch64_insn_gen_branch_imm(unsigned long pc, unsigned long addr,
336338
enum aarch64_insn_branch_type type);
337339
u32 aarch64_insn_gen_comp_branch_imm(unsigned long pc, unsigned long addr,

arch/arm64/kernel/insn.c

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -417,6 +417,35 @@ u32 __kprobes aarch64_insn_encode_immediate(enum aarch64_insn_imm_type type,
417417
return insn;
418418
}
419419

420+
u32 aarch64_insn_decode_register(enum aarch64_insn_register_type type,
421+
u32 insn)
422+
{
423+
int shift;
424+
425+
switch (type) {
426+
case AARCH64_INSN_REGTYPE_RT:
427+
case AARCH64_INSN_REGTYPE_RD:
428+
shift = 0;
429+
break;
430+
case AARCH64_INSN_REGTYPE_RN:
431+
shift = 5;
432+
break;
433+
case AARCH64_INSN_REGTYPE_RT2:
434+
case AARCH64_INSN_REGTYPE_RA:
435+
shift = 10;
436+
break;
437+
case AARCH64_INSN_REGTYPE_RM:
438+
shift = 16;
439+
break;
440+
default:
441+
pr_err("%s: unknown register type encoding %d\n", __func__,
442+
type);
443+
return 0;
444+
}
445+
446+
return (insn >> shift) & GENMASK(4, 0);
447+
}
448+
420449
static u32 aarch64_insn_encode_register(enum aarch64_insn_register_type type,
421450
u32 insn,
422451
enum aarch64_insn_register reg)

0 commit comments

Comments
 (0)