From 9db8a8bc5d9d440aec5103aec0fcac645ffcec6d Mon Sep 17 00:00:00 2001
From: hcg <hcg@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Date: Fri, 14 Nov 2008 07:52:54 +0000
Subject: Add support for openat system call - this must be extended for the
 rest of these system calls

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@13200 3c298f89-4303-0410-b956-a3cf2f4a3e73
---
 .../patches/160-add_openat_and_friends.patch       | 68 ++++++++++++++++++++++
 1 file changed, 68 insertions(+)
 create mode 100644 toolchain/uClibc/patches/160-add_openat_and_friends.patch

diff --git a/toolchain/uClibc/patches/160-add_openat_and_friends.patch b/toolchain/uClibc/patches/160-add_openat_and_friends.patch
new file mode 100644
index 000000000..74dff7bbf
--- /dev/null
+++ b/toolchain/uClibc/patches/160-add_openat_and_friends.patch
@@ -0,0 +1,68 @@
+Index: uClibc-0.9.29/libc/sysdeps/linux/common/openat.c
+===================================================================
+--- /dev/null	1970-01-01 00:00:00.000000000 +0000
++++ uClibc-0.9.29/libc/sysdeps/linux/common/openat.c	2008-10-27 12:59:25.000000000 +0100
+@@ -0,0 +1,41 @@
++/* vi: set sw=4 ts=4: */
++/*
++ * openat() for uClibc
++ *
++ * Copyright (C) 2000-2006 Erik Andersen <andersen@uclibc.org>
++ *
++ * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
++ */
++
++#include <sys/syscall.h>
++#include <stdlib.h>
++#include <stdarg.h>
++#include <fcntl.h>
++#include <string.h>
++#include <sys/param.h>
++
++extern __typeof(openat) __libc_openat;
++
++#define __NR___syscall_openat __NR_openat
++static inline _syscall4(int, __syscall_openat, int, fd, const char *, file,
++		int, flags, __kernel_mode_t, mode);
++
++libc_hidden_proto(__libc_openat)
++int __libc_openat(int fd, const char *file, int oflag, ...)
++{
++	mode_t mode = 0;
++
++	if (oflag & O_CREAT) {
++		va_list arg;
++		va_start (arg, oflag);
++		mode = va_arg (arg, mode_t);
++		va_end (arg);
++	}
++
++	return __syscall_openat(fd, file, oflag, mode);
++}
++libc_hidden_def(__libc_openat)
++
++libc_hidden_proto(openat)
++weak_alias(__libc_openat,openat)
++libc_hidden_weak(openat)
+Index: uClibc-0.9.29/include/fcntl.h
+===================================================================
+--- uClibc-0.9.29.orig/include/fcntl.h	2008-10-27 12:52:04.000000000 +0100
++++ uClibc-0.9.29/include/fcntl.h	2008-10-27 13:08:11.000000000 +0100
+@@ -56,7 +56,7 @@
+ # define SEEK_END	2	/* Seek from end of file.  */
+ #endif	/* XPG */
+ 
+-#if 0 /*def __USE_GNU*/
++#ifdef __USE_GNU
+ # define AT_FDCWD		-100	/* Special value used to indicate
+ 					   openat should use the current
+ 					   working directory. */
+@@ -103,7 +103,7 @@
+ extern int open64 (__const char *__file, int __oflag, ...) __nonnull ((1));
+ #endif
+ 
+-#if 0 /*def __USE_GNU*/
++#ifdef __USE_GNU
+ /* Similar to OPEN but a relative path name is interpreted relative to
+    the directory for which FD is a descriptor.
+ 
-- 
cgit v1.2.3