#ifndef _MACHINE_ASM_H_
#define _MACHINE_ASM_H_
#include <sys/cdefs.h>
#if defined(PIC) && !defined(__powerpc64__)
#define PIC_PROLOGUE XXX
#define PIC_EPILOGUE XXX
#define PIC_PLT(x) x@plt
#ifdef __STDC__
#define PIC_GOT(x) XXX
#else
#define PIC_GOT(x) XXX
#endif
#else
#define PIC_PROLOGUE
#define PIC_EPILOGUE
#define PIC_PLT(x) x
#define PIC_GOT(x) x
#endif
#define CNAME(csym) csym
#define ASMNAME(asmsym) asmsym
#ifdef __powerpc64__
#define HIDENAME(asmsym) __CONCAT(_,asmsym)
#else
#define HIDENAME(asmsym) __CONCAT(.,asmsym)
#endif
#if !defined(_CALL_ELF) || _CALL_ELF == 1
#ifdef _KERNEL
#define DOT_LABEL(name) __CONCAT(.,name)
#define TYPE_ENTRY(name) .size name,24; \
.type DOT_LABEL(name),@function; \
.globl DOT_LABEL(name);
#define END_SIZE(name) .size DOT_LABEL(name),.-DOT_LABEL(name);
#else
#define DOT_LABEL(name) __CONCAT(.L.,name)
#define TYPE_ENTRY(name) .type name,@function;
#define END_SIZE(name) .size name,.-DOT_LABEL(name);
#endif
#else
#define DOT_LABEL(name) name
#define TYPE_ENTRY(name) .type name,@function;
#define END_SIZE(name) .size name,.-DOT_LABEL(name);
#endif
#define _GLOBAL(name) \
.data; \
.p2align 2; \
.globl name; \
name:
#ifdef __powerpc64__
#define TOC_NAME_FOR_REF(name) __CONCAT(.L,name)
#define TOC_REF(name) TOC_NAME_FOR_REF(name)@toc
#define TOC_ENTRY(name) \
.section ".toc","aw"; \
TOC_NAME_FOR_REF(name): \
.tc name[TC],name
#endif
#ifdef __powerpc64__
#if !defined(_CALL_ELF) || _CALL_ELF == 1
#define _ENTRY(name) \
.section ".text"; \
.p2align 2; \
.globl name; \
.section ".opd","aw"; \
.p2align 3; \
name: \
.quad DOT_LABEL(name),.TOC.@tocbase,0; \
.previous; \
.p2align 4; \
TYPE_ENTRY(name) \
DOT_LABEL(name): \
.cfi_startproc
#define _NAKED_ENTRY(name) _ENTRY(name)
#else
#define _ENTRY(name) \
.text; \
.p2align 4; \
.globl name; \
.type name,@function; \
name: \
.cfi_startproc; \
addis %r2, %r12, (.TOC.-name)@ha; \
addi %r2, %r2, (.TOC.-name)@l; \
.localentry name, .-name;
#define _NAKED_ENTRY(name) \
.text; \
.p2align 4; \
.globl name; \
.type name,@function; \
name: \
.cfi_startproc; \
.localentry name, .-name;
#endif
#define _END(name) \
.cfi_endproc; \
.long 0; \
.byte 0,0,0,0,0,0,0,0; \
END_SIZE(name)
#define LOAD_ADDR(reg, var) \
lis reg, var@highest; \
ori reg, reg, var@higher; \
rldicr reg, reg, 32, 31; \
oris reg, reg, var@h; \
ori reg, reg, var@l;
#else
#define _ENTRY(name) \
.text; \
.p2align 4; \
.globl name; \
.type name,@function; \
name: \
.cfi_startproc
#define _END(name) \
.cfi_endproc; \
.size name, . - name
#define _NAKED_ENTRY(name) _ENTRY(name)
#define LOAD_ADDR(reg, var) \
lis reg, var@ha; \
ori reg, reg, var@l;
#endif
#if defined(PROF) || (defined(_KERNEL) && defined(GPROF))
# ifdef __powerpc64__
# define _PROF_PROLOGUE mflr 0; \
std 3,48(1); \
std 4,56(1); \
std 5,64(1); \
std 0,16(1); \
stdu 1,-112(1); \
bl _mcount; \
nop; \
ld 0,112+16(1); \
ld 3,112+48(1); \
ld 4,112+56(1); \
ld 5,112+64(1); \
mtlr 0; \
addi 1,1,112
# else
# define _PROF_PROLOGUE mflr 0; stw 0,4(1); bl _mcount
# endif
#else
# define _PROF_PROLOGUE
#endif
#define ASEND(y) _END(ASMNAME(y))
#define ASENTRY(y) _ENTRY(ASMNAME(y)); _PROF_PROLOGUE
#define END(y) _END(CNAME(y))
#define ENTRY(y) _ENTRY(CNAME(y)); _PROF_PROLOGUE
#define GLOBAL(y) _GLOBAL(CNAME(y))
#define ASENTRY_NOPROF(y) _ENTRY(ASMNAME(y))
#define ENTRY_NOPROF(y) _ENTRY(CNAME(y))
#define LOAD_LR_NIA bcl 20, 31, .+4
#define RETURN_TO_NATIVE_ENDIAN \
tdi 0, %r0, 0x48; \
b 1f; \
.long 0xa600607d; \
.long 0x00000038; \
.long 0x6401617d; \
.long 0x01006b69; \
.long 0xa602087c; \
.long 0x05009f42; \
.long 0xa6037b7d; \
.long 0xa602687d; \
.long 0x18006b39; \
.long 0xa6037a7d; \
.long 0xa603087c; \
.long 0x2400004c; \
1:
#define ASMSTR .asciz
#define RCSID(x) .text; .asciz x
#undef __FBSDID
#if !defined(lint) && !defined(STRIP_FBSDID)
#define __FBSDID(s) .ident s
#else
#define __FBSDID(s)
#endif
#define WEAK_REFERENCE(sym, alias) \
.weak alias; \
.equ alias,sym
#ifdef __STDC__
#define WARN_REFERENCES(_sym,_msg) \
.section .gnu.warning. ## _sym ; .ascii _msg ; .text
#else
#define WARN_REFERENCES(_sym,_msg) \
.section .gnu.warning._sym ; .ascii _msg ; .text
#endif
#endif