Sophie

Sophie

distrib > Mageia > 7 > i586 > by-pkgid > 0350866ab9930ba571160e9fdd9152bd > files > 3

dSFMT-2.2.3-2.mga7.src.rpm

--- dSFMT-src-2.2.3/Makefile.orig	2013-12-19 05:37:46.000000000 +0100
+++ dSFMT-src-2.2.3/Makefile	2014-09-03 17:17:48.032841290 +0200
@@ -17,35 +17,56 @@
 # We could comple test-alti-Mxxx using gcc 3.3 of osx.
 # We could comple test-alti-Mxxx using gcc 4.0 of osx.
 
+V_MAJOR   = 2
+V_MINOR   = 2
+V_RELEASE = 3
+SONAME    = $(V_MAJOR).$(V_MINOR)
+VERSION   = $(V_MAJOR).$(V_MINOR).$(V_RELEASE)
+
+prefix     = /usr
+includedir = $(prefix)/include
+libdir     = $(prefix)/lib
+SSE2_libdir = $(libdir)/sse2
+DESTDIR    = .
+
+SFMT_MEXP  = 19937
 WARN = -Wmissing-prototypes -Wall #-Winline
 #WARN = -Wmissing-prototypes -Wall -W
 #WARN = /Wall
-OPTI = -O3 -finline-functions -fomit-frame-pointer -DNDEBUG \
--fno-strict-aliasing --param max-inline-insns-single=1800
-#--param inline-unit-growth=500 --param large-function-growth=900 #for gcc 4
-#OPTI = /Ot /Ob2 /Oy /Ox /Oi /GL /G6
-#STD =
-#STD = -std=c89 -pedantic
-#STD = -std=c99 -pedantic
-STD = -std=c99
-CC = gcc
-CCFLAGS = $(OPTI) $(WARN) $(STD)
-ALTIFLAGS = -mabi=altivec -maltivec -DHAVE_ALTIVEC
-OSXALTIFLAGS = -faltivec -maltivec -DHAVE_ALTIVEC
-SSE2FLAGS = -msse2 -DHAVE_SSE2
-#SSE2FLAGS = /arch:SSE2 /DHAVE_SSE2
-STD_TARGET = test-std-M19937
-ALL_STD_TARGET = test-std-M521 test-std-M1279 test-std-M2203 test-std-M4253 \
-test-std-M11213 test-std-M19937 test-std-M44497 test-std-M86243 \
-test-std-M132049 test-std-M216091
-ALTI_TARGET = $(STD_TARGET) test-alti-M19937
-ALL_ALTI_TARGET = test-alti-M521 test-alti-M1279 test-alti-M2203 \
-test-alti-M4253 test-alti-M11213 test-alti-M19937 test-alti-M44497 \
-test-alti-M86243 test-alti-M132049 test-alti-M216091
-SSE2_TARGET = $(STD_TARGET) test-sse2-M19937
-ALL_SSE2_TARGET = test-sse2-M521 test-sse2-M1279 test-sse2-M2203 \
-test-sse2-M4253 test-sse2-M11213 test-sse2-M19937 test-sse2-M44497 \
-test-sse2-M86243 test-sse2-M132049 test-sse2-M216091
+OPTI            = -O3 -finline-functions -fomit-frame-pointer -DNDEBUG \
+--param inline-unit-growth=500 --param large-function-growth=900 #for gcc 4
+#-fno-strict-aliasing --param max-inline-insns-single=1800
+#OPTI           = /Ot /Ob2 /Oy /Ox /Oi /GL /G6
+STD             = -std=c99
+CC              = gcc
+LINK            = gcc
+CCFLAGS         = -fPIC $(OPTI) $(WARN) $(STD)
+INCPATH         = -I$(includedir)
+LIBS            = -L$(libdir) -L. -lpthread
+LDFLAGS         = -Wl,--no-undefined -Wl,-z,noexecstack -shared
+ALTIFLAGS       = -mabi=altivec -maltivec -DHAVE_ALTIVEC
+OSXALTIFLAGS    = -faltivec -maltivec -DHAVE_ALTIVEC
+SSE2FLAGS       = -msse2 -DHAVE_SSE2
+#SSE2FLAGS      = /arch:SSE2 /DHAVE_SSE2
+STRIP           =
+COPY_FILE       = cp -f
+COPY_DIR        = $(COPY_FILE) -R
+INSTALL_FILE    = @install -m 644 -p
+INSTALL_DIR     = $(COPY_DIR)
+SYMLINK         = ln -f -s
+DEL_FILE        = rm -rf
+MOVE            = mv -f
+CHK_DIR_EXISTS  = test -d
+CHK_FILE_EXISTS  = test ! -f
+MKDIR           = mkdir -p
+
+TARGET  = dSFMT
+STD_TARGET = test-std
+ALTI_TARGET = $(STD_TARGET) test-alti
+SSE2_TARGET = $(STD_TARGET) test-sse2
+
+HEADERS = $(TARGET).h $(TARGET)-params.h $(TARGET)-common.h
+
 # ==========================================================
 # comment out or EDIT following lines to get max performance
 # ==========================================================
@@ -78,121 +99,88 @@
 # -----------------
 #CCFLAGS += -march=athlon64
 
-.PHONY: std-check sse2-check alti-check
-
-std: $(STD_TARGET)
-
-sse2: $(SSE2_TARGET)
-
-alti: $(ALTI_TARGET)
-
-osx-alti:
-	$(MAKE) "ALTIFLAGS=$(OSXALTIFLAGS)" alti
-
-std-check: $(ALL_STD_TARGET)
-	./check.sh test-std
-
-sse2-check: $(ALL_SSE2_TARGET)
-	./check.sh test-sse2
-
-alti-check: $(ALL_ALTI_TARGET)
-	./check.sh test-alti
-
-osx-alti-check:
-	make "ALTIFLAGS=$(OSXALTIFLAGS)" alti-check
-
-test-std-M521: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=521 -o $@ dSFMT.c test.c
-
-test-alti-M521: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=521 -o $@ dSFMT.c test.c
-
-test-sse2-M521: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=521 -o $@ dSFMT.c test.c
-
-test-std-M1279: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=1279 -o $@ dSFMT.c test.c
+DEFINES = -DDSFMT_MEXP=$(SFMT_MEXP)
 
-test-alti-M1279: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=1279 -o $@ dSFMT.c test.c
+SHARED_TARGET  = lib$(TARGET).so.$(VERSION)
+SHARED_TARGET0 = lib$(TARGET).so
+SHARED_TARGET1 = lib$(TARGET).so.$(V_MAJOR)
+SHARED_TARGET2 = lib$(TARGET).so.$(SONAME)
+SHARED_TARGETS = $(SHARED_TARGET) $(SHARED_TARGET0) $(SHARED_TARGET1) $(SHARED_TARGET2)
 
-test-sse2-M1279: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=1279 -o $@ dSFMT.c test.c
+SOURCE = $(TARGET).c $(HEADERS)
+OBJECT = $(TARGET).o
 
-test-std-M2203: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=2203 -o $@ dSFMT.c test.c
+.PHONY: sharedlib std-check sse2-check alti-check
 
-test-alti-M2203: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=2203 -o $@ dSFMT.c test.c
+test-std: test.c sharedlib dSFMT.h
+	$(CC) $(CCFLAGS) $(DEFINES) -o $@ lib$(TARGET).so test.c
 
-test-sse2-M2203: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=2203 -o $@ dSFMT.c test.c
+test-alti: test.c sharedlib dSFMT.h
+	$(CC) $(CCFLAGS) $(ALTIFLAGS) $(DEFINES) -o $@ lib$(TARGET).so test.c
 
-test-std-M4253: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=4253 -o $@ dSFMT.c test.c
+test-sse2: test.c sharedlib dSFMT.h
+	$(CC) $(CCFLAGS) $(SSE2FLAGS) $(DEFINES) -o $@ lib$(TARGET).so test.c
 
-test-alti-M4253: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=4253 -o $@ dSFMT.c test.c
+std-check: test-std
+	LD_LIBRARY_PATH=. ./test-std > test-std-M$(SFMT_MEXP).txt
+	diff -w test-std-M$(SFMT_MEXP).txt dSFMT.$(SFMT_MEXP).out.txt || exit 1
 
-test-sse2-M4253: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=4253 -o $@ dSFMT.c test.c
+alti-check: test-alti
+	LD_LIBRARY_PATH=. ./test-alti > test-alti-M$(SFMT_MEXP).txt
+	diff -w test-alti-M$(SFMT_MEXP).txt dSFMT.$(SFMT_MEXP).out.txt || exit 1
 
-test-std-M11213: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=11213 -o $@ dSFMT.c test.c
+sse2-check: test-sse2
+	LD_LIBRARY_PATH=. ./test-sse2 > test-sse2-M$(SFMT_MEXP).txt
+	diff -w test-sse2-M$(SFMT_MEXP).txt dSFMT.$(SFMT_MEXP).out.txt || exit 1
 
-test-alti-M11213: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=11213 -o $@ dSFMT.c test.c
+.SUFFIXES: .o .c
 
-test-sse2-M11213: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=11213 -o $@ dSFMT.c test.c
-
-test-std-M19937: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=19937 -o $@ dSFMT.c test.c
-
-test-alti-M19937: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=19937 -o $@ dSFMT.c test.c
-
-test-sse2-M19937: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=19937 -o $@ dSFMT.c test.c
-
-test-std-M44497: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=44497 -o $@ dSFMT.c test.c
-
-test-alti-M44497: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=44497 -o $@ dSFMT.c test.c
-
-test-sse2-M44497: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=44497 -o $@ dSFMT.c test.c
-
-test-std-M86243: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=86243 -o $@ dSFMT.c test.c
-
-test-alti-M86243: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=86243 -o $@ dSFMT.c test.c
-
-test-sse2-M86243: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=86243 -o $@ dSFMT.c test.c
-
-test-std-M132049: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=132049 -o $@ dSFMT.c test.c
-
-test-alti-M132049: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=132049 -o $@ dSFMT.c test.c
-
-test-sse2-M132049: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=132049 -o $@ dSFMT.c test.c
-
-test-std-M216091: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) -DDSFMT_MEXP=216091 -o $@ dSFMT.c test.c
+.c.o:
+	@echo $(CCFLAGS)
+	$(CC) $(CCFLAGS) $(DEFINES) -c $<
 
-test-alti-M216091: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(ALTIFLAGS) -DDSFMT_MEXP=216091 -o $@ dSFMT.c test.c
 
-test-sse2-M216091: test.c dSFMT.c dSFMT.h
-	$(CC) $(CCFLAGS) $(SSE2FLAGS) -DDSFMT_MEXP=216091 -o $@ dSFMT.c test.c
+sse2_shared: $(SOURCE)
+	$(CC) $(CCFLAGS) $(SSE2FLAGS) $(DEFINES) -c $<
 
-.c.o:
-	$(CC) $(CCFLAGS) -c $<
+sharedlib: $(OBJECT)
+	@echo $(LDFLAGS)
+	$(DEL_FILE) $(SHARED_TARGETS)
+	$(LINK) $(LDFLAGS) -Wl,-soname,$(SHARED_TARGET2) -o $(SHARED_TARGET) $<
+	$(SYMLINK) $(SHARED_TARGET) $(SHARED_TARGET0)
+	$(SYMLINK) $(SHARED_TARGET) $(SHARED_TARGET1)
+	$(SYMLINK) $(SHARED_TARGET) $(SHARED_TARGET2)
+
+install: install_headers
+
+install_shared: $(libdir)
+	@echo $(CCFLAGS)
+	@echo $(DESTDIR)
+	@echo $(libdir)
+	$(CHK_DIR_EXISTS) $(DESTDIR)$< || $(MKDIR) $(DESTDIR)$<
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET)
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET0) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET0)
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET1) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET1)
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET2) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET2)
+	$(MOVE) $(SHARED_TARGETS)  $(DESTDIR)$</
+
+install_sse2_shared: $(SSE2_libdir)
+	@echo $(DESTDIR)
+	@echo $(libdir)
+	$(CHK_DIR_EXISTS) $(DESTDIR)$< || $(MKDIR) $(DESTDIR)$<
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET)
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET0) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET0)
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET1) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET1)
+	$(CHK_FILE_EXISTS) $(DESTDIR)$</$(SHARED_TARGET2) || $(DEL_FILE) $(DESTDIR)$</$(SHARED_TARGET2)
+	$(MOVE) $(SHARED_TARGETS)  $(DESTDIR)$</
+
+install_headers: install_shared
+	@echo $(DESTDIR)
+	$(CHK_DIR_EXISTS) $(DESTDIR)$(includedir) || $(MKDIR) $(DESTDIR)$(includedir)
+	$(CHK_DIR_EXISTS) $(DESTDIR)$(libdir)/pkgconfig || $(MKDIR) $(DESTDIR)$(libdir)/pkgconfig
+	$(INSTALL_FILE) $(HEADERS) $(DESTDIR)$(includedir)
+	@sed -e 's|libdir=%{prefix}/lib64|libdir=$(libdir)|g' -i $(TARGET).pc
+	$(INSTALL_FILE) $(TARGET).pc $(DESTDIR)$(libdir)/pkgconfig
 
 clean:
-	rm -f *.o *~ test-*-M*
+	$(DEL_FILE) *.o *~ test-*-M*