|
@@ -1,5 +1,8 @@
|
|
|
# -*- mode: makefile-gmake -*-
|
|
|
|
|
|
+# Default build rule for any Makefile in this project: all
|
|
|
+default: all
|
|
|
+
|
|
|
OS := $(shell uname)
|
|
|
# Do not forget to bump SOMINOR when changing VERSION,
|
|
|
# and SOMAJOR when breaking ABI in a backward-incompatible way
|
|
@@ -13,9 +16,9 @@ libdir = $(prefix)/lib
|
|
|
includedir = $(prefix)/include
|
|
|
|
|
|
ifeq ($(OS), FreeBSD)
|
|
|
- pkgconfigdir = $(prefix)/libdata/pkgconfig
|
|
|
+pkgconfigdir = $(prefix)/libdata/pkgconfig
|
|
|
else
|
|
|
- pkgconfigdir = $(libdir)/pkgconfig
|
|
|
+pkgconfigdir = $(libdir)/pkgconfig
|
|
|
endif
|
|
|
|
|
|
USEGCC = 1
|
|
@@ -45,36 +48,16 @@ CFLAGS_add += -fno-gnu89-inline -fno-builtin
|
|
|
endif
|
|
|
|
|
|
ARCH ?= $(shell $(CC) -dumpmachine | sed "s/\([^-]*\).*$$/\1/")
|
|
|
-ARCH_ORIGIN := $(origin ARCH)
|
|
|
|
|
|
ifeq ($(ARCH),mingw32)
|
|
|
$(error "the mingw32 compiler you are using fails the openblas testsuite. please see the Julia README.windows.md document for a replacement")
|
|
|
endif
|
|
|
|
|
|
-CFLAGS_add += -std=c99 -Wall -I$(OPENLIBM_HOME) -I$(OPENLIBM_HOME)/include -I$(OPENLIBM_HOME)/ld80 -I$(OPENLIBM_HOME)/$(ARCH) -I$(OPENLIBM_HOME)/src -DASSEMBLER -D__BSD_VISIBLE -Wno-implicit-function-declaration
|
|
|
-
|
|
|
-default: all
|
|
|
-
|
|
|
-# *int / *intf need to be built with -O0
|
|
|
-src/%int.c.o: src/%int.c
|
|
|
- $(CC) $(CPPFLAGS) -O0 $(CFLAGS_add) -c $< -o $@
|
|
|
-
|
|
|
-src/%intf.c.o: src/%intf.c
|
|
|
- $(CC) $(CPPFLAGS) -O0 $(CFLAGS_add) -c $< -o $@
|
|
|
-
|
|
|
-%.c.o: %.c
|
|
|
- $(CC) $(CPPFLAGS) $(CFLAGS) $(CFLAGS_add) -c $< -o $@
|
|
|
-
|
|
|
-%.S.o: %.S
|
|
|
- $(CC) $(CPPFLAGS) $(SFLAGS) $(SFLAGS_add) $(filter -m% -B% -I% -D%,$(CFLAGS_add)) -c $< -o $@
|
|
|
-
|
|
|
# OS-specific stuff
|
|
|
-REAL_ARCH := $(ARCH)
|
|
|
ifeq ($(findstring arm,$(ARCH)),arm)
|
|
|
override ARCH := arm
|
|
|
-endif
|
|
|
-ifeq ($(ARCH),aarch64)
|
|
|
-override ARCH := arm
|
|
|
+MARCH ?= armv7-a
|
|
|
+CFLAGS_add += -mhard-float
|
|
|
endif
|
|
|
ifeq ($(findstring powerpc,$(ARCH)),powerpc)
|
|
|
override ARCH := powerpc
|
|
@@ -82,19 +65,10 @@ endif
|
|
|
ifeq ($(findstring ppc,$(ARCH)),ppc)
|
|
|
override ARCH := powerpc
|
|
|
endif
|
|
|
-ifeq ($(ARCH),i386)
|
|
|
+ifneq ($(filter $(ARCH),i386 i486 i586 i686 i387 i487 i587 i687),)
|
|
|
override ARCH := i387
|
|
|
+MARCH ?= i686
|
|
|
endif
|
|
|
-ifeq ($(ARCH),i486)
|
|
|
-override ARCH := i387
|
|
|
-endif
|
|
|
-ifeq ($(ARCH),i586)
|
|
|
-override ARCH := i387
|
|
|
-endif
|
|
|
-ifeq ($(ARCH),i686)
|
|
|
-override ARCH := i387
|
|
|
-endif
|
|
|
-
|
|
|
ifeq ($(ARCH),x86_64)
|
|
|
override ARCH := amd64
|
|
|
endif
|
|
@@ -109,51 +83,68 @@ override OS=WINNT
|
|
|
endif
|
|
|
|
|
|
#keep these if statements separate
|
|
|
-
|
|
|
ifeq ($(OS), WINNT)
|
|
|
- SHLIB_EXT = dll
|
|
|
- SONAME_FLAG = -soname
|
|
|
- CFLAGS_add += -nodefaultlibs
|
|
|
- shlibdir = $(bindir)
|
|
|
+SHLIB_EXT = dll
|
|
|
+SONAME_FLAG = -soname
|
|
|
+CFLAGS_add += -nodefaultlibs
|
|
|
+shlibdir = $(bindir)
|
|
|
else
|
|
|
- ifeq ($(OS), Darwin)
|
|
|
- SHLIB_EXT = dylib
|
|
|
- SONAME_FLAG = -install_name
|
|
|
- else
|
|
|
- SHLIB_EXT = so
|
|
|
- SONAME_FLAG = -soname
|
|
|
- endif
|
|
|
- CFLAGS_add += -fPIC
|
|
|
- shlibdir = $(libdir)
|
|
|
-endif
|
|
|
-
|
|
|
-# The target specific FLAGS_add
|
|
|
-ifeq ($(ARCH_ORIGIN),file)
|
|
|
-CFLAGS_add_TARGET_$(ARCH) :=
|
|
|
-SFLAGS_add_TARGET_$(ARCH) :=
|
|
|
-LDFLAGS_add_TARGET_$(ARCH) :=
|
|
|
+ifeq ($(OS), Darwin)
|
|
|
+SHLIB_EXT = dylib
|
|
|
+SONAME_FLAG = -install_name
|
|
|
else
|
|
|
+SHLIB_EXT = so
|
|
|
+SONAME_FLAG = -soname
|
|
|
+endif
|
|
|
+CFLAGS_add += -fPIC
|
|
|
+shlibdir = $(libdir)
|
|
|
+endif
|
|
|
+
|
|
|
+# Add `-march` to our CFLAGS if it's defined
|
|
|
+ifneq ($(MARCH),)
|
|
|
+CFLAGS_arch += -march=$(MARCH)
|
|
|
+endif
|
|
|
+
|
|
|
ifeq ($(ARCH),i387)
|
|
|
-CFLAGS_add_TARGET_$(ARCH) := -m32 -march=$(REAL_ARCH)
|
|
|
-SFLAGS_add_TARGET_$(ARCH) := -m32 -march=$(REAL_ARCH)
|
|
|
-LDFLAGS_add_TARGET_$(ARCH) := -m32 -march=$(REAL_ARCH)
|
|
|
-endif
|
|
|
-CFLAGS_add_TARGET_x86_64 := -m64
|
|
|
-SFLAGS_add_TARGET_x86_64 := -m64
|
|
|
-LDFLAGS_add_TARGET_x86_64 := -m64
|
|
|
-# Arm
|
|
|
-ifeq ($(ARCH),arm)
|
|
|
-ifneq ($(REAL_ARCH),arm)
|
|
|
-CFLAGS_add_TARGET_$(ARCH) := -march=$(REAL_ARCH)
|
|
|
-SFLAGS_add_TARGET_$(ARCH) := -march=$(REAL_ARCH)
|
|
|
-LDFLAGS_add_TARGET_$(ARCH) := -march=$(REAL_ARCH)
|
|
|
-else
|
|
|
-$(error No known generic arm cflags. Please specify arch type)
|
|
|
+CFLAGS_arch += -m32
|
|
|
+SFLAGS_arch += -m32
|
|
|
+LDFLAGS_arch += -m32
|
|
|
endif
|
|
|
+
|
|
|
+ifeq ($(ARCH),amd64)
|
|
|
+CFLAGS_arch += -m64
|
|
|
+SFLAGS_arch += -m64
|
|
|
+LDFLAGS_arch += -m64
|
|
|
endif
|
|
|
+
|
|
|
+# Add our "arch"-related FLAGS in. We separate arch-related flags out so that
|
|
|
+# we can conveniently get at them for targets that don't want the rest of
|
|
|
+# *FLAGS_add, such as the testing Makefile targets
|
|
|
+CFLAGS_add += $(CFLAGS_arch)
|
|
|
+SFLAGS_add += $(SFLAGS_arch)
|
|
|
+LDFLAGS_add += $(LDFLAGS_arch)
|
|
|
+
|
|
|
+CFLAGS_add += -std=c99 -Wall -I$(OPENLIBM_HOME) -I$(OPENLIBM_HOME)/include -I$(OPENLIBM_HOME)/$(ARCH) -I$(OPENLIBM_HOME)/src -DASSEMBLER -D__BSD_VISIBLE -Wno-implicit-function-declaration
|
|
|
+ifneq ($(filter $(ARCH),i387 amd64 aarch64 powerpc),)
|
|
|
+CFLAGS_add += -I$(OPENLIBM_HOME)/ld80
|
|
|
endif
|
|
|
|
|
|
-# Actually finish setting the FLAGS_add
|
|
|
-CFLAGS_add += $(CFLAGS_add_TARGET_$(ARCH))
|
|
|
-LDFLAGS_add += $(LDFLAGS_add_TARGET_$(ARCH))
|
|
|
-SFLAGS_add += $(SFLAGS_add_TARGET_$(ARCH))
|
|
|
+
|
|
|
+# *int / *intf need to be built with -O0
|
|
|
+src/%int.c.o: src/%int.c
|
|
|
+ $(CC) $(CPPFLAGS) -O0 $(CFLAGS_add) -c $< -o $@
|
|
|
+
|
|
|
+src/%intf.c.o: src/%intf.c
|
|
|
+ $(CC) $(CPPFLAGS) -O0 $(CFLAGS_add) -c $< -o $@
|
|
|
+
|
|
|
+%.c.o: %.c
|
|
|
+ $(CC) $(CPPFLAGS) $(CFLAGS) $(CFLAGS_add) -c $< -o $@
|
|
|
+
|
|
|
+%.S.o: %.S
|
|
|
+ $(CC) $(CPPFLAGS) $(SFLAGS) $(SFLAGS_add) $(filter -m% -B% -I% -D%,$(CFLAGS_add)) -c $< -o $@
|
|
|
+
|
|
|
+
|
|
|
+# Makefile debugging trick:
|
|
|
+# call print-VARIABLE to see the runtime value of any variable
|
|
|
+print-%:
|
|
|
+ @echo '$*=$($*)'
|