| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 | /* Copyright (C) 1995,96,97,98,99,2000,2002 Free Software Foundation, Inc.   This file is part of the GNU C Library.   The GNU C Library is free software; you can redistribute it and/or   modify it under the terms of the GNU Lesser General Public   License as published by the Free Software Foundation; either   version 2.1 of the License, or (at your option) any later version.   The GNU C Library is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU   Lesser General Public License for more details.   You should have received a copy of the GNU Lesser General Public   License along with the GNU C Library; if not, write to the Free   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA   02111-1307 USA.  */#define _ERRNO_H	1#include <features.h>#include <bits/errno.h>#include <sys/syscall.h>#if defined __UCLIBC_HAS_LFS__ && defined __NR_mmap2#define LINKAGE     4#define PTR_SIZE    4#define SVRSP	16		/* saved register space */#define PARMS	LINKAGE+SVRSP	/* space for 4 saved regs */#define ADDR	PARMS#define LEN	ADDR+PTR_SIZE#define PROT	LEN+4#define FLAGS	PROT+4#define FD	FLAGS+4#define OFFLO	FD+4#define OFFHI	OFFLO+4        .text	.globl mmap64;	.type mmap64,@function;	.align 1<<4;mmap64:	/* Save registers.  */	pushl %ebp	pushl %ebx	pushl %esi	pushl %edi	movl OFFLO(%esp), %edx	movl OFFHI(%esp), %ecx	testl $0xfff, %edx	jne L_einval	shrdl $12, %ecx, %edx		/* mmap2 takes the offset in pages.  */	shrl $12, %ecx	jne L_einval	movl %edx, %ebp	movl ADDR(%esp), %ebx	movl LEN(%esp), %ecx	movl PROT(%esp), %edx	movl FLAGS(%esp), %esi	movl FD(%esp), %edi	movl $__NR_mmap2, %eax	/* System call number in %eax.  */	int $0x80	/* Restore registers.  */	popl %edi	popl %esi	popl %ebx	popl %ebp	/* If 0 > %eax > -4096 there was an error.  */	cmpl $-4095,%eax	jae __syscall_error	ret	/* This means the offset value is too large.  */L_einval:	popl %edi	popl %esi	popl %ebx	popl %ebp	movl $-EINVAL, %eax	jmp __syscall_error__syscall_error:	negl    %eax	pushl   %eax#ifdef __PIC__	call .Lthere.Lthere:	popl	%ebx	addl	$_GLOBAL_OFFSET_TABLE_+[.- .Lthere  ], %ebx	call    __errno_location@PLT#else	call	__errno_location#endif	popl	%ecx	movl	%ecx, (%eax)	xorl	%eax, %eax	decl	%eax.Lsize:	.size	 mmap64,.Lsize-mmap64#endif
 |