X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=contrib%2Fsrc%2Fmain.mak;h=dd2bd2536d0dc0c6cc436eebd47acba6fffa77e0;hb=681a61ddf3a129e2fc3142de779969d806e2efda;hp=5250c7f14c325e05d63dc290adc483e9785c5567;hpb=7f43c5cb6001d6f9e8a7fd76b0baed71f7b1888c;p=vlc diff --git a/contrib/src/main.mak b/contrib/src/main.mak index 5250c7f14c..dd2bd2536d 100644 --- a/contrib/src/main.mak +++ b/contrib/src/main.mak @@ -24,7 +24,7 @@ VPATH := $(TARBALLS) GNU := http://ftp.gnu.org/gnu SF := http://heanet.dl.sourceforge.net/sourceforge VIDEOLAN := http://downloads.videolan.org/pub/videolan -CONTRIB_VIDEOLAN := $(VIDEOLAN)/testing/contrib +CONTRIB_VIDEOLAN := http://downloads.videolan.org/pub/contrib # # Machine-dependent variables @@ -36,16 +36,7 @@ ifneq ($(HOST),$(BUILD)) HAVE_CROSS_COMPILE = 1 endif ARCH := $(shell $(SRC)/get-arch.sh $(HOST)) -ifneq ($(findstring $(ARCH),i386 sparc sparc64 ppc ppc64 x86_64),) -# This should be consistent with include/vlc_cpu.h -HAVE_FPU = 1 -else ifneq ($(findstring $(ARCH),arm),) -ifneq ($(call cppcheck, __VFP_FP__)),) -ifeq ($(call cppcheck, __SOFTFP__),) -HAVE_FPU = 1 -endif -endif -endif + ifeq ($(ARCH)-$(HAVE_WIN32),x86_64-1) HAVE_WIN64 := 1 endif @@ -100,48 +91,27 @@ endif endif ifdef HAVE_ANDROID -CC := $(HOST)-gcc --sysroot=$(ANDROID_NDK)/platforms/android-9/arch-arm -CXX := $(HOST)-g++ --sysroot=$(ANDROID_NDK)/platforms/android-9/arch-arm -ifdef HAVE_NEON - ANDROID_ABI = armeabi-v7a - ANDROID_CPU_FLAGS = -mfpu=neon -mcpu=cortex-a8 -else -ifdef HAVE_TEGRA2 - ANDROID_ABI = armeabi-v7a - ANDROID_CPU_FLAGS = -mfpu=vfpv3-d16 -mcpu=cortex-a9 -else - ANDROID_ABI = armeabi - ANDROID_CPU_FLAGS = -mcpu=arm1136jf-s -mfpu=vfp -endif -endif -EXTRA_CFLAGS += -I$(ANDROID_NDK)/sources/cxx-stl/gnu-libstdc++/include -EXTRA_CFLAGS += -I$(ANDROID_NDK)/sources/cxx-stl/gnu-libstdc++/libs/$(ANDROID_ABI)/include -EXTRA_CFLAGS += -mfloat-abi=softfp $(ANDROID_CPU_FLAGS) +CC := $(HOST)-gcc --sysroot=$(ANDROID_NDK)/platforms/android-9/arch-$(PLATFORM_SHORT_ARCH) +CXX := $(HOST)-g++ --sysroot=$(ANDROID_NDK)/platforms/android-9/arch-$(PLATFORM_SHORT_ARCH) endif ifdef HAVE_MACOSX -MIN_OSX_VERSION=10.5 -MACOSX_SDK=/Developer/SDKs/MacOSX$(OSX_VERSION).sdk -CC=gcc-4.2 -CXX=g++-4.2 -AR=ar -LD=ld -STRIP=strip -RANLIB=ranlib +MIN_OSX_VERSION=10.6 +CC=xcrun cc +CXX=xcrun c++ +AR=xcrun ar +LD=xcrun ld +STRIP=xcrun strip +RANLIB=xcrun ranlib EXTRA_CFLAGS += -isysroot $(MACOSX_SDK) -mmacosx-version-min=$(MIN_OSX_VERSION) -DMACOSX_DEPLOYMENT_TARGET=$(MIN_OSX_VERSION) EXTRA_LDFLAGS += -Wl,-syslibroot,$(MACOSX_SDK) -mmacosx-version-min=$(MIN_OSX_VERSION) -isysroot $(MACOSX_SDK) -DMACOSX_DEPLOYMENT_TARGET=$(MIN_OSX_VERSION) ifeq ($(ARCH),x86_64) EXTRA_CFLAGS += -m64 EXTRA_LDFLAGS += -m64 else -ifeq ($(ARCH), ppc) -EXTRA_CFLAGS += -arch ppc -EXTRA_LDFLAGS += -arch ppc -else EXTRA_CFLAGS += -m32 EXTRA_LDFLAGS += -m32 endif -endif XCODE_FLAGS = -sdk macosx$(OSX_VERSION) ifeq ($(shell xcodebuild -version 2>/dev/null | tee /dev/null|head -1|cut -d\ -f2|cut -d. -f1),3) @@ -153,27 +123,23 @@ endif endif +CCAS=$(CC) -c + ifdef HAVE_IOS CC=xcrun clang CXX=xcrun clang++ -ifeq ($(ARCH), arm) +ifdef HAVE_NEON AS=perl $(abspath ../../extras/tools/build/bin/gas-preprocessor.pl) $(CC) +CCAS=gas-preprocessor.pl $(CC) -c else -AS=xcrun as +CCAS=$(CC) -c endif AR=xcrun ar LD=xcrun ld STRIP=xcrun strip RANLIB=xcrun ranlib -ifeq ($(ARCH), arm) -EXTRA_CFLAGS += -arch armv7 -mno-thumb -mcpu=cortex-a8 -EXTRA_LDFLAGS += -arch armv7 -else -EXTRA_CFLAGS += -m32 -EXTRA_LDFLAGS += -m32 -endif -EXTRA_CFLAGS += -isysroot $(SDKROOT) -miphoneos-version-min=5.0 -EXTRA_LDFLAGS += -Wl,-syslibroot,$(SDKROOT) -isysroot $(SDKROOT) -miphoneos-version-min=5.0 +EXTRA_CFLAGS += $(CFLAGS) +EXTRA_LDFLAGS += $(LDFLAGS) endif ifdef HAVE_WIN32 @@ -182,16 +148,40 @@ HAVE_MINGW_W64 := 1 endif endif +ifdef HAVE_SOLARIS +ifeq ($(ARCH),x86_64) +EXTRA_CFLAGS += -m64 +EXTRA_LDFLAGS += -m64 +else +EXTRA_CFLAGS += -m32 +EXTRA_LDFLAGS += -m32 +endif +endif + cppcheck = $(shell $(CC) $(CFLAGS) -E -dM - < /dev/null | grep -E $(1)) EXTRA_CFLAGS += -I$(PREFIX)/include CPPFLAGS := $(CPPFLAGS) $(EXTRA_CFLAGS) -CFLAGS := $(CFLAGS) $(EXTRA_CFLAGS) -CXXFLAGS := $(CXXFLAGS) $(EXTRA_CFLAGS) +CFLAGS := $(CFLAGS) $(EXTRA_CFLAGS) -g +CXXFLAGS := $(CXXFLAGS) $(EXTRA_CFLAGS) -g EXTRA_LDFLAGS += -L$(PREFIX)/lib LDFLAGS := $(LDFLAGS) $(EXTRA_LDFLAGS) # Do not export those! Use HOSTVARS. +# Do the FPU detection, after we have figured out our compilers and flags. +ifneq ($(findstring $(ARCH),aarch64 i386 ppc ppc64 sparc sparc64 x86_64),) +# This should be consistent with include/vlc_cpu.h +HAVE_FPU = 1 +else ifneq ($(findstring $(ARCH),arm),) +ifneq ($(call cppcheck, __VFP_FP__)),) +ifeq ($(call cppcheck, __SOFTFP__),) +HAVE_FPU = 1 +endif +endif +else ifneq ($(call cppcheck, __mips_hard_float),) +HAVE_FPU = 1 +endif + ACLOCAL_AMFLAGS += -I$(PREFIX)/share/aclocal export ACLOCAL_AMFLAGS @@ -236,6 +226,12 @@ else download = $(error Neither curl nor wget found!) endif +ifeq ($(shell which bzcat >/dev/null 2>&1 || echo FAIL),) +BZCAT = bzcat +else +BZCAT ?= $(error Bunzip2 client (bzcat) not found!) +endif + ifeq ($(shell gzcat --version >/dev/null 2>&1 || echo FAIL),) ZCAT = gzcat else ifeq ($(shell zcat --version >/dev/null 2>&1 || echo FAIL),) @@ -258,6 +254,9 @@ endif # Common helpers # HOSTCONF := --prefix="$(PREFIX)" +HOSTCONF += --datarootdir="$(PREFIX)/share" +HOSTCONF += --includedir="$(PREFIX)/include" +HOSTCONF += --libdir="$(PREFIX)/lib" HOSTCONF += --build="$(BUILD)" --host="$(HOST)" --target="$(HOST)" HOSTCONF += --program-prefix="" # libtool stuff: @@ -272,7 +271,7 @@ endif HOSTTOOLS := \ CC="$(CC)" CXX="$(CXX)" LD="$(LD)" \ - AR="$(AR)" RANLIB="$(RANLIB)" STRIP="$(STRIP)" \ + AR="$(AR)" CCAS="$(CCAS)" RANLIB="$(RANLIB)" STRIP="$(STRIP)" \ PATH="$(PREFIX)/bin:$(PATH)" HOSTVARS := $(HOSTTOOLS) \ CPPFLAGS="$(CPPFLAGS)" \ @@ -305,8 +304,8 @@ UNPACK = $(RM) -R $@ \ $(foreach f,$(filter %.tar.bz2,$^), && tar xvjf $(f)) \ $(foreach f,$(filter %.tar.xz,$^), && tar xvJf $(f)) \ $(foreach f,$(filter %.zip,$^), && unzip $(f)) -UNPACK_DIR = $(basename $(basename $(notdir $<))) -APPLY = (cd $(UNPACK_DIR) && patch -p1) < +UNPACK_DIR = $(patsubst %.tar,%,$(basename $(notdir $<))) +APPLY = (cd $(UNPACK_DIR) && patch -fp1) < pkg_static = (cd $(UNPACK_DIR) && ../../../contrib/src/pkg-static.sh $(1)) MOVE = mv $(UNPACK_DIR) $@ && touch $@ @@ -369,8 +368,9 @@ vlc-contrib-$(HOST)-latest.tar.bz2: $(call download,$(PREBUILT_URL)) prebuilt: vlc-contrib-$(HOST)-latest.tar.bz2 - $(UNPACK) && mv $(HOST) $(TOPDST) - cd $(TOPDST)/$(HOST) && ./change_prefix.sh + -$(UNPACK) + mv $(HOST) $(TOPDST) + cd $(TOPDST)/$(HOST) && $(SRC)/change_prefix.sh package: install rm -Rf tmp/ @@ -380,8 +380,7 @@ package: install cd tmp/$(notdir $(PREFIX)); \ cd share; rm -Rf man doc gtk-doc info lua projectM gettext; cd ..; \ rm -Rf man sbin etc lib/lua lib/sidplay - cp $(SRC)/change_prefix.sh tmp/$(notdir $(PREFIX))/ - cd tmp/$(notdir $(PREFIX)) && ./change_prefix.sh $(PREFIX) @@CONTRIB_PREFIX@@ + cd tmp/$(notdir $(PREFIX)) && $(abspath $(SRC))/change_prefix.sh $(PREFIX) @@CONTRIB_PREFIX@@ (cd tmp && tar c $(notdir $(PREFIX))/) | bzip2 -c > ../vlc-contrib-$(HOST)-$(DATE).tar.bz2 list: @@ -414,6 +413,21 @@ ifdef HAVE_DARWIN_OS echo "set(CMAKE_C_FLAGS $(CFLAGS))" >> $@ echo "set(CMAKE_CXX_FLAGS $(CFLAGS))" >> $@ echo "set(CMAKE_LD_FLAGS $(LDFLAGS))" >> $@ + echo "set(CMAKE_AR ar CACHE FILEPATH "Archiver")" >> $@ +ifdef HAVE_IOS + echo "set(CMAKE_OSX_SYSROOT $(IOS_SDK))" >> $@ +else + echo "set(CMAKE_OSX_SYSROOT $(MACOSX_SDK))" >> $@ +endif +endif +ifdef HAVE_CROSS_COMPILE + echo "set(_CMAKE_TOOLCHAIN_PREFIX $(HOST)-)" >> $@ +ifdef HAVE_ANDROID +# cmake will overwrite our --sysroot with a native (host) one on Darwin +# Set it to "" right away to short-circuit this behaviour + echo "set(CMAKE_CXX_SYSROOT_FLAG \"\")" >> $@ + echo "set(CMAKE_C_SYSROOT_FLAG \"\")" >> $@ +endif endif echo "set(CMAKE_C_COMPILER $(CC))" >> $@ echo "set(CMAKE_CXX_COMPILER $(CXX))" >> $@