/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ ! ! "@(#)SYS.h 1.14 88/02/08" ! Copyright (c) 1986, 1996 by Sun Microsystems, Inc. ! All rights reserved. ! #include <sys/syscall.h> #include <machine/asm_linkage.h> #include "PIC.h" #define SV_ERESTART 91 /* ERESTART is returned by the kernel for restartable system calls */ #define WINDOWSIZE (16*4) .global .cerror #define SYSCALL(x) \ ENTRY(x); \ mov SYS_/**/x, %g1; \ t 8; \ CERROR(o5) #define BSDSYSCALL(x) \ ENTRY(_/**/x); \ mov SYS_/**/x, %g1; \ t 8; \ CERROR(o5) /* * SYSREENTRY provides the entry sequence for restartable system calls. */ #define SYSREENTRY(x) \ ENTRY(x); \ st %o0,[%sp+68]; \ .restart_/**/x: #define PSEUDO(x, y) \ ENTRY(x); \ mov SYS_/**/y, %g1; \ t 8; /* * SYSCALL_RESTART provides the most common restartable system call sequence. */ #define SYSCALL_RESTART(x) \ SYSREENTRY(x); \ mov SYS_/**/x, %g1; \ t 8; \ SYSRESTART(.restart_/**/x) /* * SYSREENTRY provides the entry sequence for restartable system calls. */ #define SYSREENTRY(x) \ ENTRY(x); \ st %o0,[%sp+68]; \ .restart_/**/x: /* * SYSRESTART provides the error handling sequence for restartable * system calls. */ #ifdef PIC #define SYSRESTART(x) \ bcc noerr; \ cmp %o0, SV_ERESTART; \ be,a x; \ ld [%sp+68], %o0; \ PIC_SETUP(o5); \ ld [%o5 + .cerror], %o5; \ jmp %o5; \ .empty; \ noerr: nop ; #else #define SYSRESTART(x) \ bcc noerr; \ cmp %o0, SV_ERESTART; \ be,a x; \ ld [%sp+68], %o0; \ ba .cerror; \ .empty; \ noerr: nop ; #endif #define RET retl; nop; #ifdef PIC #define CERROR(free_reg) \ bcc noerr; \ PIC_SETUP(free_reg); \ .empty; \ ld [%free_reg+ .cerror],%free_reg; \ jmp %free_reg; \ .empty; \ noerr: nop; #else #define CERROR(free_reg) \ bcc noerr; \ .empty; \ sethi %hi(.cerror), %free_reg;\ or %free_reg, %lo(.cerror), %free_reg;\ jmp %free_reg;\ .empty;\ noerr: nop; #endif