Back out and replace recent kludges for errno and clock_systimer. There is a cleaner way

This commit is contained in:
Gregory Nutt
2014-08-30 14:26:56 -06:00
parent 4864b4c8c1
commit 2029236ed0
8 changed files with 17 additions and 130 deletions
+3 -1
View File
@@ -409,8 +409,10 @@ audio/libaudio$(LIBEXT): context
lib/libaudio$(LIBEXT): audio/libaudio$(LIBEXT)
$(Q) install audio/libaudio$(LIBEXT) lib/libaudio$(LIBEXT)
# Special case
syscall/libstubs$(LIBEXT): context
$(Q) $(MAKE) -C syscall TOPDIR="$(TOPDIR)" libstubs$(LIBEXT) EXTRADEFINES=$(KDEFINE)
$(Q) $(MAKE) -C syscall TOPDIR="$(TOPDIR)" libstubs$(LIBEXT) # EXTRADEFINES=$(KDEFINE)
lib/libstubs$(LIBEXT): syscall/libstubs$(LIBEXT)
$(Q) install syscall/libstubs$(LIBEXT) lib/libstubs$(LIBEXT)
+3 -1
View File
@@ -430,8 +430,10 @@ audio\libaudio$(LIBEXT): context
lib\libaudio$(LIBEXT): audio\libaudio$(LIBEXT)
$(Q) install audio\libaudio$(LIBEXT) lib\libaudio$(LIBEXT)
# Special case
syscall\libstubs$(LIBEXT): context
$(Q) $(MAKE) -C syscall TOPDIR="$(TOPDIR)" libstubs$(LIBEXT) EXTRADEFINES=$(KDEFINE)
$(Q) $(MAKE) -C syscall TOPDIR="$(TOPDIR)" libstubs$(LIBEXT) # EXTRADEFINES=$(KDEFINE)
lib\libstubs$(LIBEXT): syscall\libstubs$(LIBEXT)
$(Q) install syscall\libstubs$(LIBEXT) lib\libstubs$(LIBEXT)
+1 -1
View File
@@ -63,7 +63,7 @@
# define __DIRECT_ERRNO_ACCESS 1
#elif defined(CONFIG_BUILD_KERNEL)
#elif defined(CONFIG_BUILD_KERNEL) && defined(__KERNEL__)
/* Kernel only build. The kernel has access */
# define __DIRECT_ERRNO_ACCESS 1
+2 -8
View File
@@ -71,18 +71,12 @@
# define __HAVE_KERNEL_GLOBALS 0
#elif defined(CONFIG_BUILD_PROTECTED)
# if defined(__KERNEL__)
#elif defined(CONFIG_BUILD_PROTECTED) && defined(__KERNEL__)
/* Case 3: Kernel mode of protected kernel build */
# define __HAVE_KERNEL_GLOBALS 1
# else
/* User mode of protected kernel build */
# define __HAVE_KERNEL_GLOBALS 0
# endif
#elif defined(CONFIG_BUILD_KERNEL)
#elif defined(CONFIG_BUILD_KERNEL) && defined(__KERNEL__)
/* Case 3: Kernel only build */
# define __HAVE_KERNEL_GLOBALS 1
-110
View File
@@ -1,110 +0,0 @@
/************************************************************************
* include/nuttx/errno.h
*
* Copyright (C) 2014 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <gnutt@nuttx.org>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3. Neither the name NuttX nor the names of its contributors may be
* used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
************************************************************************/
#ifndef __INCLUDE_NUTTX_ERRNO_H
#define __INCLUDE_NUTTX_ERRNO_H
/************************************************************************
* Included Files
************************************************************************/
#include <nuttx/config.h>
/* These must always be included before this file */
#include <errno.h>
#include <nuttx/clock.h>
#ifdef CONFIG_LIB_SYSCALL
/************************************************************************
* Pre-processor Definitions
************************************************************************/
/* 'errno' and timer access is awkward. We need to generate get_errno(),
* set_errno(), and clock_systimer() interfaces to support the system
* calls, even though we don't use them from within the OS.
*
* The "normal" pre-processor definitions for the errno functions are in
* errno.h and clock functions in nuttx/clock.h but we need the internal
* function prototypes in here because those may be macro-ized.
*/
#undef get_errno
#undef set_errno
#undef clock_systimer
/************************************************************************
* Type Declarations
************************************************************************/
/************************************************************************
* Public Data
************************************************************************/
#undef EXTERN
#if defined(__cplusplus)
#define EXTERN extern "C"
extern "C"
{
#else
#define EXTERN extern
#endif
/************************************************************************
* Public Function Prototypes
************************************************************************/
/* These get_errno(), set_errno(), and clock_systimer() functions are
* always exported as functions from the kernel always when the system
* call interface is built. errno.h and nuttx/clock.h provide the
* context-specific usage interface for both the kernel- and
* user-spaces. These may be different: These interfaces may be macro-
* ized in those header files.
*
* This header file always exists to disambiguate the context. The
* prototypes here duplicate those of errno.h and nuttx/clock.h and must
* exactly match.
*/
void set_errno(int errcode);
int get_errno(void);
uint32_t clock_systimer(void);
#undef EXTERN
#if defined(__cplusplus)
}
#endif
#endif /* CONFIG_LIB_SYSCALL */
#endif /* __INCLUDE_NUTTX_ERRNO_H */
+3 -4
View File
@@ -49,7 +49,10 @@
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
/* See nuttx/clock.h */
#undef clock_systimer
/****************************************************************************
* Private Data
****************************************************************************/
@@ -74,7 +77,6 @@
*
****************************************************************************/
#if !defined(clock_systimer) /* See nuttx/clock.h */
uint32_t clock_systimer(void)
{
#ifdef CONFIG_SCHED_TICKLESS
@@ -104,7 +106,6 @@ uint32_t clock_systimer(void)
#endif
}
#endif
/****************************************************************************
* Name: clock_systimer64
@@ -122,7 +123,6 @@ uint32_t clock_systimer(void)
*
****************************************************************************/
#if !defined(clock_systimer) /* See nuttx/clock.h */
#ifdef CONFIG_SYSTEM_TIME64
uint64_t clock_systimer64(void)
{
@@ -144,4 +144,3 @@ uint64_t clock_systimer64(void)
#endif
}
#endif
#endif
+3 -3
View File
@@ -6,7 +6,7 @@
"clock_getres","time.h","","int","clockid_t","struct timespec*"
"clock_gettime","time.h","","int","clockid_t","struct timespec*"
"clock_settime","time.h","","int","clockid_t","const struct timespec*"
"clock_systimer","nuttx/syscall.h","","uint32_t"
"clock_systimer","nuttx/clock.h","","uint32_t"
"close","unistd.h","CONFIG_NSOCKET_DESCRIPTORS > 0 || CONFIG_NFILE_DESCRIPTORS > 0","int","int"
"closedir","dirent.h","CONFIG_NFILE_DESCRIPTORS > 0","int","FAR DIR*"
"connect","sys/socket.h","CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET)","int","int","FAR const struct sockaddr*","socklen_t"
@@ -18,7 +18,7 @@
"fcntl","fcntl.h","CONFIG_NFILE_DESCRIPTORS > 0","int","int","int","..."
"fs_fdopen","nuttx/fs/fs.h","CONFIG_NFILE_DESCRIPTORS > 0 && CONFIG_NFILE_STREAMS > 0","FAR struct file_struct*","int","int","FAR struct tcb_s*"
"fsync","unistd.h","CONFIG_NFILE_DESCRIPTORS > 0 && !defined(CONFIG_DISABLE_MOUNTPOINT)","int","int"
"get_errno","nuttx/syscall.h","","int"
"get_errno","errno.h","","int"
"getenv","stdlib.h","!defined(CONFIG_DISABLE_ENVIRON)","FAR char*","FAR const char*"
"getpid","unistd.h","","pid_t"
"getsockopt","sys/socket.h","CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET)","int","int","int","int","FAR void*","FAR socklen_t*"
@@ -110,7 +110,7 @@
"send","sys/socket.h","CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET)","ssize_t","int","FAR const void*","size_t","int"
"sendfile","sys/sendfile.h","CONFIG_NFILE_DESCRIPTORS > 0 && defined(CONFIG_NET_SENDFILE)","ssize_t","int","int","FAR off_t*","size_t"
"sendto","sys/socket.h","CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET)","ssize_t","int","FAR const void*","size_t","int","FAR const struct sockaddr*","socklen_t"
"set_errno","nuttx/syscall.h","","void","int"
"set_errno","errno.h","","void","int"
"setenv","stdlib.h","!defined(CONFIG_DISABLE_ENVIRON)","int","const char*","const char*","int"
"setsockopt","sys/socket.h","CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET)","int","int","int","int","FAR const void*","socklen_t"
"sigaction","signal.h","!defined(CONFIG_DISABLE_SIGNALS)","int","int","FAR const struct sigaction*","FAR struct sigaction*"
1 _exit unistd.h void int
6 clock_getres time.h int clockid_t
7 clock_gettime time.h int clockid_t
8 clock_settime time.h int clockid_t
9 clock_systimer nuttx/syscall.h nuttx/clock.h uint32_t
10 close unistd.h CONFIG_NSOCKET_DESCRIPTORS > 0 || CONFIG_NFILE_DESCRIPTORS > 0 int int
11 closedir dirent.h CONFIG_NFILE_DESCRIPTORS > 0 int FAR DIR*
12 connect sys/socket.h CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET) int int
18 fcntl fcntl.h CONFIG_NFILE_DESCRIPTORS > 0 int int
19 fs_fdopen nuttx/fs/fs.h CONFIG_NFILE_DESCRIPTORS > 0 && CONFIG_NFILE_STREAMS > 0 FAR struct file_struct* int
20 fsync unistd.h CONFIG_NFILE_DESCRIPTORS > 0 && !defined(CONFIG_DISABLE_MOUNTPOINT) int int
21 get_errno nuttx/syscall.h errno.h int
22 getenv stdlib.h !defined(CONFIG_DISABLE_ENVIRON) FAR char* FAR const char*
23 getpid unistd.h pid_t
24 getsockopt sys/socket.h CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET) int int
110 send sys/socket.h CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET) ssize_t int
111 sendfile sys/sendfile.h CONFIG_NFILE_DESCRIPTORS > 0 && defined(CONFIG_NET_SENDFILE) ssize_t int
112 sendto sys/socket.h CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET) ssize_t int
113 set_errno nuttx/syscall.h errno.h void int
114 setenv stdlib.h !defined(CONFIG_DISABLE_ENVIRON) int const char*
115 setsockopt sys/socket.h CONFIG_NSOCKET_DESCRIPTORS > 0 && defined(CONFIG_NET) int int
116 sigaction signal.h !defined(CONFIG_DISABLE_SIGNALS) int int
+2 -2
View File
@@ -46,7 +46,7 @@
* a kernel build.
*/
#if defined(CONFIG_LIB_SYSCALL) && defined(__KERNEL__)
#if defined(CONFIG_LIB_SYSCALL)
/****************************************************************************
* Pre-processor definitions
@@ -341,4 +341,4 @@ const uintptr_t g_stublookup[SYS_nsyscalls] =
* Public Functions
****************************************************************************/
#endif /* CONFIG_LIB_SYSCALL && __KERNEL__ */
#endif /* CONFIG_LIB_SYSCALL */