annotate src/libsndfile-1.0.25/M4/endian.m4 @ 169:223a55898ab9 tip default

Add null config files
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 02 Mar 2020 14:03:47 +0000
parents 545efbb81310
children
rev   line source
cannam@85 1 dnl @synopsis MN_C_FIND_ENDIAN
cannam@85 2 dnl
cannam@85 3 dnl Determine endian-ness of target processor.
cannam@85 4 dnl @version 1.1 Mar 03 2002
cannam@85 5 dnl @author Erik de Castro Lopo <erikd AT mega-nerd DOT com>
cannam@85 6 dnl
cannam@85 7 dnl Majority written from scratch to replace the standard autoconf macro
cannam@85 8 dnl AC_C_BIGENDIAN. Only part remaining from the original it the invocation
cannam@85 9 dnl of the AC_TRY_RUN macro.
cannam@85 10 dnl
cannam@85 11 dnl Permission to use, copy, modify, distribute, and sell this file for any
cannam@85 12 dnl purpose is hereby granted without fee, provided that the above copyright
cannam@85 13 dnl and this permission notice appear in all copies. No representations are
cannam@85 14 dnl made about the suitability of this software for any purpose. It is
cannam@85 15 dnl provided "as is" without express or implied warranty.
cannam@85 16
cannam@85 17 dnl Find endian-ness in the following way:
cannam@85 18 dnl 1) Look in <endian.h>.
cannam@85 19 dnl 2) If 1) fails, look in <sys/types.h> and <sys/param.h>.
cannam@85 20 dnl 3) If 1) and 2) fails and not cross compiling run a test program.
cannam@85 21 dnl 4) If 1) and 2) fails and cross compiling then guess based on target.
cannam@85 22
cannam@85 23 AC_DEFUN([MN_C_FIND_ENDIAN],
cannam@85 24 [AC_CACHE_CHECK(processor byte ordering,
cannam@85 25 ac_cv_c_byte_order,
cannam@85 26
cannam@85 27 # Initialize to unknown
cannam@85 28 ac_cv_c_byte_order=unknown
cannam@85 29
cannam@85 30 if test x$ac_cv_header_endian_h = xyes ; then
cannam@85 31
cannam@85 32 # First try <endian.h> which should set BYTE_ORDER.
cannam@85 33
cannam@85 34 [AC_TRY_LINK([
cannam@85 35 #include <endian.h>
cannam@85 36 #if BYTE_ORDER != LITTLE_ENDIAN
cannam@85 37 not big endian
cannam@85 38 #endif
cannam@85 39 ], return 0 ;,
cannam@85 40 ac_cv_c_byte_order=little
cannam@85 41 )]
cannam@85 42
cannam@85 43 [AC_TRY_LINK([
cannam@85 44 #include <endian.h>
cannam@85 45 #if BYTE_ORDER != BIG_ENDIAN
cannam@85 46 not big endian
cannam@85 47 #endif
cannam@85 48 ], return 0 ;,
cannam@85 49 ac_cv_c_byte_order=big
cannam@85 50 )]
cannam@85 51
cannam@85 52 fi
cannam@85 53
cannam@85 54 if test $ac_cv_c_byte_order = unknown ; then
cannam@85 55
cannam@85 56 [AC_TRY_LINK([
cannam@85 57 #include <sys/types.h>
cannam@85 58 #include <sys/param.h>
cannam@85 59 #if !BYTE_ORDER || !BIG_ENDIAN || !LITTLE_ENDIAN
cannam@85 60 bogus endian macros
cannam@85 61 #endif
cannam@85 62 ], return 0 ;,
cannam@85 63
cannam@85 64 [AC_TRY_LINK([
cannam@85 65 #include <sys/types.h>
cannam@85 66 #include <sys/param.h>
cannam@85 67 #if BYTE_ORDER != LITTLE_ENDIAN
cannam@85 68 not big endian
cannam@85 69 #endif
cannam@85 70 ], return 0 ;,
cannam@85 71 ac_cv_c_byte_order=little
cannam@85 72 )]
cannam@85 73
cannam@85 74 [AC_TRY_LINK([
cannam@85 75 #include <sys/types.h>
cannam@85 76 #include <sys/param.h>
cannam@85 77 #if BYTE_ORDER != LITTLE_ENDIAN
cannam@85 78 not big endian
cannam@85 79 #endif
cannam@85 80 ], return 0 ;,
cannam@85 81 ac_cv_c_byte_order=little
cannam@85 82 )]
cannam@85 83
cannam@85 84 )]
cannam@85 85
cannam@85 86 fi
cannam@85 87
cannam@85 88 if test $ac_cv_c_byte_order = unknown ; then
cannam@85 89 if test $cross_compiling = yes ; then
cannam@85 90 # This is the last resort. Try to guess the target processor endian-ness
cannam@85 91 # by looking at the target CPU type.
cannam@85 92 [
cannam@85 93 case "$target_cpu" in
cannam@85 94 alpha* | i?86* | mipsel* | ia64*)
cannam@85 95 ac_cv_c_byte_order=little
cannam@85 96 ;;
cannam@85 97
cannam@85 98 m68* | mips* | powerpc* | hppa* | sparc*)
cannam@85 99 ac_cv_c_byte_order=big
cannam@85 100 ;;
cannam@85 101
cannam@85 102 esac
cannam@85 103 ]
cannam@85 104 else
cannam@85 105 AC_TRY_RUN(
cannam@85 106 [[
cannam@85 107 int main (void)
cannam@85 108 { /* Are we little or big endian? From Harbison&Steele. */
cannam@85 109 union
cannam@85 110 { long l ;
cannam@85 111 char c [sizeof (long)] ;
cannam@85 112 } u ;
cannam@85 113 u.l = 1 ;
cannam@85 114 return (u.c [sizeof (long) - 1] == 1);
cannam@85 115 }
cannam@85 116 ]], , ac_cv_c_byte_order=big,
cannam@85 117 )
cannam@85 118
cannam@85 119 AC_TRY_RUN(
cannam@85 120 [[int main (void)
cannam@85 121 { /* Are we little or big endian? From Harbison&Steele. */
cannam@85 122 union
cannam@85 123 { long l ;
cannam@85 124 char c [sizeof (long)] ;
cannam@85 125 } u ;
cannam@85 126 u.l = 1 ;
cannam@85 127 return (u.c [0] == 1);
cannam@85 128 }]], , ac_cv_c_byte_order=little,
cannam@85 129 )
cannam@85 130 fi
cannam@85 131 fi
cannam@85 132
cannam@85 133 )
cannam@85 134
cannam@85 135 if test $ac_cv_c_byte_order = big ; then
cannam@85 136 ac_cv_c_big_endian=1
cannam@85 137 ac_cv_c_little_endian=0
cannam@85 138 elif test $ac_cv_c_byte_order = little ; then
cannam@85 139 ac_cv_c_big_endian=0
cannam@85 140 ac_cv_c_little_endian=1
cannam@85 141 else
cannam@85 142 ac_cv_c_big_endian=0
cannam@85 143 ac_cv_c_little_endian=0
cannam@85 144
cannam@85 145 AC_MSG_WARN([[*****************************************************************]])
cannam@85 146 AC_MSG_WARN([[*** Not able to determine endian-ness of target processor. ]])
cannam@85 147 AC_MSG_WARN([[*** The constants CPU_IS_BIG_ENDIAN and CPU_IS_LITTLE_ENDIAN in ]])
cannam@85 148 AC_MSG_WARN([[*** src/config.h may need to be hand editied. ]])
cannam@85 149 AC_MSG_WARN([[*****************************************************************]])
cannam@85 150 fi
cannam@85 151
cannam@85 152 ]
cannam@85 153 )# MN_C_FIND_ENDIAN
cannam@85 154
cannam@85 155