Commit 2c5aca6e authored by Antonio Nino Diaz's avatar Antonio Nino Diaz
Browse files

libc: Cleanup FreeBSD files



Remove code specific to FreeBSD so that they can be used in this
repository.

Change-Id: I5c11eb5b3c05a7fb91aed08371a1f7a0e6122a94
Signed-off-by: default avatarAntonio Nino Diaz <antonio.ninodiaz@arm.com>
parent c6fdaa73
...@@ -31,11 +31,15 @@ ...@@ -31,11 +31,15 @@
* $NetBSD: endian.h,v 1.7 1999/08/21 05:53:51 simonb Exp $ * $NetBSD: endian.h,v 1.7 1999/08/21 05:53:51 simonb Exp $
* $FreeBSD$ * $FreeBSD$
*/ */
/*
* Portions copyright (c) 2018, ARM Limited and Contributors.
* All rights reserved.
*/
#ifndef _ENDIAN_H_ #ifndef AARCH32_ENDIAN_H
#define _ENDIAN_H_ #define AARCH32_ENDIAN_H
#include <sys/_types.h> #include <stdint.h>
/* /*
* Definitions for byte order, according to byte significance from low * Definitions for byte order, according to byte significance from low
...@@ -61,10 +65,10 @@ ...@@ -61,10 +65,10 @@
#ifdef __ARMEB__ #ifdef __ARMEB__
#define _QUAD_HIGHWORD 0 #define _QUAD_HIGHWORD 0
#define _QUAD_LOWWORD 1 #define _QUAD_LOWWORD 1
#define __ntohl(x) ((__uint32_t)(x)) #define __ntohl(x) ((uint32_t)(x))
#define __ntohs(x) ((__uint16_t)(x)) #define __ntohs(x) ((uint16_t)(x))
#define __htonl(x) ((__uint32_t)(x)) #define __htonl(x) ((uint32_t)(x))
#define __htons(x) ((__uint16_t)(x)) #define __htons(x) ((uint16_t)(x))
#else #else
#define _QUAD_HIGHWORD 1 #define _QUAD_HIGHWORD 1
#define _QUAD_LOWWORD 0 #define _QUAD_LOWWORD 0
...@@ -74,20 +78,20 @@ ...@@ -74,20 +78,20 @@
#define __htons(x) (__bswap16(x)) #define __htons(x) (__bswap16(x))
#endif /* __ARMEB__ */ #endif /* __ARMEB__ */
static __inline __uint64_t static __inline uint64_t
__bswap64(__uint64_t _x) __bswap64(uint64_t _x)
{ {
return ((_x >> 56) | ((_x >> 40) & 0xff00) | ((_x >> 24) & 0xff0000) | return ((_x >> 56) | ((_x >> 40) & 0xff00) | ((_x >> 24) & 0xff0000) |
((_x >> 8) & 0xff000000) | ((_x << 8) & ((__uint64_t)0xff << 32)) | ((_x >> 8) & 0xff000000) | ((_x << 8) & ((uint64_t)0xff << 32)) |
((_x << 24) & ((__uint64_t)0xff << 40)) | ((_x << 24) & ((uint64_t)0xff << 40)) |
((_x << 40) & ((__uint64_t)0xff << 48)) | ((_x << 56))); ((_x << 40) & ((uint64_t)0xff << 48)) | ((_x << 56)));
} }
static __inline __uint32_t static __inline uint32_t
__bswap32_var(__uint32_t v) __bswap32_var(uint32_t v)
{ {
__uint32_t t1; uint32_t t1;
__asm __volatile("eor %1, %0, %0, ror #16\n" __asm __volatile("eor %1, %0, %0, ror #16\n"
"bic %1, %1, #0x00ff0000\n" "bic %1, %1, #0x00ff0000\n"
...@@ -98,10 +102,10 @@ __bswap32_var(__uint32_t v) ...@@ -98,10 +102,10 @@ __bswap32_var(__uint32_t v)
return (v); return (v);
} }
static __inline __uint16_t static __inline uint16_t
__bswap16_var(__uint16_t v) __bswap16_var(uint16_t v)
{ {
__uint32_t ret = v & 0xffff; uint32_t ret = v & 0xffff;
__asm __volatile( __asm __volatile(
"mov %0, %0, ror #8\n" "mov %0, %0, ror #8\n"
...@@ -109,7 +113,7 @@ __bswap16_var(__uint16_t v) ...@@ -109,7 +113,7 @@ __bswap16_var(__uint16_t v)
"bic %0, %0, %0, lsl #16" "bic %0, %0, %0, lsl #16"
: "+r" (ret)); : "+r" (ret));
return ((__uint16_t)ret); return ((uint16_t)ret);
} }
#ifdef __OPTIMIZE__ #ifdef __OPTIMIZE__
...@@ -125,12 +129,12 @@ __bswap16_var(__uint16_t v) ...@@ -125,12 +129,12 @@ __bswap16_var(__uint16_t v)
(((x) & 0x00ff) << 8)) (((x) & 0x00ff) << 8))
#define __bswap16(x) \ #define __bswap16(x) \
((__uint16_t)(__builtin_constant_p(x) ? \ ((uint16_t)(__builtin_constant_p(x) ? \
__bswap16_constant(x) : \ __bswap16_constant(x) : \
__bswap16_var(x))) __bswap16_var(x)))
#define __bswap32(x) \ #define __bswap32(x) \
((__uint32_t)(__builtin_constant_p(x) ? \ ((uint32_t)(__builtin_constant_p(x) ? \
__bswap32_constant(x) : \ __bswap32_constant(x) : \
__bswap32_var(x))) __bswap32_var(x)))
...@@ -139,4 +143,4 @@ __bswap16_var(__uint16_t v) ...@@ -139,4 +143,4 @@ __bswap16_var(__uint16_t v)
#define __bswap32(x) __bswap32_var(x) #define __bswap32(x) __bswap32_var(x)
#endif /* __OPTIMIZE__ */ #endif /* __OPTIMIZE__ */
#endif /* !_ENDIAN_H_ */ #endif /* AARCH32_ENDIAN_H */
/*- /*-
* SPDX-License-Identifier: BSD-3-Clause
*
* Copyright (c) 2001 David E. O'Brien * Copyright (c) 2001 David E. O'Brien
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
...@@ -29,11 +31,15 @@ ...@@ -29,11 +31,15 @@
* $NetBSD: endian.h,v 1.7 1999/08/21 05:53:51 simonb Exp $ * $NetBSD: endian.h,v 1.7 1999/08/21 05:53:51 simonb Exp $
* $FreeBSD$ * $FreeBSD$
*/ */
/*
* Portions copyright (c) 2018, ARM Limited and Contributors.
* All rights reserved.
*/
#ifndef _MACHINE_ENDIAN_H_ #ifndef AARCH64_ENDIAN_H
#define _MACHINE_ENDIAN_H_ #define AARCH64_ENDIAN_H
#include <sys/_types.h> #include <stdint.h>
/* /*
* Definitions for byte order, according to byte significance from low * Definitions for byte order, according to byte significance from low
...@@ -59,38 +65,38 @@ ...@@ -59,38 +65,38 @@
#define __htonl(x) (__bswap32(x)) #define __htonl(x) (__bswap32(x))
#define __htons(x) (__bswap16(x)) #define __htons(x) (__bswap16(x))
static __inline __uint64_t static __inline uint64_t
__bswap64(__uint64_t x) __bswap64(uint64_t x)
{ {
__uint64_t ret; uint64_t ret;
__asm __volatile("rev %0, %1\n" __asm __volatile("rev %0, %1\n"
: "=&r" (ret), "+r" (x)); : "=&r" (ret), "+r" (x));
return (ret); return (ret);
} }
static __inline __uint32_t static __inline uint32_t
__bswap32_var(__uint32_t v) __bswap32_var(uint32_t v)
{ {
__uint32_t ret; uint32_t ret;
__asm __volatile("rev32 %x0, %x1\n" __asm __volatile("rev32 %x0, %x1\n"
: "=&r" (ret), "+r" (v)); : "=&r" (ret), "+r" (v));
return (ret); return (ret);
} }
static __inline __uint16_t static __inline uint16_t
__bswap16_var(__uint16_t v) __bswap16_var(uint16_t v)
{ {
__uint32_t ret; uint32_t ret;
__asm __volatile("rev16 %w0, %w1\n" __asm __volatile("rev16 %w0, %w1\n"
: "=&r" (ret), "+r" (v)); : "=&r" (ret), "+r" (v));
return ((__uint16_t)ret); return ((uint16_t)ret);
} }
#ifdef __OPTIMIZE__ #ifdef __OPTIMIZE__
...@@ -105,13 +111,13 @@ __bswap16_var(__uint16_t v) ...@@ -105,13 +111,13 @@ __bswap16_var(__uint16_t v)
(((x) & 0x00ff) << 8)) (((x) & 0x00ff) << 8))
#define __bswap16(x) \ #define __bswap16(x) \
((__uint16_t)(__builtin_constant_p(x) ? \ ((uint16_t)(__builtin_constant_p(x) ? \
__bswap16_constant((__uint16_t)(x)) : \ __bswap16_constant((uint16_t)(x)) : \
__bswap16_var(x))) __bswap16_var(x)))
#define __bswap32(x) \ #define __bswap32(x) \
((__uint32_t)(__builtin_constant_p(x) ? \ ((uint32_t)(__builtin_constant_p(x) ? \
__bswap32_constant((__uint32_t)(x)) : \ __bswap32_constant((uint32_t)(x)) : \
__bswap32_var(x))) __bswap32_var(x)))
#else #else
...@@ -119,4 +125,4 @@ __bswap16_var(__uint16_t v) ...@@ -119,4 +125,4 @@ __bswap16_var(__uint16_t v)
#define __bswap32(x) __bswap32_var(x) #define __bswap32(x) __bswap32_var(x)
#endif /* __OPTIMIZE__ */ #endif /* __OPTIMIZE__ */
#endif /* !_MACHINE_ENDIAN_H_ */ #endif /* AARCH64_ENDIAN_H */
...@@ -27,34 +27,18 @@ ...@@ -27,34 +27,18 @@
* *
* $FreeBSD$ * $FreeBSD$
*/ */
/*
* Portions copyright (c) 2018, ARM Limited and Contributors.
* All rights reserved.
*/
#ifndef ENDIAN_H
#define ENDIAN_H
#include <cdefs.h>
#include <stdint.h>
#include <endian_.h>
#ifndef _SYS_ENDIAN_H_
#define _SYS_ENDIAN_H_
#include <sys/cdefs.h>
#include <sys/_types.h>
#include <machine/endian.h>
#ifndef _UINT8_T_DECLARED
typedef __uint8_t uint8_t;
#define _UINT8_T_DECLARED
#endif
#ifndef _UINT16_T_DECLARED
typedef __uint16_t uint16_t;
#define _UINT16_T_DECLARED
#endif
#ifndef _UINT32_T_DECLARED
typedef __uint32_t uint32_t;
#define _UINT32_T_DECLARED
#endif
#ifndef _UINT64_T_DECLARED
typedef __uint64_t uint64_t;
#define _UINT64_T_DECLARED
#endif
/* /*
* General byte order swapping functions. * General byte order swapping functions.
*/ */
...@@ -204,4 +188,4 @@ le64enc(void *pp, uint64_t u) ...@@ -204,4 +188,4 @@ le64enc(void *pp, uint64_t u)
le32enc(p + 4, (uint32_t)(u >> 32)); le32enc(p + 4, (uint32_t)(u >> 32));
} }
#endif /* _SYS_ENDIAN_H_ */ #endif /* SYS_ENDIAN_H */
...@@ -36,17 +36,13 @@ ...@@ -36,17 +36,13 @@
* @(#)errno.h 8.5 (Berkeley) 1/21/94 * @(#)errno.h 8.5 (Berkeley) 1/21/94
* $FreeBSD$ * $FreeBSD$
*/ */
/*
* Portions copyright (c) 2018, ARM Limited and Contributors.
* All rights reserved.
*/
#ifndef _SYS_ERRNO_H_ #ifndef ERRNO_H
#define _SYS_ERRNO_H_ #define ERRNO_H
#if !defined(_KERNEL) && !defined(_STANDALONE)
#include <sys/cdefs.h>
__BEGIN_DECLS
int * __error(void);
__END_DECLS
#define errno (* __error())
#endif
#define EPERM 1 /* Operation not permitted */ #define EPERM 1 /* Operation not permitted */
#define ENOENT 2 /* No such file or directory */ #define ENOENT 2 /* No such file or directory */
...@@ -63,9 +59,7 @@ __END_DECLS ...@@ -63,9 +59,7 @@ __END_DECLS
#define ENOMEM 12 /* Cannot allocate memory */ #define ENOMEM 12 /* Cannot allocate memory */
#define EACCES 13 /* Permission denied */ #define EACCES 13 /* Permission denied */
#define EFAULT 14 /* Bad address */ #define EFAULT 14 /* Bad address */
#ifndef _POSIX_SOURCE
#define ENOTBLK 15 /* Block device required */ #define ENOTBLK 15 /* Block device required */
#endif
#define EBUSY 16 /* Device busy */ #define EBUSY 16 /* Device busy */
#define EEXIST 17 /* File exists */ #define EEXIST 17 /* File exists */
#define EXDEV 18 /* Cross-device link */ #define EXDEV 18 /* Cross-device link */
...@@ -76,9 +70,7 @@ __END_DECLS ...@@ -76,9 +70,7 @@ __END_DECLS
#define ENFILE 23 /* Too many open files in system */ #define ENFILE 23 /* Too many open files in system */
#define EMFILE 24 /* Too many open files */ #define EMFILE 24 /* Too many open files */
#define ENOTTY 25 /* Inappropriate ioctl for device */ #define ENOTTY 25 /* Inappropriate ioctl for device */
#ifndef _POSIX_SOURCE
#define ETXTBSY 26 /* Text file busy */ #define ETXTBSY 26 /* Text file busy */
#endif
#define EFBIG 27 /* File too large */ #define EFBIG 27 /* File too large */
#define ENOSPC 28 /* No space left on device */ #define ENOSPC 28 /* No space left on device */
#define ESPIPE 29 /* Illegal seek */ #define ESPIPE 29 /* Illegal seek */
...@@ -92,7 +84,6 @@ __END_DECLS ...@@ -92,7 +84,6 @@ __END_DECLS
/* non-blocking and interrupt i/o */ /* non-blocking and interrupt i/o */
#define EAGAIN 35 /* Resource temporarily unavailable */ #define EAGAIN 35 /* Resource temporarily unavailable */
#ifndef _POSIX_SOURCE
#define EWOULDBLOCK EAGAIN /* Operation would block */ #define EWOULDBLOCK EAGAIN /* Operation would block */
#define EINPROGRESS 36 /* Operation now in progress */ #define EINPROGRESS 36 /* Operation now in progress */
#define EALREADY 37 /* Operation already in progress */ #define EALREADY 37 /* Operation already in progress */
...@@ -127,18 +118,14 @@ __END_DECLS ...@@ -127,18 +118,14 @@ __END_DECLS
#define ECONNREFUSED 61 /* Connection refused */ #define ECONNREFUSED 61 /* Connection refused */
#define ELOOP 62 /* Too many levels of symbolic links */ #define ELOOP 62 /* Too many levels of symbolic links */
#endif /* _POSIX_SOURCE */
#define ENAMETOOLONG 63 /* File name too long */ #define ENAMETOOLONG 63 /* File name too long */
/* should be rearranged */ /* should be rearranged */
#ifndef _POSIX_SOURCE
#define EHOSTDOWN 64 /* Host is down */ #define EHOSTDOWN 64 /* Host is down */
#define EHOSTUNREACH 65 /* No route to host */ #define EHOSTUNREACH 65 /* No route to host */
#endif /* _POSIX_SOURCE */
#define ENOTEMPTY 66 /* Directory not empty */ #define ENOTEMPTY 66 /* Directory not empty */
/* quotas & mush */ /* quotas & mush */
#ifndef _POSIX_SOURCE
#define EPROCLIM 67 /* Too many processes */ #define EPROCLIM 67 /* Too many processes */
#define EUSERS 68 /* Too many users */ #define EUSERS 68 /* Too many users */
#define EDQUOT 69 /* Disc quota exceeded */ #define EDQUOT 69 /* Disc quota exceeded */
...@@ -151,12 +138,10 @@ __END_DECLS ...@@ -151,12 +138,10 @@ __END_DECLS
#define EPROGUNAVAIL 74 /* RPC prog. not avail */ #define EPROGUNAVAIL 74 /* RPC prog. not avail */
#define EPROGMISMATCH 75 /* Program version wrong */ #define EPROGMISMATCH 75 /* Program version wrong */
#define EPROCUNAVAIL 76 /* Bad procedure for program */ #define EPROCUNAVAIL 76 /* Bad procedure for program */
#endif /* _POSIX_SOURCE */
#define ENOLCK 77 /* No locks available */ #define ENOLCK 77 /* No locks available */
#define ENOSYS 78 /* Function not implemented */ #define ENOSYS 78 /* Function not implemented */
#ifndef _POSIX_SOURCE
#define EFTYPE 79 /* Inappropriate file type or format */ #define EFTYPE 79 /* Inappropriate file type or format */
#define EAUTH 80 /* Authentication error */ #define EAUTH 80 /* Authentication error */
#define ENEEDAUTH 81 /* Need authenticator */ #define ENEEDAUTH 81 /* Need authenticator */
...@@ -168,41 +153,17 @@ __END_DECLS ...@@ -168,41 +153,17 @@ __END_DECLS
#define ENOATTR 87 /* Attribute not found */ #define ENOATTR 87 /* Attribute not found */
#define EDOOFUS 88 /* Programming error */ #define EDOOFUS 88 /* Programming error */
#endif /* _POSIX_SOURCE */
#define EBADMSG 89 /* Bad message */ #define EBADMSG 89 /* Bad message */
#define EMULTIHOP 90 /* Multihop attempted */ #define EMULTIHOP 90 /* Multihop attempted */
#define ENOLINK 91 /* Link has been severed */ #define ENOLINK 91 /* Link has been severed */
#define EPROTO 92 /* Protocol error */ #define EPROTO 92 /* Protocol error */
#ifndef _POSIX_SOURCE
#define ENOTCAPABLE 93 /* Capabilities insufficient */ #define ENOTCAPABLE 93 /* Capabilities insufficient */
#define ECAPMODE 94 /* Not permitted in capability mode */ #define ECAPMODE 94 /* Not permitted in capability mode */
#define ENOTRECOVERABLE 95 /* State not recoverable */ #define ENOTRECOVERABLE 95 /* State not recoverable */
#define EOWNERDEAD 96 /* Previous owner died */ #define EOWNERDEAD 96 /* Previous owner died */
#endif /* _POSIX_SOURCE */
#ifndef _POSIX_SOURCE
#define ELAST 96 /* Must be equal largest errno */ #define ELAST 96 /* Must be equal largest errno */
#endif /* _POSIX_SOURCE */
#endif /* ERRNO_H */
#if defined(_KERNEL) || defined(_WANT_KERNEL_ERRNO)
/* pseudo-errors returned inside kernel to modify return to process */
#define ERESTART (-1) /* restart syscall */
#define EJUSTRETURN (-2) /* don't modify regs, just return */
#define ENOIOCTL (-3) /* ioctl not handled by this layer */
#define EDIRIOCTL (-4) /* do direct ioctl in GEOM */
#define ERELOOKUP (-5) /* retry the directory lookup */
#endif
#ifndef _KERNEL
#if __EXT1_VISIBLE
/* ISO/IEC 9899:2011 K.3.2.2 */
#ifndef _ERRNO_T_DEFINED
#define _ERRNO_T_DEFINED
typedef int errno_t;
#endif
#endif /* __EXT1_VISIBLE */
#endif
#endif
...@@ -29,11 +29,10 @@ ...@@ -29,11 +29,10 @@
* SUCH DAMAGE. * SUCH DAMAGE.
*/ */
#if defined(LIBC_SCCS) && !defined(lint) /*
static char sccsid[] = "@(#)index.c 8.1 (Berkeley) 6/4/93"; * Portions copyright (c) 2018, ARM Limited and Contributors.
#endif /* LIBC_SCCS and not lint */ * All rights reserved.
#include <sys/cdefs.h> */
__FBSDID("$FreeBSD$");
#include <stddef.h> #include <stddef.h>
#include <string.h> #include <string.h>
...@@ -52,5 +51,3 @@ strchr(const char *p, int ch) ...@@ -52,5 +51,3 @@ strchr(const char *p, int ch)
} }
/* NOTREACHED */ /* NOTREACHED */
} }
__weak_reference(strchr, index);
...@@ -32,11 +32,10 @@ ...@@ -32,11 +32,10 @@
* SUCH DAMAGE. * SUCH DAMAGE.
*/ */
#if defined(LIBC_SCCS) && !defined(lint) /*
static char sccsid[] = "@(#)strcmp.c 8.1 (Berkeley) 6/4/93"; * Portions copyright (c) 2018, ARM Limited and Contributors.
#endif /* LIBC_SCCS and not lint */ * All rights reserved.
#include <sys/cdefs.h> */
__FBSDID("$FreeBSD$");
#include <string.h> #include <string.h>
......
...@@ -29,11 +29,10 @@ ...@@ -29,11 +29,10 @@
* SUCH DAMAGE. * SUCH DAMAGE.
*/ */
#if defined(LIBC_SCCS) && !defined(lint) /*
static char sccsid[] = "@(#)strncmp.c 8.1 (Berkeley) 6/4/93"; * Portions copyright (c) 2018, ARM Limited and Contributors.
#endif /* LIBC_SCCS and not lint */ * All rights reserved.
#include <sys/cdefs.h> */
__FBSDID("$FreeBSD$");
#include <string.h> #include <string.h>
......
...@@ -26,8 +26,10 @@ ...@@ -26,8 +26,10 @@
* SUCH DAMAGE. * SUCH DAMAGE.
*/ */
#include <sys/cdefs.h> /*
__FBSDID("$FreeBSD$"); * Portions copyright (c) 2018, ARM Limited and Contributors.
* All rights reserved.
*/
#include <string.h> #include <string.h>
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment