2007-02-28 18:42:55 +00:00
|
|
|
|
|
|
|
# mpicxx must be on your path to build newsyn. on googoo, this means
|
|
|
|
# that /usr/local/mpich2-1.0.2/bin must be on your path.
|
|
|
|
|
|
|
|
# For now, use g++ most of the time.
|
|
|
|
# When compiling MPI stuff, specify myfile.cc instead of myfile.o so
|
|
|
|
# that ${MPICC} is invoked instead of the generic .o rule (or it'll
|
|
|
|
# use g++). This makes it less annoying to build on non-mpi hosts for
|
|
|
|
# dev work, and seems to behave just fine... change ${CC} back to
|
|
|
|
# mpicxx if you get paranoid.
|
|
|
|
|
|
|
|
#CC = g++
|
|
|
|
#CFLAGS = -g -Wall -I. -D_FILE_OFFSET_BITS=64 -DMPICH_IGNORE_CXX_SEEK -D_REENTRANT -D_THREAD_SAFE
|
|
|
|
#LIBS = -lpthread
|
|
|
|
|
|
|
|
# Hook for extra -I options, etc.
|
|
|
|
EXTRA_CFLAGS =
|
|
|
|
|
|
|
|
ifeq ($(target),darwin)
|
|
|
|
# For Darwin
|
|
|
|
CFLAGS = -g -Wall -I. -D_FILE_OFFSET_BITS=64 -DMPICH_IGNORE_CXX_SEEK -D_REENTRANT -D_THREAD_SAFE -DDARWIN -D__FreeBSD__=10 ${EXTRA_CFLAGS}
|
|
|
|
LDINC = ar -rc
|
|
|
|
else
|
|
|
|
# For linux
|
|
|
|
CFLAGS = -g -Wall -I. -D_FILE_OFFSET_BITS=64 -DMPICH_IGNORE_CXX_SEEK -D_REENTRANT -D_THREAD_SAFE
|
|
|
|
LDINC = ld -i -o
|
|
|
|
endif
|
|
|
|
|
|
|
|
CC = g++
|
|
|
|
LIBS = -lpthread
|
|
|
|
|
|
|
|
ifeq ($(want_bdb),yes)
|
|
|
|
CFLAGS += -DUSE_OSBDB
|
|
|
|
OSBDB_LIBS = -ldb_cxx
|
|
|
|
endif
|
|
|
|
|
|
|
|
#for normal mpich2 machines
|
|
|
|
MPICC = mpicxx
|
|
|
|
MPICFLAGS = ${CFLAGS}
|
|
|
|
MPILIBS = ${LIBS}
|
|
|
|
|
|
|
|
#for LLNL boxes without mpicxx
|
|
|
|
#MPICC = g++
|
|
|
|
#MPICFLAGS = ${CFLAGS} -I/usr/lib/mpi/include -L/usr/lib/mpi/mpi_gnu/lib
|
|
|
|
#MPILIBS = ${LIBS} -lelan -lmpi
|
|
|
|
|
|
|
|
EBOFS_OBJS= \
|
|
|
|
ebofs/BlockDevice.o\
|
|
|
|
ebofs/BufferCache.o\
|
|
|
|
ebofs/Ebofs.o\
|
|
|
|
ebofs/Allocator.o
|
|
|
|
|
|
|
|
MDS_OBJS= \
|
|
|
|
mds/MDS.o\
|
|
|
|
mds/journal.o\
|
|
|
|
mds/Server.o\
|
|
|
|
mds/MDCache.o\
|
|
|
|
mds/Locker.o\
|
|
|
|
mds/Migrator.o\
|
|
|
|
mds/Renamer.o\
|
|
|
|
mds/MDBalancer.o\
|
|
|
|
mds/CDentry.o\
|
|
|
|
mds/CDir.o\
|
|
|
|
mds/CInode.o\
|
|
|
|
mds/AnchorTable.o\
|
|
|
|
mds/AnchorClient.o\
|
|
|
|
mds/MDStore.o\
|
|
|
|
mds/LogEvent.o\
|
|
|
|
mds/IdAllocator.o\
|
|
|
|
mds/MDLog.o
|
|
|
|
|
|
|
|
OSD_OBJS= \
|
|
|
|
osd/PG.o\
|
|
|
|
osd/ReplicatedPG.o\
|
2007-03-02 20:08:34 +00:00
|
|
|
osd/RAID4PG.o\
|
2007-02-28 18:42:55 +00:00
|
|
|
osd/Ager.o\
|
|
|
|
osd/FakeStore.o\
|
|
|
|
osd/OSD.o
|
|
|
|
|
|
|
|
OSDC_OBJS= \
|
|
|
|
osdc/Objecter.o\
|
|
|
|
osdc/ObjectCacher.o\
|
|
|
|
osdc/Filer.o\
|
|
|
|
osdc/Journaler.o
|
|
|
|
|
|
|
|
MON_OBJS= \
|
|
|
|
mon/Monitor.o\
|
|
|
|
mon/Paxos.o\
|
|
|
|
mon/OSDMonitor.o\
|
|
|
|
mon/MDSMonitor.o\
|
|
|
|
mon/ClientMonitor.o\
|
|
|
|
mon/Elector.o\
|
|
|
|
mon/MonitorStore.o
|
|
|
|
|
|
|
|
COMMON_OBJS= \
|
|
|
|
msg/Message.o\
|
|
|
|
common/Logger.o\
|
|
|
|
common/Clock.o\
|
|
|
|
common/Timer.o\
|
|
|
|
config.o
|
|
|
|
|
|
|
|
|
|
|
|
CLIENT_OBJS= \
|
|
|
|
client/FileCache.o\
|
|
|
|
client/Client.o\
|
|
|
|
client/SyntheticClient.o\
|
|
|
|
client/Trace.o
|
|
|
|
|
|
|
|
ifeq ($(want_bdb),yes)
|
|
|
|
OSBDB_OBJS = \
|
|
|
|
osbdb/OSBDB.o
|
|
|
|
|
|
|
|
OSBDB_OBJ = osbdb.o
|
|
|
|
endif
|
|
|
|
|
|
|
|
TARGETS = cmon cosd cmds cfuse csyn newsyn fakesyn mkmonmap
|
|
|
|
|
|
|
|
SRCS=*.cc */*.cc *.h */*.h */*/*.h
|
|
|
|
|
|
|
|
all: depend ${TARGETS}
|
|
|
|
|
|
|
|
test: depend ${TEST_TARGETS}
|
|
|
|
|
|
|
|
obfs: depend obfstest
|
|
|
|
|
|
|
|
|
|
|
|
# real bits
|
|
|
|
mkmonmap: mkmonmap.cc common.o
|
|
|
|
${CC} ${CFLAGS} ${LIBS} $^ -o $@
|
|
|
|
|
|
|
|
cmon: cmon.cc mon.o msg/SimpleMessenger.o common.o
|
|
|
|
${CC} ${CFLAGS} ${LIBS} $^ -o $@
|
|
|
|
|
|
|
|
cosd: cosd.cc osd.o ebofs.o ${OSBDB_OBJ} msg/SimpleMessenger.o common.o
|
|
|
|
${CC} ${CFLAGS} ${LIBS} ${OSBDB_LIBS} $^ -o $@
|
|
|
|
|
|
|
|
cmds: cmds.cc mds.o osdc.o msg/SimpleMessenger.o common.o
|
|
|
|
${CC} ${CFLAGS} ${LIBS} $^ -o $@
|
|
|
|
|
|
|
|
csyn: csyn.cc client.o osdc.o msg/SimpleMessenger.o common.o
|
|
|
|
${CC} ${CFLAGS} ${LIBS} $^ -o $@
|
|
|
|
|
|
|
|
cfuse: cfuse.cc client.o osdc.o client/fuse.o msg/SimpleMessenger.o common.o
|
|
|
|
${CC} ${CFLAGS} ${LIBS} -lfuse $^ -o $@
|
|
|
|
|
|
|
|
|
|
|
|
# misc
|
|
|
|
gprof-helper.so: test/gprof-helper.c
|
|
|
|
gcc -shared -fPIC test/gprof-helper.c -o gprof-helper.so -lpthread -ldl
|
|
|
|
|
|
|
|
|
|
|
|
# fake*
|
|
|
|
fakefuse: fakefuse.cc mon.o mds.o client.o osd.o osdc.o ebofs.o ${OSBDB_OBJ} client/fuse.o msg/FakeMessenger.o common.o
|
|
|
|
${CC} -pg ${CFLAGS} ${LIBS} ${OSBDB_LIBS} -lfuse $^ -o $@
|
|
|
|
|
|
|
|
fakesyn: fakesyn.cc mon.o mds.o client.o osd.o ebofs.o ${OSBDB_OBJ} osdc.o msg/FakeMessenger.o common.o
|
|
|
|
${CC} -pg ${CFLAGS} ${LIBS} ${OSBDB_LIBS} $^ -o $@
|
|
|
|
|
|
|
|
|
|
|
|
# mpi startup
|
|
|
|
newsyn: newsyn.cc mon.o mds.o client.o osd.o ebofs.o ${OSBDB_OBJ} osdc.o msg/SimpleMessenger.o common.o
|
|
|
|
${MPICC} -pg ${MPICFLAGS} ${MPILIBS} ${OSBDB_LIBS} $^ -o $@
|
|
|
|
|
|
|
|
newsyn.nopg: newsyn.cc mon.o mds.o client.o osd.o ebofs.o ${OSBDB_OBJ} osdc.o msg/SimpleMessenger.o common.o
|
|
|
|
${MPICC} ${MPICFLAGS} ${MPILIBS} ${OSBDB_LIBS} $^ -o $@
|
|
|
|
|
|
|
|
|
|
|
|
# ebofs
|
|
|
|
mkfs.ebofs: ebofs/mkfs.ebofs.cc config.cc common/Clock.o ebofs.o
|
|
|
|
${CC} -pg ${CFLAGS} ${LIBS} $^ -o $@
|
|
|
|
|
|
|
|
test.ebofs: ebofs/test.ebofs.cc config.cc common/Clock.o ebofs.o
|
|
|
|
${CC} -pg ${CFLAGS} ${LIBS} $^ -o $@
|
|
|
|
|
|
|
|
|
|
|
|
# + obfs (old)
|
|
|
|
fakesynobfs: fakesyn.cc mds.o client.o osd_obfs.o msg/FakeMessenger.o common.o
|
|
|
|
${CC} -DUSE_OBFS ${CFLAGS} ${LIBS} $^ -o $@
|
|
|
|
|
|
|
|
tcpsynobfs: tcpsyn.cc mds.o client.o osd_obfs.o ${TCP_OBJS} common.o
|
|
|
|
${MPICC} -DUSE_OBFS ${MPICFLAGS} ${MPILIBS} $^ -o $@
|
|
|
|
|
|
|
|
osd_obfs.o: osd/OBFSStore.o osd/OSD.cc osd/PG.o osd/ObjectStore.o osd/FakeStore.o
|
|
|
|
${MPICC} -DUSE_OBFS ${MPICFLAGS} ${MPILIBS} $^ -o $@ ../uofs/uofs.a
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# libceph
|
|
|
|
libceph.o: client/ldceph.o client/Client.o msg/SimpleMessenger.o ${COMMON_OBJS} ${SYN_OBJS} ${OSDC_OBJS}
|
|
|
|
${LDINC} $^ -o $@
|
|
|
|
|
|
|
|
bench/mdtest/mdtest.o: bench/mdtest/mdtest.c
|
|
|
|
mpicc -c $^ -o $@
|
|
|
|
|
|
|
|
mdtest: bench/mdtest/mdtest.o
|
|
|
|
${MPICC} ${MPICFLAGS} ${MPILIBS} $^ -o $@
|
|
|
|
|
|
|
|
mdtest.ceph: bench/mdtest/mdtest.o libceph.o
|
|
|
|
${MPICC} ${MPICFLAGS} ${MPILIBS} $^ -o $@
|
|
|
|
|
|
|
|
# OSD test
|
|
|
|
|
|
|
|
testos: test/testos.o ebofs.o osbdb.o common.o
|
|
|
|
${CC} ${CFLAGS} ${LIBS} ${OSBDB_LIBS} -o $@ $^
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
%.so: %.cc
|
|
|
|
${CC} -shared -fPIC ${CFLAGS} $< -o $@
|
|
|
|
|
|
|
|
clean:
|
|
|
|
rm -f *.o */*.o ${TARGETS} ${TEST_TARGETS}
|
|
|
|
|
|
|
|
common.o: ${COMMON_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
ebofs.o: ${EBOFS_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
client.o: ${CLIENT_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
osd.o: ${OSD_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
osdc.o: ${OSDC_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
mds.o: ${MDS_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
mon.o: ${MON_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
osbdb.o: ${OSBDB_OBJS}
|
|
|
|
${LDINC} $@ $^
|
|
|
|
|
|
|
|
%.o: %.cc
|
|
|
|
${CC} ${CFLAGS} -c $< -o $@
|
|
|
|
|
|
|
|
%.po: %.cc
|
|
|
|
${CC} -fPIC ${CFLAGS} -c $< -o $@
|
|
|
|
|
|
|
|
count:
|
|
|
|
cat ${SRCS} | wc -l
|
|
|
|
cat ${SRCS} | grep -c \;
|
|
|
|
|
|
|
|
TAGS:
|
|
|
|
etags `find . -name "*.[h|cc]"`
|
|
|
|
|
|
|
|
.depend:
|
|
|
|
touch .depend
|
|
|
|
|
|
|
|
depend:
|
|
|
|
$(RM) .depend
|
|
|
|
makedepend -f- -- $(CFLAGS) -- $(SRCS) > .depend 2>/dev/null
|
|
|
|
|
|
|
|
# now add a line to include the dependency list.
|
|
|
|
include .depend
|