diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/Makefile.am | 3 | ||||
| -rw-r--r-- | lib/os_internal.h | 73 | ||||
| -rw-r--r-- | lib/os_types.h | 109 | ||||
| -rw-r--r-- | lib/timedlock.c | 33 | 
4 files changed, 107 insertions, 111 deletions
| diff --git a/lib/Makefile.am b/lib/Makefile.am index 36b695bc8..931c411ac 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -1,10 +1,11 @@  include $(top_srcdir)/misc/Makefile.common +AM_CFLAGS = $(DEFAULT_OCFLAGS) +  EXTRA_DIST = Makefile.common  noinst_LTLIBRARIES = libxineposix.la  noinst_HEADERS = os_internal.h -xineinclude_HEADERS = os_types.h  libxineposix_la_SOURCES =   libxineposix_la_LIBADD = @LTLIBOBJS@ diff --git a/lib/os_internal.h b/lib/os_internal.h index fe406a747..8136ce76e 100644 --- a/lib/os_internal.h +++ b/lib/os_internal.h @@ -1,6 +1,69 @@  #ifndef _XINE_OS_INTERNAL_H  #define _XINE_OS_INTERNAL_H +/* When using Apple's GCC, __APPLE__ will be defined.  This is a whole lot of + * messiness, but it's necessary in order to perform universal builds properly. + * It's meant to over-ride configure time stuff that would be different at + * compile time. + */ +#if defined(__APPLE__) && defined(XINE_MACOSX_UNIVERSAL_BINARY) + +/* __ppc__, __ppc64__, __i386__, __x86_64__ are interesting arch macros */ +#undef HOST_ARCH +#if defined(__ppc__) || defined(__ppc64__) +#define ARCH_PPC +#if defined(__ppc64__) +#define HOST_ARCH           "darwin/powerpc64" +#else +#define HOST_ARCH           "darwin/powerpc" +#endif +#elif defined(__i386__) || defined(__x86_64__) +#define ARCH_X86 +#define BITFIELD_LSBF +#define HAVE_MMX +#if defined(__x86_64__) +#define ARCH_X86_64 +#define HOST_ARCH           "darwin/x86_64" +#elif defined(__i386__) +#define ARCH_X86_32 +#define HOST_ARCH           "darwin/x86_32" +#else +#error unrecognized/unsupported CPU type building for Apple Darwin +#endif +#endif + +/* See /Developer/SDKs/MacOSX10.4u.sdk/usr/include/machine/limits.h */ +#if SIZEOF_INT != 4 +#undef  SIZEOF_INT +#define SIZEOF_INT 4 +#endif + +#if defined(__LP64__) && SIZEOF_LONG != 8 +#undef  SIZEOF_LONG +#define SIZEOF_LONG 8 +#elif !defined(__LP64__) && SIZEOF_LONG != 4 +#undef  SIZEOF_LONG +#define SIZEOF_LONG 4 +#endif + +/* WORDS_BIGENDIAN (replaces AC_C_BIGENDIAN autoconf test at compile time) */ +#include <machine/endian.h> +#if BYTE_ORDER == BIG_ENDIAN +#define WORDS_BIGENDIAN 1 +#else +#undef  WORDS_BIGENDIAN +#endif + +#if defined(__LP64__) +#define FPM_64BIT           1 +#elif defined(__ppc__) || defined(__ppc64__) +#define FPM_PPC             1 +#elif defined(__i386__) || defined(__x86_64__) +#define FPM_INTEL           1 +#endif + +#endif  /* __APPLE__ */ +  #include <stddef.h>  #include <stdarg.h> @@ -21,7 +84,8 @@  #endif  #include <inttypes.h> -#include "../src/xine-utils/attributes.h" +#include <pthread.h> +#include <xine/attributes.h>  #if defined(WIN32) || defined(__CYGWIN__) @@ -150,6 +214,13 @@ int xine_private_vasprintf(char **string, const char *format, va_list ap) XINE_F  char *xine_private_strndup(const char *s, size_t n);  #endif +/* replacement of pthread_mutex_timedlock */ +#ifndef HAVE_PTHREAD_MUTEX_TIMEDLOCK +#define HAVE_PTHREAD_MUTEX_TIMEDLOCK +#define pthread_mutex_timedlock(M, T) xine_private_pthread_mutex_timedlock((M), (T)) +int xine_private_pthread_mutex_timedlock(pthread_mutex_t *mutex, const struct timespec *abs_timeout); +#endif +  /* handle non-standard function names */  #if !defined(HAVE_SNPRINTF) && defined(HAVE__SNPRINTF)  #  define HAVE_SNPRINTF diff --git a/lib/os_types.h b/lib/os_types.h deleted file mode 100644 index 75ce9b8a5..000000000 --- a/lib/os_types.h +++ /dev/null @@ -1,109 +0,0 @@ -/* - * Copyright (C) 2004-2006 the xine project - * - * This file is part of xine, a free video player. - * - * xine is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * xine 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 General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA - * - * Platform dependent types needed by public xine.h.  - * Types not needed by xine.h are specified in os_internal.h. - * - * Heavily based on os_types.h from OggVorbis (BSD License), - * not tested on all platforms with xine. - */ - -#ifndef XINE_OS_TYPES_H -#define XINE_OS_TYPES_H - -#if defined(_WIN32) && !defined(__GNUC__) - -   /* MSVC/Borland */ -   typedef __int8 int8_t; -   typedef unsigned __int8 uint8_t; -   typedef __int16 int16_t; -   typedef unsigned __int16 uint16_t; -   typedef __int32 int32_t; -   typedef unsigned __int32 uint32_t; -   typedef __int64 int64_t; -   typedef unsigned __int64 uint64_t; - -#elif defined(__MACOS__) - -#  include <sys/types.h> -   typedef SInt8 int8_t; -   typedef UInt8 uint8_t; -   typedef SInt16 int16_t; -   typedef UInt16 uint16_t; -   typedef SInt32 int32_t; -   typedef UInt32 uint32_t; -   typedef SInt64 int64_t; -   typedef UInt64 uint64_t; - -#elif defined(__MACOSX__) /* MacOS X Framework build */ - -#  include <sys/types.h> -   typedef u_int8_t uint8_t; -   typedef u_int16_t uint16_t; -   typedef u_int32_t uint32_t; -   typedef u_int64_t uint64_t; - -#elif defined (__EMX__) - -   /* OS/2 GCC */ -   typedef signed char int8_t; -   typedef unsigned char uint8_t; -   typedef short int16_t; -   typedef unsigned short uint16_t; -   typedef int int32_t; -   typedef unsigned int uint32_t; -   typedef long long int64_t; -   typedef unsigned long long int64_t; - -#elif defined (DJGPP) - -   /* DJGPP */ -   typedef signed char int8_t; -   typedef unsigned char uint8_t; -   typedef short int16_t; -   typedef unsigned short uint16_t; -   typedef int int32_t; -   typedef unsigned int uint32_t; -   typedef long long int64_t; -   typedef unsigned long long uint64_t; - -#elif defined(R5900) - -   /* PS2 EE */ -   typedef signed char int8_t; -   typedef unsigned char uint8_t; -   typedef short int16_t; -   typedef unsigned short int16_t; -   typedef int int32_t; -   typedef unsigned uint32_t; -   typedef long int64_t; -   typedef unsigned long int64_t; - -#else - -  /*  -   * CygWin: _WIN32 & __GNUC__ -   * BeOS:   __BEOS__ -   * Linux, Solaris, Mac and others -   */ -#  include <inttypes.h> - -#endif - -#endif  /* XINE_OS_TYPES_H */ diff --git a/lib/timedlock.c b/lib/timedlock.c new file mode 100644 index 000000000..997ef6235 --- /dev/null +++ b/lib/timedlock.c @@ -0,0 +1,33 @@ +#include "config.h" + +#include <errno.h> + +#define _x_min(a, b) ((a) < (b) ? (a) : (b)) + +int xine_private_pthread_mutex_timedlock(pthread_mutex_t *mutex, +                                         const struct timespec *abs_timeout) +{ +    int             pthread_rc; +    struct timespec remaining, slept, ts; + +    remaining = *abs_timeout; +    while ((pthread_rc = pthread_mutex_trylock(mutex)) == EBUSY) { +        ts.tv_sec  = 0; +        ts.tv_nsec = (remaining.tv_sec > 0 ? 10000000 +                                           : _x_min(remaining.tv_nsec, 10000000)); +        nanosleep(&ts, &slept); +        ts.tv_nsec -= slept.tv_nsec; +        if (ts.tv_nsec <= remaining.tv_nsec) { +            remaining.tv_nsec -= ts.tv_nsec; +        } +        else { +            remaining.tv_sec--; +            remaining.tv_nsec = (1000000 - (ts.tv_nsec - remaining.tv_nsec)); +        } +        if (remaining.tv_sec < 0 || (!remaining.tv_sec && remaining.tv_nsec <= 0)) { +            return ETIMEDOUT; +        } +    } + +    return pthread_rc; +} | 
