diff options
author | Eric Wong <normalperson@yhbt.net> | 2008-06-01 22:24:55 +0000 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2008-06-01 22:24:55 +0000 |
commit | 8a4dff14ad7560aae83e9155d0c62ba7f8c101fd (patch) | |
tree | f9803ea83fa7cb6020e84b78f3fc45b4086e4a13 /bs/cross-arch.sh | |
parent | 97698bd4aaf168620205fea26f089e7b1acc869d (diff) | |
download | mpd-8a4dff14ad7560aae83e9155d0c62ba7f8c101fd.tar.gz mpd-8a4dff14ad7560aae83e9155d0c62ba7f8c101fd.tar.xz mpd-8a4dff14ad7560aae83e9155d0c62ba7f8c101fd.zip |
Add the bs build system from mpd-ke
Dealing with autotools is too painful when having
to deal with multiple build environments and
configurations.
git-svn-id: https://svn.musicpd.org/mpd/trunk@7368 09075e82-0dd4-0310-85a5-a0d7c8717e4f
Diffstat (limited to 'bs/cross-arch.sh')
-rwxr-xr-x | bs/cross-arch.sh | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/bs/cross-arch.sh b/bs/cross-arch.sh new file mode 100755 index 000000000..c520433a5 --- /dev/null +++ b/bs/cross-arch.sh @@ -0,0 +1,82 @@ +#!/bin/sh +# many parts of this blatantly ripped from GNU Autoconf macros +# Use this for cross-compiling, as we can't run cross-compiled binaries +# on our host. +if test -z "$O" || ! cd "$O"; then + echo '$O= not defined or not a directory' >&2 + exit 1 +fi + +echo '/* architecture-specific settings (auto-detected): */' +# check sizes of various types we care for +# this is slightly slower but much easier to read and follow than the +# bisecting autoconf version +for t in short int long 'long long'; do + > out + for s in 2 4 6 8 12 1 16 24 32 0; do + cat > t.c <<EOF +int main(void) +{ + static int x[(long int)(sizeof($t)) == $s ? 1 : -1]; + x[0] = 0; + return 0; +} +EOF + echo "trying sizeof($t) == $s" >> out + $CC -o t.o $CFLAGS $CPPFLAGS t.c \ + >> out 2>&1 && break + done + if test $s -eq 0; then + echo "Unable to calculate sizeof($t) for cross-compiling" >&2 + cat out >&2 + exit 1 + fi + t=`echo $t | tr a-z A-Z | tr ' ' _` + echo "#define SIZEOF_$t $s" + echo "SIZEOF_$t := $s" >> config_detected.mk +done + +# check endian-ness +cat > t.c <<EOF +short ascii_mm[] = { 0x4249, 0x4765, 0x6E44, 0x6961, 0x6E53, 0x7953, 0 }; +short ascii_ii[] = { 0x694C, 0x5454, 0x656C, 0x6E45, 0x6944, 0x6E61, 0 }; +void _ascii(void) +{ + char *s = (char *)ascii_mm; + s = (char *)ascii_ii; +} + +short ebcdic_ii[] = { 0x89D3, 0xE3E3, 0x8593, 0x95C5, 0x89C4, 0x9581, 0 }; +short ebcdic_mm[] = { 0xC2C9, 0xC785, 0x95C4, 0x8981, 0x95E2, 0xA8E2, 0 }; +void _ebcdic(void) +{ + char *s = (char *)ebcdic_mm; + s = (char *)ebcdic_ii; +} + +int main(void) +{ + _ascii(); + _ebcdic(); + + return 0; +} +EOF + +echo "compiling endian test" > out +$CC -o t.o $CFLAGS $CPPFLAGS t.c >> out 2>&1 +if grep BIGenDianSyS t.o >/dev/null 2>&1; then + echo "#define WORDS_BIGENDIAN 1" + echo "WORDS_BIGENDIAN := 1" >> config_detected.mk +elif grep LiTTleEnDian t.o >/dev/null 2>&1; then + echo "/* #undef WORDS_BIGENDIAN */" + echo "# WORDS_BIGENDIAN :=" >> config_detected.mk +else + echo "Unable to determine endian-ness for cross compiling" >&2 + cat out >&2 + exit 1 +fi + +echo '' + +exec rm -f t.o out t.c |