3 /********************************************************************
5 * THIS FILE IS PART OF THE OggVorbis SOFTWARE CODEC SOURCE CODE. *
6 * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
7 * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
8 * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
10 * THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2002 *
11 * by the XIPHOPHORUS Company http://www.xiph.org/ *
13 ********************************************************************
15 function: #ifdef jail to whip a few platforms into the UNIX ideal.
16 last mod: $Id: os.h,v 1.33 2003/09/02 05:11:53 xiphmont Exp $
18 ********************************************************************/
21 #include <ogg/os_types.h>
25 #ifndef _V_IFDEFJAIL_H_
26 # define _V_IFDEFJAIL_H_
29 # define STIN static __inline__
31 # define STIN static __inline
37 # define rint(x) (floor((x)+0.5f))
41 # define M_PI (3.1415926536f)
46 # define rint(x) (floor((x)+0.5f))
47 # define NO_FLOAT_MATH_LIB
48 # define FAST_HYPOT(a, b) sqrt((a)*(a) + (b)*(b))
52 # define FAST_HYPOT hypot
66 # define min(x,y) ((x)>(y)?(y):(x))
70 # define max(x,y) ((x)<(y)?(y):(x))
73 #if defined(__i386__) && defined(__GNUC__) && !defined(__BEOS__)
74 # define VORBIS_FPU_CONTROL
75 /* both GCC and MSVC are kinda stupid about rounding/casting to int.
76 Because of encapsulation constraints (GCC can't see inside the asm
77 block and so we end up doing stupid things like a store/load that
78 is collectively a noop), we do it this way */
80 /* we must set up the fpu before this works!! */
82 typedef ogg_int16_t vorbis_fpu_control;
84 static inline void vorbis_fpu_setround(vorbis_fpu_control *fpu){
87 __asm__ __volatile__("fnstcw %0\n\t"
91 "fldcw %1\n\t":"=m"(ret):"m"(temp): "dx");
95 static inline void vorbis_fpu_restore(vorbis_fpu_control fpu){
96 __asm__ __volatile__("fldcw %0":: "m"(fpu));
99 /* assumes the FPU is in round mode! */
100 static inline int vorbis_ftoi(double f){ /* yes, double! Otherwise,
101 we get extra fst/fld to
102 truncate precision */
104 __asm__("fistl %0": "=m"(i) : "t"(f));
110 #if defined(_WIN32) && !defined(__GNUC__) && !defined(__BORLANDC__)
111 # define VORBIS_FPU_CONTROL
113 typedef ogg_int16_t vorbis_fpu_control;
115 static __inline int vorbis_ftoi(double f){
124 static __inline void vorbis_fpu_setround(vorbis_fpu_control *fpu){
127 static __inline void vorbis_fpu_restore(vorbis_fpu_control fpu){
133 #ifndef VORBIS_FPU_CONTROL
135 typedef int vorbis_fpu_control;
137 static int vorbis_ftoi(double f){
141 /* We don't have special code for this compiler/arch, so do it the slow way */
142 # define vorbis_fpu_setround(vorbis_fpu_control) {}
143 # define vorbis_fpu_restore(vorbis_fpu_control) {}