summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristophe Leroy <christophe.leroy@c-s.fr>2018-11-09 12:33:17 -0500
committerMichael Ellerman <mpe@ellerman.id.au>2018-12-19 02:56:32 -0500
commit36b08b431e2e282f78d09921ca55652d2c55eee5 (patch)
tree33cb6b2464db86caaa9493d91223bae99fc45316
parent45090c26614fe991d9d5a2cd08e65c4d6680549a (diff)
powerpc: add modify_instruction() and modify_instruction_site()
Add two helpers to avoid hardcoding of instructions modifications. Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
-rw-r--r--arch/powerpc/include/asm/code-patching.h11
1 files changed, 11 insertions, 0 deletions
diff --git a/arch/powerpc/include/asm/code-patching.h b/arch/powerpc/include/asm/code-patching.h
index 0eeed21e4898..2074b40f3fb5 100644
--- a/arch/powerpc/include/asm/code-patching.h
+++ b/arch/powerpc/include/asm/code-patching.h
@@ -49,6 +49,17 @@ static inline int patch_branch_site(s32 *site, unsigned long target, int flags)
49 return patch_branch((unsigned int *)patch_site_addr(site), target, flags); 49 return patch_branch((unsigned int *)patch_site_addr(site), target, flags);
50} 50}
51 51
52static inline int modify_instruction(unsigned int *addr, unsigned int clr,
53 unsigned int set)
54{
55 return patch_instruction(addr, (*addr & ~clr) | set);
56}
57
58static inline int modify_instruction_site(s32 *site, unsigned int clr, unsigned int set)
59{
60 return modify_instruction((unsigned int *)patch_site_addr(site), clr, set);
61}
62
52int instr_is_relative_branch(unsigned int instr); 63int instr_is_relative_branch(unsigned int instr);
53int instr_is_relative_link_branch(unsigned int instr); 64int instr_is_relative_link_branch(unsigned int instr);
54int instr_is_branch_to_addr(const unsigned int *instr, unsigned long addr); 65int instr_is_branch_to_addr(const unsigned int *instr, unsigned long addr);