Making CELT_GET_MODE "private"
[opus.git] / libcelt / float_cast.h
index 9e74c69..72c1714 100644 (file)
@@ -1,11 +1,27 @@
+/* Copyright (C) 2001 Erik de Castro Lopo <erikd AT mega-nerd DOT com> */
 /*
-** Copyright (C) 2001 Erik de Castro Lopo <erikd AT mega-nerd DOT com>
-**
-** Permission to use, copy, modify, distribute, and sell this file for any 
-** purpose is hereby granted without fee, provided that the above copyright 
-** and this permission notice appear in all copies.  No representations are
-** made about the suitability of this software for any purpose.  It is 
-** provided "as is" without express or implied warranty.
+   Redistribution and use in source and binary forms, with or without
+   modification, are permitted provided that the following conditions
+   are met:
+
+   - Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+
+   - 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.
+
+   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 FOUNDATION 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.
 */
 
 /* Version 1.1 */
 #include       <math.h>
 #define float2int(x) lrint(x)
 
+#elif (defined (WIN64) || defined (_WIN64))
+       #include <xmmintrin.h>
+
+       __inline long int float2int(float value)
+       {
+               return _mm_cvtss_si32(_mm_load_ss(&value));
+       }
 #elif (defined (WIN32) || defined (_WIN32))
 
        #include        <math.h>
 
 #else
 
+#ifdef __GNUC__ /* supported by gcc, but not by all other compilers*/
        #warning "Don't have the functions lrint() and lrintf ()."
        #warning "Replacing these functions with a standard C cast."
+#endif /* __GNUC__ */
 
        #include        <math.h>