static_call.h (1063B)
1/* SPDX-License-Identifier: GPL-2.0 */ 2#ifndef _ASM_POWERPC_STATIC_CALL_H 3#define _ASM_POWERPC_STATIC_CALL_H 4 5#define __PPC_SCT(name, inst) \ 6 asm(".pushsection .text, \"ax\" \n" \ 7 ".align 5 \n" \ 8 ".globl " STATIC_CALL_TRAMP_STR(name) " \n" \ 9 STATIC_CALL_TRAMP_STR(name) ": \n" \ 10 inst " \n" \ 11 " lis 12,2f@ha \n" \ 12 " lwz 12,2f@l(12) \n" \ 13 " mtctr 12 \n" \ 14 " bctr \n" \ 15 "1: li 3, 0 \n" \ 16 " blr \n" \ 17 "2: .long 0 \n" \ 18 ".type " STATIC_CALL_TRAMP_STR(name) ", @function \n" \ 19 ".size " STATIC_CALL_TRAMP_STR(name) ", . - " STATIC_CALL_TRAMP_STR(name) " \n" \ 20 ".popsection \n") 21 22#define PPC_SCT_RET0 20 /* Offset of label 1 */ 23#define PPC_SCT_DATA 28 /* Offset of label 2 */ 24 25#define ARCH_DEFINE_STATIC_CALL_TRAMP(name, func) __PPC_SCT(name, "b " #func) 26#define ARCH_DEFINE_STATIC_CALL_NULL_TRAMP(name) __PPC_SCT(name, "blr") 27#define ARCH_DEFINE_STATIC_CALL_RET0_TRAMP(name) __PPC_SCT(name, "b .+20") 28 29#endif /* _ASM_POWERPC_STATIC_CALL_H */