SYS.h (209878) | SYS.h (218824) |
---|---|
1/*- 2 * Copyright (c) 2002 Benno Rice. All rights reserved. 3 * Copyright (c) 2002 David E. O'Brien. All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright --- 13 unchanged lines hidden (view full) --- 22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27 * SUCH DAMAGE. 28 * 29 * $NetBSD: SYS.h,v 1.8 2002/01/14 00:55:56 thorpej Exp $ | 1/*- 2 * Copyright (c) 2002 Benno Rice. All rights reserved. 3 * Copyright (c) 2002 David E. O'Brien. All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright --- 13 unchanged lines hidden (view full) --- 22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27 * SUCH DAMAGE. 28 * 29 * $NetBSD: SYS.h,v 1.8 2002/01/14 00:55:56 thorpej Exp $ |
30 * $FreeBSD: head/lib/libc/powerpc64/SYS.h 209878 2010-07-10 14:45:03Z nwhitehorn $ | 30 * $FreeBSD: head/lib/libc/powerpc64/SYS.h 218824 2011-02-18 21:44:53Z nwhitehorn $ |
31 */ 32 33#include <sys/syscall.h> 34#include <machine/asm.h> 35 36#define _SYSCALL(x) \ 37 .text; \ 38 .align 2; \ 39 li 0,(__CONCAT(SYS_,x)); \ 40 sc 41 42#define SYSCALL(x) \ 43 .text; \ 44 .align 2; \ 452: mflr %r0; \ 46 std %r0,16(%r1); \ 47 stdu %r1,-48(%r1); \ | 31 */ 32 33#include <sys/syscall.h> 34#include <machine/asm.h> 35 36#define _SYSCALL(x) \ 37 .text; \ 38 .align 2; \ 39 li 0,(__CONCAT(SYS_,x)); \ 40 sc 41 42#define SYSCALL(x) \ 43 .text; \ 44 .align 2; \ 452: mflr %r0; \ 46 std %r0,16(%r1); \ 47 stdu %r1,-48(%r1); \ |
48 bl PIC_PLT(CNAME(HIDENAME(cerror))); \ | 48 bl CNAME(HIDENAME(cerror)); \ |
49 nop; \ 50 addi %r1,%r1,48; \ 51 ld %r0,16(%r1); \ 52 mtlr %r0; \ 53 blr; \ 54ENTRY(__CONCAT(__sys_,x)); \ 55 .weak CNAME(x); \ 56 .set CNAME(x),CNAME(__CONCAT(__sys_,x)); \ 57 .weak CNAME(__CONCAT(_,x)); \ 58 .set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \ | 49 nop; \ 50 addi %r1,%r1,48; \ 51 ld %r0,16(%r1); \ 52 mtlr %r0; \ 53 blr; \ 54ENTRY(__CONCAT(__sys_,x)); \ 55 .weak CNAME(x); \ 56 .set CNAME(x),CNAME(__CONCAT(__sys_,x)); \ 57 .weak CNAME(__CONCAT(_,x)); \ 58 .set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \ |
59 .weak CNAME(__CONCAT(.,x)); \ 60 .set CNAME(__CONCAT(.,x)),CNAME(__CONCAT(.__sys_,x));\ 61 .weak CNAME(__CONCAT(._,x)); \ 62 .set CNAME(__CONCAT(._,x)),CNAME(__CONCAT(.__sys_,x));\ | |
63 _SYSCALL(x); \ 64 bso 2b 65 66#define PSEUDO(x) \ 67 .text; \ 68 .align 2; \ 69ENTRY(__CONCAT(__sys_,x)); \ 70 .weak CNAME(__CONCAT(_,x)); \ 71 .set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \ | 59 _SYSCALL(x); \ 60 bso 2b 61 62#define PSEUDO(x) \ 63 .text; \ 64 .align 2; \ 65ENTRY(__CONCAT(__sys_,x)); \ 66 .weak CNAME(__CONCAT(_,x)); \ 67 .set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \ |
72 .weak CNAME(__CONCAT(._,x)); \ 73 .set CNAME(__CONCAT(._,x)),CNAME(__CONCAT(.__sys_,x));\ | |
74 _SYSCALL(x); \ 75 bnslr; \ 76 mflr %r0; \ 77 std %r0,16(%r1); \ 78 stdu %r1,-48(%r1); \ | 68 _SYSCALL(x); \ 69 bnslr; \ 70 mflr %r0; \ 71 std %r0,16(%r1); \ 72 stdu %r1,-48(%r1); \ |
79 bl PIC_PLT(CNAME(HIDENAME(cerror))); \ | 73 bl CNAME(HIDENAME(cerror)); \ |
80 nop; \ 81 addi %r1,%r1,48; \ 82 ld %r0,16(%r1); \ 83 mtlr %r0; \ 84 blr; 85 86#define RSYSCALL(x) \ 87 .text; \ 88 .align 2; \ 89ENTRY(__CONCAT(__sys_,x)); \ 90 .weak CNAME(x); \ 91 .set CNAME(x),CNAME(__CONCAT(__sys_,x)); \ 92 .weak CNAME(__CONCAT(_,x)); \ 93 .set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \ | 74 nop; \ 75 addi %r1,%r1,48; \ 76 ld %r0,16(%r1); \ 77 mtlr %r0; \ 78 blr; 79 80#define RSYSCALL(x) \ 81 .text; \ 82 .align 2; \ 83ENTRY(__CONCAT(__sys_,x)); \ 84 .weak CNAME(x); \ 85 .set CNAME(x),CNAME(__CONCAT(__sys_,x)); \ 86 .weak CNAME(__CONCAT(_,x)); \ 87 .set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \ |
94 .weak CNAME(__CONCAT(.,x)); \ 95 .set CNAME(__CONCAT(.,x)),CNAME(__CONCAT(.__sys_,x));\ 96 .weak CNAME(__CONCAT(._,x)); \ 97 .set CNAME(__CONCAT(._,x)),CNAME(__CONCAT(.__sys_,x));\ | |
98 _SYSCALL(x); \ 99 bnslr; \ 100 \ 101 mflr %r0; \ 102 std %r0,16(%r1); \ 103 stdu %r1,-48(%r1); \ | 88 _SYSCALL(x); \ 89 bnslr; \ 90 \ 91 mflr %r0; \ 92 std %r0,16(%r1); \ 93 stdu %r1,-48(%r1); \ |
104 bl PIC_PLT(CNAME(HIDENAME(cerror))); \ | 94 bl CNAME(HIDENAME(cerror)); \ |
105 nop; \ 106 addi %r1,%r1,48; \ 107 ld %r0,16(%r1); \ 108 mtlr %r0; \ 109 blr; | 95 nop; \ 96 addi %r1,%r1,48; \ 97 ld %r0,16(%r1); \ 98 mtlr %r0; \ 99 blr; |