X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=Makefile;h=c89bb1737b62eb09cc83ba686fafced2775b7159;hb=cdf54d85054858d9e3fc4d7ee8ea5c6a418f1b43;hp=df58489d34ffc7a01bbf4c53e59973db2a88f2c5;hpb=7d130d8d2a5638ca91dc81ec085acef4d3c3ad08;p=fio.git diff --git a/Makefile b/Makefile index df58489d..c89bb173 100644 --- a/Makefile +++ b/Makefile @@ -2,9 +2,9 @@ CC = gcc DEBUGFLAGS = -D_FORTIFY_SOURCE=2 -DFIO_INC_DEBUG CPPFLAGS= -D_GNU_SOURCE -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 \ $(DEBUGFLAGS) -OPTFLAGS= -O2 -fno-omit-frame-pointer -g $(EXTFLAGS) +OPTFLAGS= -fno-omit-frame-pointer -g $(EXTFLAGS) CFLAGS = -std=gnu99 -Wwrite-strings -Wall $(OPTFLAGS) -LIBS = -lm +LIBS = -lm $(EXTLIBS) PROGS = fio SCRIPTS = fio_generate_plots UNAME := $(shell uname) @@ -13,43 +13,60 @@ SOURCE = gettime.c fio.c ioengines.c init.c stat.c log.c time.c filesetup.c \ eta.c verify.c memory.c io_u.c parse.c mutex.c options.c \ rbtree.c smalloc.c filehash.c profile.c debug.c lib/rand.c \ lib/num2str.c $(wildcard crc/*.c) engines/cpu.c \ - engines/mmap.c engines/sync.c engines/null.c engines/net.c + engines/mmap.c engines/sync.c engines/null.c engines/net.c \ + memalign.c server.c client.c iolog.c ifeq ($(UNAME), Linux) SOURCE += diskutil.c fifo.c blktrace.c helpers.c cgroup.c trim.c \ engines/libaio.c engines/posixaio.c engines/sg.c \ engines/splice.c engines/syslet-rw.c engines/guasi.c \ - engines/binject.c profiles/tiobench.c + engines/binject.c engines/rdma.c profiles/tiobench.c LIBS += -lpthread -ldl -lrt -laio CFLAGS += -rdynamic -else ifeq ($(UNAME), SunOS) - SOURCE += fifo.c lib/strsep.c helpers.c solaris.c engines/posixaio.c \ +endif +ifeq ($(UNAME), SunOS) + SOURCE += fifo.c lib/strsep.c helpers.c engines/posixaio.c \ engines/solarisaio.c LIBS += -lpthread -ldl -laio -lrt -lnsl -lsocket CPPFLAGS += -D__EXTENSIONS__ -else ifeq ($(UNAME), FreeBSD) +endif +ifeq ($(UNAME), FreeBSD) SOURCE += helpers.c engines/posixaio.c LIBS += -lpthread -lrt CFLAGS += -rdynamic -else ifeq ($(UNAME), NetBSD) +endif +ifeq ($(UNAME), NetBSD) SOURCE += helpers.c engines/posixaio.c LIBS += -lpthread -lrt CFLAGS += -rdynamic -else ifeq ($(UNAME), AIX) +endif +ifeq ($(UNAME), AIX) SOURCE += fifo.c helpers.c lib/getopt_long.c engines/posixaio.c LIBS += -lpthread -ldl -lrt - CFLAGS += -rdynamic CPPFLAGS += -D_LARGE_FILES -D__ppc__ -else ifeq ($(UNAME), Darwin) + LDFLAGS += -L/opt/freeware/lib -Wl,-blibpath:/opt/freeware/lib:/usr/lib:/lib -Wl,-bmaxdata:0x80000000 +endif +ifeq ($(UNAME), HP-UX) + SOURCE += fifo.c helpers.c lib/getopt_long.c lib/strsep.c engines/posixaio.c + LIBS += -lpthread -ldl -lrt + CFLAGS += -D_LARGEFILE64_SOURCE +endif +ifeq ($(UNAME), Darwin) SOURCE += helpers.c engines/posixaio.c LIBS += -lpthread -ldl -else ifneq (,$(findstring CYGWIN,$(UNAME))) +endif +ifneq (,$(findstring CYGWIN,$(UNAME))) SOURCE += engines/windowsaio.c - LIBS += -lpthread -lrt + LIBS += -lpthread -lrt -lpsapi + CFLAGS += -DPSAPI_VERSION=1 endif OBJS = $(SOURCE:.c=.o) +T_OBJS = t/stest.o +T_OBJS += mutex.o smalloc.o +T_PROGS = t/stest + ifneq ($(findstring $(MAKEFLAGS),s),s) ifndef V QUIET_CC = @echo ' ' CC $@; @@ -62,27 +79,30 @@ prefix = /usr/local bindir = $(prefix)/bin mandir = $(prefix)/man -.c.o: +all: .depend $(PROGS) $(SCRIPTS) + +.c.o: .depend $(QUIET_CC)$(CC) -o $@ -c $(CFLAGS) $(CPPFLAGS) $< - + +t/stest: $(T_OBJS) + $(QUIET_CC)$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $(T_OBJS) $(LIBS) $(LDFLAGS) + fio: $(OBJS) - $(QUIET_CC)$(CC) $(CFLAGS) -o $@ $(LIBS) $(OBJS) + $(QUIET_CC)$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $(OBJS) $(LIBS) $(LDFLAGS) -depend: +.depend: $(SOURCE) $(QUIET_DEP)$(CC) -MM $(CFLAGS) $(CPPFLAGS) $(SOURCE) 1> .depend -$(PROGS): depend - -all: depend $(PROGS) $(SCRIPTS) +$(PROGS): .depend clean: - -rm -f .depend $(OBJS) $(PROGS) core.* core + -rm -f .depend $(OBJS) $(T_OBJS) $(PROGS) $(T_PROGS) core.* core cscope: @cscope -b -R install: $(PROGS) $(SCRIPTS) - $(INSTALL) -m755 -d $(DESTDIR)$(bindir) + $(INSTALL) -m 755 -d $(DESTDIR)$(bindir) $(INSTALL) $(PROGS) $(SCRIPTS) $(DESTDIR)$(bindir) $(INSTALL) -m 755 -d $(DESTDIR)$(mandir)/man1 $(INSTALL) -m 644 fio.1 $(DESTDIR)$(mandir)/man1