Makefile 78.8 KB
Newer Older
J
jorlow@chromium.org 已提交
1 2 3 4
# Copyright (c) 2011 The LevelDB Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file. See the AUTHORS file for names of contributors.

5
# Inherit some settings from environment variables, if available
J
jorlow@chromium.org 已提交
6

7
#-----------------------------------------------
8

J
Jonathan Lee 已提交
9 10
BASH_EXISTS := $(shell which bash)
SHELL := $(shell which bash)
11 12 13
# Default to python3. Some distros like CentOS 8 do not have `python`.
PYTHON?=$(shell which python3 || which python || echo python3)
export PYTHON
J
Jonathan Lee 已提交
14

15
CLEAN_FILES = # deliberately empty, so we can append below.
16 17 18 19
CFLAGS += ${EXTRA_CFLAGS}
CXXFLAGS += ${EXTRA_CXXFLAGS}
LDFLAGS += $(EXTRA_LDFLAGS)
MACHINE ?= $(shell uname -m)
T
Tomas Kolda 已提交
20 21
ARFLAGS = ${EXTRA_ARFLAGS} rs
STRIPFLAGS = -S -x
22

23 24
# Transform parallel LOG output into something more readable.
perl_command = perl -n \
25 26 27
  -e '@a=split("\t",$$_,-1); $$t=$$a[8];'				\
  -e '$$t =~ /.*if\s\[\[\s"(.*?\.[\w\/]+)/ and $$t=$$1;'		\
  -e '$$t =~ s,^\./,,;'							\
Y
Yueh-Hsuan Chiang 已提交
28 29 30
  -e '$$t =~ s, >.*,,; chomp $$t;'					\
  -e '$$t =~ /.*--gtest_filter=(.*?\.[\w\/]+)/ and $$t=$$1;'		\
  -e 'printf "%7.3f %s %s\n", $$a[3], $$a[6] == 0 ? "PASS" : "FAIL", $$t'
31 32
quoted_perl_command = $(subst ','\'',$(perl_command))

33 34 35 36 37 38 39 40 41
# DEBUG_LEVEL can have three values:
# * DEBUG_LEVEL=2; this is the ultimate debug mode. It will compile rocksdb
# without any optimizations. To compile with level 2, issue `make dbg`
# * DEBUG_LEVEL=1; debug level 1 enables all assertions and debug code, but
# compiles rocksdb with -O2 optimizations. this is the default debug level.
# `make all` or `make <binary_target>` compile RocksDB with debug level 1.
# We use this debug level when developing RocksDB.
# * DEBUG_LEVEL=0; this is the debug level we use for release. If you're
# running rocksdb in production you most definitely want to compile RocksDB
A
agiardullo 已提交
42
# with debug level 0. To compile with level 0, run `make shared_lib`,
43 44
# `make install-shared`, `make static_lib`, `make install-static` or
# `make install`
45 46 47

# Set the default DEBUG_LEVEL to 1
DEBUG_LEVEL?=1
48

49 50 51 52 53 54 55
# LIB_MODE says whether or not to use/build "shared" or "static" libraries.
# Mode "static" means to link against static libraries (.a)
# Mode "shared" means to link against shared libraries (.so, .sl, .dylib, etc)
#
# Set the default LIB_MODE to static
LIB_MODE?=static

56
ifeq ($(MAKECMDGOALS),dbg)
Y
Yueh-Hsuan Chiang 已提交
57
	DEBUG_LEVEL=2
58
endif
59

60 61 62 63 64 65 66 67
ifeq ($(MAKECMDGOALS),clean)
	DEBUG_LEVEL=0
endif

ifeq ($(MAKECMDGOALS),release)
	DEBUG_LEVEL=0
endif

68
ifeq ($(MAKECMDGOALS),shared_lib)
69
	LIB_MODE=shared
Y
Yueh-Hsuan Chiang 已提交
70
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
71
endif
I
Igor Canadi 已提交
72

I
Igor Canadi 已提交
73
ifeq ($(MAKECMDGOALS),install-shared)
74
	LIB_MODE=shared
Y
Yueh-Hsuan Chiang 已提交
75
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
76 77
endif

I
Igor Canadi 已提交
78
ifeq ($(MAKECMDGOALS),static_lib)
Y
Yueh-Hsuan Chiang 已提交
79
	DEBUG_LEVEL=0
80
	LIB_MODE=static
81
endif
I
Igor Canadi 已提交
82

I
Igor Canadi 已提交
83
ifeq ($(MAKECMDGOALS),install-static)
Y
Yueh-Hsuan Chiang 已提交
84
	DEBUG_LEVEL=0
85
	LIB_MODE=static
I
Igor Canadi 已提交
86 87 88
endif

ifeq ($(MAKECMDGOALS),install)
Y
Yueh-Hsuan Chiang 已提交
89
	DEBUG_LEVEL=0
90 91
endif

92

93 94 95
ifneq ($(findstring jtest, $(MAKECMDGOALS)),)
	OBJ_DIR=jl
	LIB_MODE=shared
Y
Yueh-Hsuan Chiang 已提交
96 97
endif

98 99 100 101 102 103 104 105 106 107 108 109
ifneq ($(findstring rocksdbjava, $(MAKECMDGOALS)),)
	LIB_MODE=shared
        ifneq ($(findstring rocksdbjavastatic, $(MAKECMDGOALS)),)
		OBJ_DIR=jls
	        ifneq ($(DEBUG_LEVEL),2)
	            DEBUG_LEVEL=0
                endif
                ifeq ($(MAKECMDGOALS),rocksdbjavastaticpublish)
	            DEBUG_LEVEL=0
                endif
	else
		OBJ_DIR=jl
110
	endif
111 112
endif

113 114
$(info $$DEBUG_LEVEL is ${DEBUG_LEVEL})

Y
Yi Wu 已提交
115 116
# Lite build flag.
LITE ?= 0
117 118 119 120 121 122 123 124
ifeq ($(LITE), 0)
ifneq ($(filter -DROCKSDB_LITE,$(OPT)),)
  # Be backward compatible and support older format where OPT=-DROCKSDB_LITE is
  # specified instead of LITE=1 on the command line.
  LITE=1
endif
else ifeq ($(LITE), 1)
ifeq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yi Wu 已提交
125 126
	OPT += -DROCKSDB_LITE
endif
127
endif
Y
Yi Wu 已提交
128 129 130 131 132 133 134 135 136 137

# Figure out optimize level.
ifneq ($(DEBUG_LEVEL), 2)
ifeq ($(LITE), 0)
	OPT += -O2
else
	OPT += -Os
endif
endif

138 139
# compile with -O2 if debug level is not 2
ifneq ($(DEBUG_LEVEL), 2)
Y
Yi Wu 已提交
140
OPT += -fno-omit-frame-pointer
141 142
# Skip for archs that don't support -momit-leaf-frame-pointer
ifeq (,$(shell $(CXX) -fsyntax-only -momit-leaf-frame-pointer -xc /dev/null 2>&1))
143 144 145 146
OPT += -momit-leaf-frame-pointer
endif
endif

147 148 149 150 151 152 153 154 155 156 157 158
ifeq (,$(shell $(CXX) -fsyntax-only -maltivec -xc /dev/null 2>&1))
CXXFLAGS += -DHAS_ALTIVEC
CFLAGS += -DHAS_ALTIVEC
HAS_ALTIVEC=1
endif

ifeq (,$(shell $(CXX) -fsyntax-only -mcpu=power8 -xc /dev/null 2>&1))
CXXFLAGS += -DHAVE_POWER8
CFLAGS +=  -DHAVE_POWER8
HAVE_POWER8=1
endif

159
ifeq (,$(shell $(CXX) -fsyntax-only -march=armv8-a+crc+crypto -xc /dev/null 2>&1))
160 161
CXXFLAGS += -march=armv8-a+crc+crypto
CFLAGS += -march=armv8-a+crc+crypto
162 163 164
ARMCRC_SOURCE=1
endif

165 166 167 168 169 170
# if we're compiling for shared libraries, add the shared flags
ifeq ($(LIB_MODE),shared)
CXXFLAGS += $(PLATFORM_SHARED_CFLAGS) -DROCKSDB_DLL
CFLAGS +=  $(PLATFORM_SHARED_CFLAGS) -DROCKSDB_DLL
endif

171
# if we're compiling for release, compile without debug code (-DNDEBUG)
172
ifeq ($(DEBUG_LEVEL),0)
I
Igor Canadi 已提交
173
OPT += -DNDEBUG
S
Siying Dong 已提交
174 175 176 177 178 179

ifneq ($(USE_RTTI), 1)
	CXXFLAGS += -fno-rtti
else
	CXXFLAGS += -DROCKSDB_USE_RTTI
endif
180
else
S
Siying Dong 已提交
181 182 183 184 185 186
ifneq ($(USE_RTTI), 0)
	CXXFLAGS += -DROCKSDB_USE_RTTI
else
	CXXFLAGS += -fno-rtti
endif

187 188 189 190 191 192
ifdef ASSERT_STATUS_CHECKED
ifeq ($(filter -DROCKSDB_ASSERT_STATUS_CHECKED,$(OPT)),)
	OPT += -DROCKSDB_ASSERT_STATUS_CHECKED
endif
endif

193
$(warning Warning: Compiling in debug mode. Don't use the resulting binary in production)
I
Igor Canadi 已提交
194 195
endif

196
#-----------------------------------------------
197
include src.mk
198

199
AM_DEFAULT_VERBOSITY ?= 0
200 201 202 203 204

AM_V_GEN = $(am__v_GEN_$(V))
am__v_GEN_ = $(am__v_GEN_$(AM_DEFAULT_VERBOSITY))
am__v_GEN_0 = @echo "  GEN     " $@;
am__v_GEN_1 =
J
Jim Meyering 已提交
205 206 207 208
AM_V_at = $(am__v_at_$(V))
am__v_at_ = $(am__v_at_$(AM_DEFAULT_VERBOSITY))
am__v_at_0 = @
am__v_at_1 =
209 210 211 212 213

AM_V_CC = $(am__v_CC_$(V))
am__v_CC_ = $(am__v_CC_$(AM_DEFAULT_VERBOSITY))
am__v_CC_0 = @echo "  CC      " $@;
am__v_CC_1 =
214

215 216
AM_V_CCLD = $(am__v_CCLD_$(V))
am__v_CCLD_ = $(am__v_CCLD_$(AM_DEFAULT_VERBOSITY))
217
ifneq ($(SKIP_LINK), 1)
218 219
am__v_CCLD_0 = @echo "  CCLD    " $@;
am__v_CCLD_1 =
220 221 222 223
else
am__v_CCLD_0 = @echo "  !CCLD   " $@; true skip
am__v_CCLD_1 = true skip
endif
J
Jim Meyering 已提交
224 225 226 227
AM_V_AR = $(am__v_AR_$(V))
am__v_AR_ = $(am__v_AR_$(AM_DEFAULT_VERBOSITY))
am__v_AR_0 = @echo "  AR      " $@;
am__v_AR_1 =
228

229 230 231 232
ifdef ROCKSDB_USE_LIBRADOS
LIB_SOURCES += utilities/env_librados.cc
LDFLAGS += -lrados
endif
233

234 235
AM_LINK = $(AM_V_CCLD)$(CXX) -L. $(patsubst lib%.a, -l%, $(patsubst lib%.$(PLATFORM_SHARED_EXT), -l%, $^)) $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(COVERAGEFLAGS)
AM_SHARE = $(AM_V_CCLD) $(CXX) $(PLATFORM_SHARED_LDFLAGS)$@ -L. $(patsubst lib%.$(PLATFORM_SHARED_EXT), -l%, $^) $(LDFLAGS) -o $@
236

237 238 239 240 241 242 243 244 245 246 247
# Detect what platform we're building on.
# Export some common variables that might have been passed as Make variables
# instead of environment variables.
dummy := $(shell (export ROCKSDB_ROOT="$(CURDIR)"; \
                  export COMPILE_WITH_ASAN="$(COMPILE_WITH_ASAN)"; \
                  export COMPILE_WITH_TSAN="$(COMPILE_WITH_TSAN)"; \
                  export COMPILE_WITH_UBSAN="$(COMPILE_WITH_UBSAN)"; \
                  export PORTABLE="$(PORTABLE)"; \
                  export ROCKSDB_NO_FBCODE="$(ROCKSDB_NO_FBCODE)"; \
                  export USE_CLANG="$(USE_CLANG)"; \
                  "$(CURDIR)/build_tools/build_detect_platform" "$(CURDIR)/make_config.mk"))
S
Sanjay Ghemawat 已提交
248
# this file is generated by the previous line to set build flags and sources
I
Igor Canadi 已提交
249
include make_config.mk
250

251
export JAVAC_ARGS
252
CLEAN_FILES += make_config.mk
J
jorlow@chromium.org 已提交
253

254 255 256 257 258 259
ifeq ($(V), 1)
$(info $(shell uname -a))
$(info $(shell $(CC) --version))
$(info $(shell $(CXX) --version))
endif

260
missing_make_config_paths := $(shell				\
261
	grep "\./\S*\|/\S*" -o $(CURDIR)/make_config.mk | 	\
262 263 264 265 266
	while read path;					\
		do [ -e $$path ] || echo $$path; 		\
	done | sort | uniq)

$(foreach path, $(missing_make_config_paths), \
267
	$(warning Warning: $(path) does not exist))
268

T
Tomas Kolda 已提交
269 270 271
ifeq ($(PLATFORM), OS_AIX)
# no debug info
else ifneq ($(PLATFORM), IOS)
I
Igor Canadi 已提交
272 273 274 275 276 277 278
CFLAGS += -g
CXXFLAGS += -g
else
# no debug info for IOS, that will make our library big
OPT += -DNDEBUG
endif

T
Tomas Kolda 已提交
279 280 281 282 283
ifeq ($(PLATFORM), OS_AIX)
ARFLAGS = -X64 rs
STRIPFLAGS = -X64 -x
endif

D
David Bernard 已提交
284 285 286
ifeq ($(PLATFORM), OS_SOLARIS)
	PLATFORM_CXXFLAGS += -D _GLIBCXX_USE_C99
endif
287
ifneq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yueh-Hsuan Chiang 已提交
288 289 290
	# found
	CFLAGS += -fno-exceptions
	CXXFLAGS += -fno-exceptions
291 292
	# LUA is not supported under ROCKSDB_LITE
	LUA_PATH =
293 294
endif

295 296
ifeq ($(LIB_MODE),shared)
# So that binaries are executable from build location, in addition to install location
P
Peter Dillinger 已提交
297
EXEC_LDFLAGS += -Wl,-rpath -Wl,'$$ORIGIN'
298 299
endif

I
Igor Canadi 已提交
300 301
# ASAN doesn't work well with jemalloc. If we're compiling with ASAN, we should use regular malloc.
ifdef COMPILE_WITH_ASAN
Y
Yueh-Hsuan Chiang 已提交
302 303 304 305
	DISABLE_JEMALLOC=1
	EXEC_LDFLAGS += -fsanitize=address
	PLATFORM_CCFLAGS += -fsanitize=address
	PLATFORM_CXXFLAGS += -fsanitize=address
I
Igor Canadi 已提交
306 307 308 309
endif

# TSAN doesn't work well with jemalloc. If we're compiling with TSAN, we should use regular malloc.
ifdef COMPILE_WITH_TSAN
Y
Yueh-Hsuan Chiang 已提交
310
	DISABLE_JEMALLOC=1
S
Siying Dong 已提交
311
	EXEC_LDFLAGS += -fsanitize=thread
312 313
	PLATFORM_CCFLAGS += -fsanitize=thread -fPIC -DFOLLY_SANITIZE_THREAD
	PLATFORM_CXXFLAGS += -fsanitize=thread -fPIC -DFOLLY_SANITIZE_THREAD
314 315
        # Turn off -pg when enabling TSAN testing, because that induces
        # a link failure.  TODO: find the root cause
D
dx9 已提交
316
	PROFILING_FLAGS =
317 318
	# LUA is not supported under TSAN
	LUA_PATH =
319 320 321
	# Limit keys for crash test under TSAN to avoid error:
	# "ThreadSanitizer: DenseSlabAllocator overflow. Dying."
	CRASH_TEST_EXT_ARGS += --max_key=1000000
I
Igor Canadi 已提交
322 323
endif

T
Tomas Kolda 已提交
324 325 326 327 328
# AIX doesn't work with -pg
ifeq ($(PLATFORM), OS_AIX)
	PROFILING_FLAGS =
endif

329 330 331
# USAN doesn't work well with jemalloc. If we're compiling with USAN, we should use regular malloc.
ifdef COMPILE_WITH_UBSAN
	DISABLE_JEMALLOC=1
S
Siying Dong 已提交
332 333 334 335
	# Suppress alignment warning because murmurhash relies on casting unaligned
	# memory to integer. Fixing it may cause performance regression. 3-way crc32
	# relies on it too, although it can be rewritten to eliminate with minimal
	# performance regression.
336 337 338
	EXEC_LDFLAGS += -fsanitize=undefined -fno-sanitize-recover=all
	PLATFORM_CCFLAGS += -fsanitize=undefined -fno-sanitize-recover=all -DROCKSDB_UBSAN_RUN
	PLATFORM_CXXFLAGS += -fsanitize=undefined -fno-sanitize-recover=all -DROCKSDB_UBSAN_RUN
339 340
endif

341 342 343 344 345
ifdef ROCKSDB_VALGRIND_RUN
	PLATFORM_CCFLAGS += -DROCKSDB_VALGRIND_RUN
	PLATFORM_CXXFLAGS += -DROCKSDB_VALGRIND_RUN
endif

I
Igor Canadi 已提交
346
ifndef DISABLE_JEMALLOC
347
	ifdef JEMALLOC
T
Tamir Duberstein 已提交
348 349
		PLATFORM_CXXFLAGS += -DROCKSDB_JEMALLOC -DJEMALLOC_NO_DEMANGLE
		PLATFORM_CCFLAGS  += -DROCKSDB_JEMALLOC -DJEMALLOC_NO_DEMANGLE
350
	endif
351 352 353 354
	ifdef WITH_JEMALLOC_FLAG
		PLATFORM_LDFLAGS += -ljemalloc
		JAVA_LDFLAGS += -ljemalloc
	endif
Y
Yueh-Hsuan Chiang 已提交
355 356 357
	EXEC_LDFLAGS := $(JEMALLOC_LIB) $(EXEC_LDFLAGS)
	PLATFORM_CXXFLAGS += $(JEMALLOC_INCLUDE)
	PLATFORM_CCFLAGS += $(JEMALLOC_INCLUDE)
I
Igor Canadi 已提交
358 359
endif

360 361 362 363
ifndef USE_FOLLY_DISTRIBUTED_MUTEX
	USE_FOLLY_DISTRIBUTED_MUTEX=0
endif

T
Tamir Duberstein 已提交
364 365
export GTEST_THROW_ON_FAILURE=1
export GTEST_HAS_EXCEPTIONS=1
366
GTEST_DIR = third-party/gtest-1.8.1/fused-src
T
Tomas Kolda 已提交
367 368 369 370 371 372 373 374
# AIX: pre-defined system headers are surrounded by an extern "C" block
ifeq ($(PLATFORM), OS_AIX)
	PLATFORM_CCFLAGS += -I$(GTEST_DIR)
	PLATFORM_CXXFLAGS += -I$(GTEST_DIR)
else
	PLATFORM_CCFLAGS += -isystem $(GTEST_DIR)
	PLATFORM_CXXFLAGS += -isystem $(GTEST_DIR)
endif
I
Igor Sugak 已提交
375

376
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
377 378 379 380 381 382 383 384 385 386
	FOLLY_DIR = ./third-party/folly
	# AIX: pre-defined system headers are surrounded by an extern "C" block
	ifeq ($(PLATFORM), OS_AIX)
		PLATFORM_CCFLAGS += -I$(FOLLY_DIR)
		PLATFORM_CXXFLAGS += -I$(FOLLY_DIR)
	else
		PLATFORM_CCFLAGS += -isystem $(FOLLY_DIR)
		PLATFORM_CXXFLAGS += -isystem $(FOLLY_DIR)
	endif
endif
387 388 389 390 391

ifdef TEST_CACHE_LINE_SIZE
  PLATFORM_CCFLAGS += -DTEST_CACHE_LINE_SIZE=$(TEST_CACHE_LINE_SIZE)
  PLATFORM_CXXFLAGS += -DTEST_CACHE_LINE_SIZE=$(TEST_CACHE_LINE_SIZE)
endif
392

393 394 395
# This (the first rule) must depend on "all".
default: all

396
WARNING_FLAGS = -W -Wextra -Wall -Wsign-compare -Wshadow \
397
  -Wunused-parameter
398

399 400 401 402
ifeq ($(PLATFORM), OS_OPENBSD)
	WARNING_FLAGS += -Wno-unused-lambda-capture
endif

403
ifndef DISABLE_WARNING_AS_ERROR
Y
Yueh-Hsuan Chiang 已提交
404
	WARNING_FLAGS += -Werror
405 406
endif

407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429

ifdef LUA_PATH

ifndef LUA_INCLUDE
LUA_INCLUDE=$(LUA_PATH)/include
endif

LUA_INCLUDE_FILE=$(LUA_INCLUDE)/lualib.h

ifeq ("$(wildcard $(LUA_INCLUDE_FILE))", "")
# LUA_INCLUDE_FILE does not exist
$(error Cannot find lualib.h under $(LUA_INCLUDE).  Try to specify both LUA_PATH and LUA_INCLUDE manually)
endif
LUA_FLAGS = -I$(LUA_INCLUDE) -DLUA -DLUA_COMPAT_ALL
CFLAGS += $(LUA_FLAGS)
CXXFLAGS += $(LUA_FLAGS)

ifndef LUA_LIB
LUA_LIB = $(LUA_PATH)/lib/liblua.a
endif
ifeq ("$(wildcard $(LUA_LIB))", "") # LUA_LIB does not exist
$(error $(LUA_LIB) does not exist.  Try to specify both LUA_PATH and LUA_LIB manually)
endif
430
EXEC_LDFLAGS += $(LUA_LIB)
431 432 433

endif

434 435 436
ifeq ($(NO_THREEWAY_CRC32C), 1)
	CXXFLAGS += -DNO_THREEWAY_CRC32C
endif
437

I
Igor Canadi 已提交
438
CFLAGS += $(WARNING_FLAGS) -I. -I./include $(PLATFORM_CCFLAGS) $(OPT)
I
Islam AbdelRahman 已提交
439
CXXFLAGS += $(WARNING_FLAGS) -I. -I./include $(PLATFORM_CXXFLAGS) $(OPT) -Woverloaded-virtual -Wnon-virtual-dtor -Wno-missing-field-initializers
440

S
Sanjay Ghemawat 已提交
441
LDFLAGS += $(PLATFORM_LDFLAGS)
J
jorlow@chromium.org 已提交
442

443 444 445
# If NO_UPDATE_BUILD_VERSION is set we don't update util/build_version.cc, but
# the file needs to already exist or else the build will fail
ifndef NO_UPDATE_BUILD_VERSION
446
date := $(shell date +%F)
I
Igor Canadi 已提交
447
ifdef FORCE_GIT_SHA
Y
Yueh-Hsuan Chiang 已提交
448
	git_sha := $(FORCE_GIT_SHA)
I
Igor Canadi 已提交
449
else
Y
Yueh-Hsuan Chiang 已提交
450
	git_sha := $(shell git rev-parse HEAD 2>/dev/null)
I
Igor Canadi 已提交
451
endif
452
gen_build_version = sed -e s/@@GIT_SHA@@/$(git_sha)/ -e s/@@GIT_DATE_TIME@@/$(date)/ util/build_version.cc.in
453 454 455 456 457 458

# Record the version of the source that we are compiling.
# We keep a record of the git revision in this file.  It is then built
# as a regular source file as part of the compilation process.
# One can run "strings executable_filename | grep _build_" to find
# the version of the source that we used to build the executable file.
459 460
FORCE:
util/build_version.cc: FORCE
Y
Yueh-Hsuan Chiang 已提交
461 462 463 464 465
	$(AM_V_GEN)rm -f $@-t
	$(AM_V_at)$(gen_build_version) > $@-t
	$(AM_V_at)if test -f $@; then					\
	  cmp -s $@-t $@ && rm -f $@-t || mv -f $@-t $@;		\
	else mv -f $@-t $@; fi
466
endif
467

468 469
OBJ_DIR?=.
LIB_OBJECTS = $(patsubst %.cc, $(OBJ_DIR)/%.o, $(LIB_SOURCES))
470
ifeq ($(HAVE_POWER8),1)
471 472
LIB_OBJECTS += $(patsubst %.c, $(OBJ_DIR)/%.o, $(LIB_SOURCES_C))
LIB_OBJECTS += $(patsubst %.S, $(OBJ_DIR)/%.o, $(LIB_SOURCES_ASM))
473 474
endif

475
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
476
  LIB_OBJECTS += $(patsubst %.cpp, $(OBJ_DIR)/%.o, $(FOLLY_SOURCES))
477
endif
J
jorlow@chromium.org 已提交
478

479 480 481
GTEST = $(OBJ_DIR)/$(GTEST_DIR)/gtest/gtest-all.o
TESTUTIL = $(OBJ_DIR)/test_util/testutil.o
TESTHARNESS = $(OBJ_DIR)/test_util/testharness.o $(TESTUTIL) $(GTEST)
482
VALGRIND_ERROR = 2
483
VALGRIND_VER := $(join $(VALGRIND_VER),valgrind)
484

485
VALGRIND_OPTS = --error-exitcode=$(VALGRIND_ERROR) --leak-check=full
486

487 488 489 490 491
TEST_OBJECTS = $(patsubst %.cc, $(OBJ_DIR)/%.o, $(TEST_LIB_SOURCES) $(MOCK_LIB_SOURCES)) $(GTEST)
BENCH_OBJECTS = $(patsubst %.cc, $(OBJ_DIR)/%.o, $(BENCH_LIB_SOURCES))
TOOL_OBJECTS = $(patsubst %.cc, $(OBJ_DIR)/%.o, $(TOOL_LIB_SOURCES))
ANALYZE_OBJECTS = $(patsubst %.cc, $(OBJ_DIR)/%.o, $(ANALYZER_LIB_SOURCES))
STRESS_OBJECTS =  $(patsubst %.cc, $(OBJ_DIR)/%.o, $(STRESS_LIB_SOURCES))
492

493 494 495
ALL_SOURCES  = $(LIB_SOURCES) $(TEST_LIB_SOURCES) $(MOCK_LIB_SOURCES) $(GTEST_DIR)/gtest/gtest-all.cc
ALL_SOURCES += $(TOOL_LIB_SOURCES) $(BENCH_LIB_SOURCES) $(ANALYZER_LIB_SOURCES) $(STRESS_LIB_SOURCES)
ALL_SOURCES += $(TEST_MAIN_SOURCES) $(TOOL_MAIN_SOURCES) $(BENCH_MAIN_SOURCES)
496

497 498 499 500 501 502 503
TESTS = $(patsubst %.cc, %, $(notdir $(TEST_MAIN_SOURCES)))
TESTS += $(patsubst %.c, %, $(notdir $(TEST_MAIN_SOURCES_C)))

ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
	TESTS += folly_synchronization_distributed_mutex_test
	ALL_SOURCES += third-party/folly/folly/synchronization/test/DistributedMutexTest.cc
endif
504

Y
Yi Wu 已提交
505 506
PARALLEL_TEST = \
	backupable_db_test \
507
	db_bloom_filter_test \
Y
Yi Wu 已提交
508 509
	db_compaction_filter_test \
	db_compaction_test \
510
	db_merge_operator_test \
511
	db_sst_test \
Y
Yi Wu 已提交
512 513
	db_test \
	db_universal_compaction_test \
514 515
	db_wal_test \
	external_sst_file_test \
516
	import_column_family_test \
Y
Yi Wu 已提交
517
	fault_injection_test \
518
	file_reader_writer_test \
Y
Yi Wu 已提交
519 520
	inlineskiplist_test \
	manual_compaction_test \
521 522
	persistent_cache_test \
	table_test \
523
	transaction_test \
524
	transaction_lock_mgr_test \
525
	write_prepared_transaction_test \
526
	write_unprepared_transaction_test \
Y
Yi Wu 已提交
527

528 529 530 531 532
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
	TESTS += folly_synchronization_distributed_mutex_test
	PARALLEL_TEST += folly_synchronization_distributed_mutex_test
endif

533 534 535 536
# options_settable_test doesn't pass with UBSAN as we use hack in the test
ifdef COMPILE_WITH_UBSAN
        TESTS := $(shell echo $(TESTS) | sed 's/\boptions_settable_test\b//g')
endif
537
ifdef ASSERT_STATUS_CHECKED
538 539
# This is a new check for which we will add support incrementally. This
# list can be removed once support is fully added.
540
	TESTS_PASSING_ASC = \
541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568
		arena_test \
		autovector_test \
		blob_file_addition_test \
		blob_file_garbage_test \
		bloom_test \
		cassandra_format_test \
		cassandra_row_merge_test \
		cassandra_serialize_test \
		cleanable_test \
		coding_test \
		crc32c_test \
		dbformat_test \
		defer_test \
		dynamic_bloom_test \
		event_logger_test \
		file_indexer_test \
		folly_synchronization_distributed_mutex_test \
		hash_table_test \
		hash_test \
		heap_test \
		histogram_test \
		inlineskiplist_test \
		io_posix_test \
		iostats_context_test \
		memkind_kmem_allocator_test \
		merger_test \
		mock_env_test \
		object_registry_test \
569
		options_settable_test \
570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585
		options_test \
		random_test \
		range_del_aggregator_test \
		range_tombstone_fragmenter_test \
		repeatable_thread_test \
		skiplist_test \
		slice_test \
		statistics_test \
		thread_local_test \
		timer_queue_test \
		timer_test \
		util_merge_operators_test \
		version_edit_test \
		work_queue_test \
		write_controller_test \

586 587 588 589 590 591 592 593 594
	# Enable building all unit tests, but use check_some to run only tests
	# known to pass ASC
	SUBSET := $(TESTS_PASSING_ASC)
	# Alternate: only build unit tests known to pass ASC, and run them
	# with make check
	#TESTS := $(filter $(TESTS_PASSING_ASC),$(TESTS))
	#PARALLEL_TEST := $(filter $(TESTS_PASSING_ASC),$(PARALLEL_TEST))
else
	SUBSET := $(TESTS)
595
endif
I
Islam AbdelRahman 已提交
596 597 598 599 600 601 602
ifdef ROCKSDBTESTS_START
        SUBSET := $(shell echo $(SUBSET) | sed 's/^.*$(ROCKSDBTESTS_START)/$(ROCKSDBTESTS_START)/')
endif

ifdef ROCKSDBTESTS_END
        SUBSET := $(shell echo $(SUBSET) | sed 's/$(ROCKSDBTESTS_END).*//')
endif
603

604 605
# bench_tool_analyer main is in bench_tool_analyzer_tool, or this would be simpler...
TOOLS = $(patsubst %.cc, %, $(notdir $(patsubst %_tool.cc, %.cc, $(TOOLS_MAIN_SOURCES))))
J
jorlow@chromium.org 已提交
606

607 608 609
TEST_LIBS = \
	librocksdb_env_basic_test.a

S
sdong 已提交
610
# TODO: add back forward_iterator_bench, after making it build in all environemnts.
611
BENCHMARKS = $(patsubst %.cc, %, $(notdir $(BENCH_MAIN_SOURCES)))
J
jorlow@chromium.org 已提交
612

613
# if user didn't config LIBNAME, set the default
614
ifeq ($(LIBNAME),)
615
  LIBNAME=librocksdb
616
# we should only run rocksdb in production with DEBUG_LEVEL 0
617 618
ifneq ($(DEBUG_LEVEL),0)
  LIBDEBUG=_debug
619
endif
620
endif
621 622 623 624 625 626 627 628 629 630
STATIC_LIBRARY = ${LIBNAME}$(LIBDEBUG).a
STATIC_TEST_LIBRARY =  ${LIBNAME}_test$(LIBDEBUG).a
STATIC_TOOLS_LIBRARY = ${LIBNAME}_tools$(LIBDEBUG).a
STATIC_STRESS_LIBRARY = ${LIBNAME}_stress$(LIBDEBUG).a

ALL_STATIC_LIBS = $(STATIC_LIBRARY) $(STATIC_TEST_LIBRARY) $(STATIC_TOOLS_LIBRARY) $(STATIC_STRESS_LIBRARY)

SHARED_TEST_LIBRARY =  ${LIBNAME}_test$(LIBDEBUG).$(PLATFORM_SHARED_EXT)
SHARED_TOOLS_LIBRARY = ${LIBNAME}_tools$(LIBDEBUG).$(PLATFORM_SHARED_EXT)
SHARED_STRESS_LIBRARY = ${LIBNAME}_stress$(LIBDEBUG).$(PLATFORM_SHARED_EXT)
631

632 633 634 635 636 637 638
ALL_SHARED_LIBS = $(SHARED1) $(SHARED2) $(SHARED3) $(SHARED4) $(SHARED_TEST_LIBRARY) $(SHARED_TOOLS_LIBRARY) $(SHARED_STRESS_LIBRARY)

ifeq ($(LIB_MODE),shared)
LIBRARY=$(SHARED1)
TEST_LIBRARY=$(SHARED_TEST_LIBRARY)
TOOLS_LIBRARY=$(SHARED_TOOLS_LIBRARY)
STRESS_LIBRARY=$(SHARED_STRESS_LIBRARY)
639 640 641 642 643
ifeq ($(DEBUG_LEVEL),0)
STRESS_LIBRARY_RUNTIME_DEPS=$(SHARED_TOOLS_LIBRARY)
else
STRESS_LIBRARY_RUNTIME_DEPS=$(SHARED_TEST_LIBRARY) $(SHARED_TOOLS_LIBRARY)
endif
644 645 646 647 648 649
CLOUD_LIBRARY=$(SHARED_CLOUD_LIBRARY)
else
LIBRARY=$(STATIC_LIBRARY)
TEST_LIBRARY=$(STATIC_TEST_LIBRARY)
TOOLS_LIBRARY=$(STATIC_TOOLS_LIBRARY)
STRESS_LIBRARY=$(STATIC_STRESS_LIBRARY)
650
STRESS_LIBRARY_RUNTIME_DEPS=
651
endif
652

653 654 655
ROCKSDB_MAJOR = $(shell egrep "ROCKSDB_MAJOR.[0-9]" include/rocksdb/version.h | cut -d ' ' -f 3)
ROCKSDB_MINOR = $(shell egrep "ROCKSDB_MINOR.[0-9]" include/rocksdb/version.h | cut -d ' ' -f 3)
ROCKSDB_PATCH = $(shell egrep "ROCKSDB_PATCH.[0-9]" include/rocksdb/version.h | cut -d ' ' -f 3)
656

657 658
default: all

659 660 661
#-----------------------------------------------
# Create platform independent shared libraries.
#-----------------------------------------------
662
ifneq ($(PLATFORM_SHARED_EXT),)
H
heyongqiang 已提交
663 664

ifneq ($(PLATFORM_SHARED_VERSIONED),true)
665
SHARED1 = ${LIBNAME}$(LIBDEBUG).$(PLATFORM_SHARED_EXT)
H
heyongqiang 已提交
666 667
SHARED2 = $(SHARED1)
SHARED3 = $(SHARED1)
668
SHARED4 = $(SHARED1)
H
heyongqiang 已提交
669 670
SHARED = $(SHARED1)
else
671 672
SHARED_MAJOR = $(ROCKSDB_MAJOR)
SHARED_MINOR = $(ROCKSDB_MINOR)
673
SHARED_PATCH = $(ROCKSDB_PATCH)
674
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
675
ifeq ($(PLATFORM), OS_MACOSX)
676
SHARED_OSX = $(LIBNAME)$(LIBDEBUG).$(SHARED_MAJOR)
677 678 679 680
SHARED2 = $(SHARED_OSX).$(PLATFORM_SHARED_EXT)
SHARED3 = $(SHARED_OSX).$(SHARED_MINOR).$(PLATFORM_SHARED_EXT)
SHARED4 = $(SHARED_OSX).$(SHARED_MINOR).$(SHARED_PATCH).$(PLATFORM_SHARED_EXT)
else
681 682
SHARED2 = $(SHARED1).$(SHARED_MAJOR)
SHARED3 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR)
683
SHARED4 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR).$(SHARED_PATCH)
684
endif # MACOSX
685
SHARED = $(SHARED1) $(SHARED2) $(SHARED3) $(SHARED4)
686
$(SHARED1): $(SHARED4) $(SHARED2)
Y
Yueh-Hsuan Chiang 已提交
687
	ln -fs $(SHARED4) $(SHARED1)
688
$(SHARED2): $(SHARED4) $(SHARED3)
Y
Yueh-Hsuan Chiang 已提交
689
	ln -fs $(SHARED4) $(SHARED2)
690
$(SHARED3): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
691
	ln -fs $(SHARED4) $(SHARED3)
H
heyongqiang 已提交
692

693 694
endif   # PLATFORM_SHARED_VERSIONED
$(SHARED4): $(LIB_OBJECTS)
695
	$(AM_V_CCLD) $(CXX) $(PLATFORM_SHARED_LDFLAGS)$(SHARED3) $(LIB_OBJECTS) $(LDFLAGS) -o $@
H
heyongqiang 已提交
696 697
endif  # PLATFORM_SHARED_EXT

698
.PHONY: blackbox_crash_test check clean coverage crash_test ldb_tests package \
699
	release tags tags0 valgrind_check whitebox_crash_test format static_lib shared_lib all \
Y
Yueh-Hsuan Chiang 已提交
700
	dbg rocksdbjavastatic rocksdbjava install install-static install-shared uninstall \
701
	analyze tools tools_lib \
702
	blackbox_crash_test_with_atomic_flush whitebox_crash_test_with_atomic_flush  \
703 704
	blackbox_crash_test_with_txn whitebox_crash_test_with_txn \
	blackbox_crash_test_with_best_efforts_recovery
705

M
maurice barnum 已提交
706

707
all: $(LIBRARY) $(BENCHMARKS) tools tools_lib test_libs $(TESTS)
708

709 710
all_but_some_tests: $(LIBRARY) $(BENCHMARKS) tools tools_lib test_libs $(SUBSET)

711
static_lib: $(STATIC_LIBRARY)
I
Igor Canadi 已提交
712 713 714

shared_lib: $(SHARED)

715 716
stress_lib: $(STRESS_LIBRARY)

M
maurice barnum 已提交
717 718
tools: $(TOOLS)

719 720
tools_lib: $(TOOLS_LIBRARY)

721 722
test_libs: $(TEST_LIBS)

723 724
benchmarks: $(BENCHMARKS)

M
maurice barnum 已提交
725
dbg: $(LIBRARY) $(BENCHMARKS) tools $(TESTS)
K
Kai Liu 已提交
726

727 728 729
# creates library and programs
release: clean
	LIB_MODE=$(LIB_MODE) DEBUG_LEVEL=0 $(MAKE) $(LIBRARY) tools db_bench
K
Kai Liu 已提交
730

731
coverage: clean
Y
Yueh-Hsuan Chiang 已提交
732 733 734
	COVERAGEFLAGS="-fprofile-arcs -ftest-coverage" LDFLAGS+="-lgcov" $(MAKE) J=1 all check
	cd coverage && ./coverage_test.sh
        # Delete intermediate files
735
	$(FIND) . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm -f {} \;
J
jorlow@chromium.org 已提交
736

Y
Yi Wu 已提交
737 738 739 740 741
ifneq (,$(filter check parallel_check,$(MAKECMDGOALS)),)
# Use /dev/shm if it has the sticky bit set (otherwise, /tmp),
# and create a randomly-named rocksdb.XXXX directory therein.
# We'll use that directory in the "make check" rules.
ifeq ($(TMPD),)
T
Tomas Kolda 已提交
742 743
TMPDIR := $(shell echo $${TMPDIR:-/tmp})
TMPD := $(shell f=/dev/shm; test -k $$f || f=$(TMPDIR);     \
Y
Yi Wu 已提交
744 745 746 747 748 749 750 751 752 753 754 755 756 757
  perl -le 'use File::Temp "tempdir";'					\
    -e 'print tempdir("'$$f'/rocksdb.XXXX", CLEANUP => 0)')
endif
endif

# Run all tests in parallel, accumulating per-test logs in t/log-*.
#
# Each t/run-* file is a tiny generated bourne shell script that invokes one of
# sub-tests. Why use a file for this?  Because that makes the invocation of
# parallel below simpler, which in turn makes the parsing of parallel's
# LOG simpler (the latter is for live monitoring as parallel
# tests run).
#
# Test names are extracted by running tests with --gtest_list_tests.
758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775
# This filter removes the "#"-introduced comments, and expands to
# fully-qualified names by changing input like this:
#
#   DBTest.
#     Empty
#     WriteEmptyBatch
#   MultiThreaded/MultiThreadedDBTest.
#     MultiThreaded/0  # GetParam() = 0
#     MultiThreaded/1  # GetParam() = 1
#
# into this:
#
#   DBTest.Empty
#   DBTest.WriteEmptyBatch
#   MultiThreaded/MultiThreadedDBTest.MultiThreaded/0
#   MultiThreaded/MultiThreadedDBTest.MultiThreaded/1
#

Y
Yi Wu 已提交
776 777 778 779 780 781 782 783 784 785 786
parallel_tests = $(patsubst %,parallel_%,$(PARALLEL_TEST))
.PHONY: gen_parallel_tests $(parallel_tests)
$(parallel_tests): $(PARALLEL_TEST)
	$(AM_V_at)TEST_BINARY=$(patsubst parallel_%,%,$@); \
  TEST_NAMES=` \
    ./$$TEST_BINARY --gtest_list_tests \
    | perl -n \
      -e 's/ *\#.*//;' \
      -e '/^(\s*)(\S+)/; !$$1 and do {$$p=$$2; break};'	\
      -e 'print qq! $$p$$2!'`; \
	for TEST_NAME in $$TEST_NAMES; do \
787
		TEST_SCRIPT=t/run-$$TEST_BINARY-$${TEST_NAME//\//-}; \
Y
Yi Wu 已提交
788 789 790 791 792
		echo "  GEN     " $$TEST_SCRIPT; \
    printf '%s\n' \
      '#!/bin/sh' \
      "d=\$(TMPD)$$TEST_SCRIPT" \
      'mkdir -p $$d' \
793
      "TEST_TMPDIR=\$$d $(DRIVER) ./$$TEST_BINARY --gtest_filter=$$TEST_NAME" \
Y
Yi Wu 已提交
794 795 796 797 798 799
		> $$TEST_SCRIPT; \
		chmod a=rx $$TEST_SCRIPT; \
	done

gen_parallel_tests:
	$(AM_V_at)mkdir -p t
800
	$(AM_V_at)$(FIND) t -type f -name 'run-*' -exec rm -f {} \;
Y
Yi Wu 已提交
801
	$(MAKE) $(parallel_tests)
802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819

# Reorder input lines (which are one per test) so that the
# longest-running tests appear first in the output.
# Do this by prefixing each selected name with its duration,
# sort the resulting names, and remove the leading numbers.
# FIXME: the "100" we prepend is a fake time, for now.
# FIXME: squirrel away timings from each run and use them
# (when present) on subsequent runs to order these tests.
#
# Without this reordering, these two tests would happen to start only
# after almost all other tests had completed, thus adding 100 seconds
# to the duration of parallel "make check".  That's the difference
# between 4 minutes (old) and 2m20s (new).
#
# 152.120 PASS t/DBTest.FileCreationRandomFailure
# 107.816 PASS t/DBTest.EncodeDecompressedBlockSizeTest
#
slow_test_regexp = \
Y
Yi Wu 已提交
820
	^.*SnapshotConcurrentAccessTest.*$$|^t/run-table_test-HarnessTest.Randomized$$|^t/run-db_test-.*(?:FileCreationRandomFailure|EncodeDecompressedBlockSizeTest)$$|^.*RecoverFromCorruptedWALWithoutFlush$$
821
prioritize_long_running_tests =						\
Y
Yueh-Hsuan Chiang 已提交
822 823 824
  perl -pe 's,($(slow_test_regexp)),100 $$1,'				\
    | sort -k1,1gr							\
    | sed 's/^[.0-9]* //'
825 826 827 828 829 830

# "make check" uses
# Run with "make J=1 check" to disable parallelism in "make check".
# Run with "make J=200% check" to run two parallel jobs per core.
# The default is to run one job per core (J=100%).
# See "man parallel" for its "-j ..." option.
Y
Yi Wu 已提交
831
J ?= 100%
832

V
Venkatesh Radhakrishnan 已提交
833 834 835
# Use this regexp to select the subset of tests whose names match.
tests-regexp = .

836
ifeq ($(PRINT_PARALLEL_OUTPUTS), 1)
837 838 839 840 841
	parallel_com = '{}'
else
	parallel_com = '{} >& t/log-{/}'
endif

842
.PHONY: check_0
Y
Yi Wu 已提交
843 844
check_0:
	$(AM_V_GEN)export TEST_TMPDIR=$(TMPD); \
Y
Yueh-Hsuan Chiang 已提交
845 846 847
	printf '%s\n' ''						\
	  'To monitor subtest <duration,pass/fail,name>,'		\
	  '  run "make watch-log" in a separate window' '';		\
Y
Yi Wu 已提交
848 849 850
	test -t 1 && eta=--eta || eta=; \
	{ \
		printf './%s\n' $(filter-out $(PARALLEL_TEST),$(TESTS)); \
851
		find t -name 'run-*' -print; \
Y
Yi Wu 已提交
852
	} \
Y
Yueh-Hsuan Chiang 已提交
853 854
	  | $(prioritize_long_running_tests)				\
	  | grep -E '$(tests-regexp)'					\
855 856 857 858
	  | build_tools/gnu_parallel -j$(J) --plain --joblog=LOG $$eta --gnu  $(parallel_com) ; \
	parallel_retcode=$$? ; \
	awk '{ if ($$7 != 0 || $$8 != 0) { if ($$7 == "Exitval") { h = $$0; } else { if (!f) print h; print; f = 1 } } } END { if(f) exit 1; }' < LOG ; \
	if [ $$parallel_retcode -ne 0 ] ; then exit 1 ; fi
S
sdong 已提交
859

860
valgrind-exclude-regexp = InlineSkipTest.ConcurrentInsert|TransactionStressTest.DeadlockStress|DBCompactionTest.SuggestCompactRangeNoTwoLevel0Compactions|BackupableDBTest.RateLimiting|DBTest.CloseSpeedup|DBTest.ThreadStatusFlush|DBTest.RateLimitingTest|DBTest.EncodeDecompressedBlockSizeTest|FaultInjectionTest.UninstalledCompaction|HarnessTest.Randomized|ExternalSSTFileTest.CompactDuringAddFileRandom|ExternalSSTFileTest.IngestFileWithGlobalSeqnoRandomized|MySQLStyleTransactionTest.TransactionStressTest
861

S
sdong 已提交
862
.PHONY: valgrind_check_0
Y
Yi Wu 已提交
863
valgrind_check_0:
S
sdong 已提交
864 865 866 867 868 869
	$(AM_V_GEN)export TEST_TMPDIR=$(TMPD);				\
	printf '%s\n' ''						\
	  'To monitor subtest <duration,pass/fail,name>,'		\
	  '  run "make watch-log" in a separate window' '';		\
	test -t 1 && eta=--eta || eta=;					\
	{								\
Y
Yi Wu 已提交
870
	  printf './%s\n' $(filter-out $(PARALLEL_TEST) %skiplist_test options_settable_test, $(TESTS));		\
871
	  find t -name 'run-*' -print; \
S
sdong 已提交
872 873 874
	}								\
	  | $(prioritize_long_running_tests)				\
	  | grep -E '$(tests-regexp)'					\
875
	  | grep -E -v '$(valgrind-exclude-regexp)'					\
876
	  | build_tools/gnu_parallel -j$(J) --plain --joblog=LOG $$eta --gnu \
877 878
	  '(if [[ "{}" == "./"* ]] ; then $(DRIVER) {}; else {}; fi) ' \
	  '>& t/valgrind_log-{/}'
879 880

CLEAN_FILES += t LOG $(TMPD)
881

882 883 884 885 886 887 888 889
# When running parallel "make check", you can monitor its progress
# from another window.
# Run "make watch_LOG" to show the duration,PASS/FAIL,name of parallel
# tests as they are being run.  We sort them so that longer-running ones
# appear at the top of the list and any failing tests remain at the top
# regardless of their duration. As with any use of "watch", hit ^C to
# interrupt.
watch-log:
890
	$(WATCH) --interval=0 'sort -k7,7nr -k4,4gr LOG|$(quoted_perl_command)'
891

892 893 894
dump-log:
	bash -c '$(quoted_perl_command)' < LOG

I
Igor Canadi 已提交
895
# If J != 1 and GNU parallel is installed, run the tests in parallel,
896 897
# via the check_0 rule above.  Otherwise, run them sequentially.
check: all
Y
Yi Wu 已提交
898
	$(MAKE) gen_parallel_tests
Y
Yueh-Hsuan Chiang 已提交
899
	$(AM_V_GEN)if test "$(J)" != 1                                  \
900
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
Y
Yueh-Hsuan Chiang 已提交
901 902 903 904 905
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
	    $(MAKE) T="$$t" TMPD=$(TMPD) check_0;                       \
	else                                                            \
	    for t in $(TESTS); do                                       \
906
	      echo "===== Running $$t (`date`)"; ./$$t || exit 1; done;          \
Y
Yueh-Hsuan Chiang 已提交
907 908
	fi
	rm -rf $(TMPD)
T
Tomas Kolda 已提交
909
ifneq ($(PLATFORM), OS_AIX)
910
	$(PYTHON) tools/check_all_python.py
I
Islam AbdelRahman 已提交
911
ifeq ($(filter -DROCKSDB_LITE,$(OPT)),)
912
ifndef ASSERT_STATUS_CHECKED # not yet working with these tests
913
	$(PYTHON) tools/ldb_test.py
Y
Yueh-Hsuan Chiang 已提交
914
	sh tools/rocksdb_dump_test.sh
I
Islam AbdelRahman 已提交
915
endif
916
endif
917
endif
918
ifndef SKIP_FORMAT_BUCK_CHECKS
919 920
	$(MAKE) check-format
	$(MAKE) check-buck-targets
921
endif
922

S
Siying Dong 已提交
923 924
# TODO add ldb_tests
check_some: $(SUBSET)
925
	for t in $(SUBSET); do echo "===== Running $$t (`date`)"; ./$$t || exit 1; done
926 927

.PHONY: ldb_tests
928
ldb_tests: ldb
929
	$(PYTHON) tools/ldb_test.py
930

I
Igor Canadi 已提交
931
crash_test: whitebox_crash_test blackbox_crash_test
932

933 934
crash_test_with_atomic_flush: whitebox_crash_test_with_atomic_flush blackbox_crash_test_with_atomic_flush

935 936
crash_test_with_txn: whitebox_crash_test_with_txn blackbox_crash_test_with_txn

937 938
crash_test_with_best_efforts_recovery: blackbox_crash_test_with_best_efforts_recovery

939
blackbox_crash_test: db_stress
940 941
	$(PYTHON) -u tools/db_crashtest.py --simple blackbox $(CRASH_TEST_EXT_ARGS)
	$(PYTHON) -u tools/db_crashtest.py blackbox $(CRASH_TEST_EXT_ARGS)
942

943
blackbox_crash_test_with_atomic_flush: db_stress
944
	$(PYTHON) -u tools/db_crashtest.py --cf_consistency blackbox $(CRASH_TEST_EXT_ARGS)
945

946
blackbox_crash_test_with_txn: db_stress
947
	$(PYTHON) -u tools/db_crashtest.py --txn blackbox $(CRASH_TEST_EXT_ARGS)
948

949 950 951
blackbox_crash_test_with_best_efforts_recovery: db_stress
	$(PYTHON) -u tools/db_crashtest.py --test_best_efforts_recovery blackbox $(CRASH_TEST_EXT_ARGS)

952 953 954 955
ifeq ($(CRASH_TEST_KILL_ODD),)
  CRASH_TEST_KILL_ODD=888887
endif

956
whitebox_crash_test: db_stress
957
	$(PYTHON) -u tools/db_crashtest.py --simple whitebox --random_kill_odd \
958
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)
959
	$(PYTHON) -u tools/db_crashtest.py whitebox  --random_kill_odd \
960
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)
961

962
whitebox_crash_test_with_atomic_flush: db_stress
963
	$(PYTHON) -u tools/db_crashtest.py --cf_consistency whitebox  --random_kill_odd \
964 965
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)

966
whitebox_crash_test_with_txn: db_stress
967
	$(PYTHON) -u tools/db_crashtest.py --txn whitebox --random_kill_odd \
968 969
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)

970
asan_check: clean
Y
Yueh-Hsuan Chiang 已提交
971 972
	COMPILE_WITH_ASAN=1 $(MAKE) check -j32
	$(MAKE) clean
973

974
asan_crash_test: clean
Y
Yueh-Hsuan Chiang 已提交
975 976
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test
	$(MAKE) clean
I
Igor Canadi 已提交
977

978
asan_crash_test_with_atomic_flush: clean
979 980 981
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test_with_atomic_flush
	$(MAKE) clean

982
asan_crash_test_with_txn: clean
983 984 985
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test_with_txn
	$(MAKE) clean

986
asan_crash_test_with_best_efforts_recovery: clean
987 988 989
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test_with_best_efforts_recovery
	$(MAKE) clean

990
ubsan_check: clean
991 992 993
	COMPILE_WITH_UBSAN=1 $(MAKE) check -j32
	$(MAKE) clean

994
ubsan_crash_test: clean
995 996 997
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test
	$(MAKE) clean

998
ubsan_crash_test_with_atomic_flush: clean
999 1000 1001
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test_with_atomic_flush
	$(MAKE) clean

1002
ubsan_crash_test_with_txn: clean
1003 1004 1005
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test_with_txn
	$(MAKE) clean

1006
ubsan_crash_test_with_best_efforts_recovery: clean
1007 1008 1009
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test_with_best_efforts_recovery
	$(MAKE) clean

1010
valgrind_test:
1011
	ROCKSDB_VALGRIND_RUN=1 DISABLE_JEMALLOC=1 $(MAKE) valgrind_check
1012

I
Igor Canadi 已提交
1013
valgrind_check: $(TESTS)
1014
	$(MAKE) DRIVER="$(VALGRIND_VER) $(VALGRIND_OPTS)" gen_parallel_tests
S
sdong 已提交
1015
	$(AM_V_GEN)if test "$(J)" != 1                                  \
1016
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
S
sdong 已提交
1017 1018
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
Y
Yi Wu 已提交
1019
      $(MAKE) TMPD=$(TMPD)                                        \
S
sdong 已提交
1020 1021 1022 1023 1024 1025 1026 1027 1028 1029
      DRIVER="$(VALGRIND_VER) $(VALGRIND_OPTS)" valgrind_check_0; \
	else                                                            \
		for t in $(filter-out %skiplist_test options_settable_test,$(TESTS)); do \
			$(VALGRIND_VER) $(VALGRIND_OPTS) ./$$t; \
			ret_code=$$?; \
			if [ $$ret_code -ne 0 ]; then \
				exit $$ret_code; \
			fi; \
		done; \
	fi
1030

1031 1032 1033 1034 1035

ifneq ($(PAR_TEST),)
parloop:
	ret_bad=0;							\
	for t in $(PAR_TEST); do		\
1036
		echo "===== Running $$t in parallel $(NUM_PAR) (`date`)";\
1037
		if [ $(db_test) -eq 1 ]; then \
1038
			seq $(J) | v="$$t" build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{};  export TEST_TMPDIR=$$s;' \
1039 1040
				'timeout 2m ./db_test --gtest_filter=$$v >> $$s/log-{} 2>1'; \
		else\
1041
			seq $(J) | v="./$$t" build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{};' \
1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052
			     'export TEST_TMPDIR=$$s; timeout 10m $$v >> $$s/log-{} 2>1'; \
		fi; \
		ret_code=$$?; \
		if [ $$ret_code -ne 0 ]; then \
			ret_bad=$$ret_code; \
			echo $$t exited with $$ret_code; \
		fi; \
	done; \
	exit $$ret_bad;
endif

Y
Yi Wu 已提交
1053 1054 1055 1056 1057 1058 1059
test_names = \
  ./db_test --gtest_list_tests						\
    | perl -n								\
      -e 's/ *\#.*//;'							\
      -e '/^(\s*)(\S+)/; !$$1 and do {$$p=$$2; break};'			\
      -e 'print qq! $$p$$2!'

1060 1061
parallel_check: $(TESTS)
	$(AM_V_GEN)if test "$(J)" > 1                                  \
1062
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
1063 1064 1065 1066 1067 1068 1069 1070 1071
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
	    echo Running in parallel $(J);			\
	else                                                            \
	    echo "Need to have GNU Parallel and J > 1"; exit 1;		\
	fi;								\
	ret_bad=0;							\
	echo $(J);\
	echo Test Dir: $(TMPD); \
1072
        seq $(J) | build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{}; rm -rf $$s; mkdir $$s'; \
1073
	$(MAKE)  PAR_TEST="$(shell $(test_names))" TMPD=$(TMPD) \
1074 1075 1076 1077
		J=$(J) db_test=1 parloop; \
	$(MAKE) PAR_TEST="$(filter-out db_test, $(TESTS))" \
		TMPD=$(TMPD) J=$(J) db_test=0 parloop;

1078
analyze: clean
1079 1080 1081
	USE_CLANG=1 $(MAKE) analyze_incremental

analyze_incremental:
Y
Yueh-Hsuan Chiang 已提交
1082 1083 1084 1085
	$(CLANG_SCAN_BUILD) --use-analyzer=$(CLANG_ANALYZER) \
		--use-c++=$(CXX) --use-cc=$(CC) --status-bugs \
		-o $(CURDIR)/scan_build_report \
		$(MAKE) dbg
1086

1087 1088
CLEAN_FILES += unity.cc
unity.cc: Makefile
Y
Yueh-Hsuan Chiang 已提交
1089 1090
	rm -f $@ $@-t
	for source_file in $(LIB_SOURCES); do \
E
Evan Shaw 已提交
1091
		echo "#include \"$$source_file\"" >> $@-t; \
Y
Yueh-Hsuan Chiang 已提交
1092 1093 1094
	done
	chmod a=r $@-t
	mv $@-t $@
M
miguelportilla 已提交
1095

1096
unity.a: $(OBJ_DIR)/unity.o
E
Evan Shaw 已提交
1097
	$(AM_V_AR)rm -f $@
1098
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $(OBJ_DIR)/unity.o
E
Evan Shaw 已提交
1099

1100

I
Igor Canadi 已提交
1101
# try compiling db_test with unity
1102
unity_test: $(OBJ_DIR)/db/db_basic_test.o $(OBJ_DIR)/db/db_test_util.o $(TEST_OBJECTS) $(TOOL_OBJECTS) unity.a
I
Igor Canadi 已提交
1103 1104 1105
	$(AM_LINK)
	./unity_test

E
Evan Shaw 已提交
1106 1107
rocksdb.h rocksdb.cc: build_tools/amalgamate.py Makefile $(LIB_SOURCES) unity.cc
	build_tools/amalgamate.py -I. -i./include unity.cc -x include/rocksdb/c.h -H rocksdb.h -o rocksdb.cc
M
miguelportilla 已提交
1108

1109
clean: clean-ext-libraries-all clean-rocks clean-rocksjava
1110

1111
clean-not-downloaded: clean-ext-libraries-bin clean-rocks clean-not-downloaded-rocksjava
1112 1113

clean-rocks:
1114 1115 1116
	echo shared=$(ALL_SHARED_LIBS)
	echo static=$(ALL_STATIC_LIBS)
	rm -f $(BENCHMARKS) $(TOOLS) $(TESTS) $(PARALLEL_TEST) $(ALL_STATIC_LIBS) $(ALL_SHARED_LIBS)
Y
Yueh-Hsuan Chiang 已提交
1117
	rm -rf $(CLEAN_FILES) ios-x86 ios-arm scan_build_report
1118
	$(FIND) . -name "*.[oda]" -exec rm -f {} \;
1119
	$(FIND) . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm -f {} \;
1120 1121

clean-rocksjava:
1122
	rm -rf jl jls
1123 1124 1125 1126
	cd java && $(MAKE) clean

clean-not-downloaded-rocksjava:
	cd java && $(MAKE) clean-not-downloaded
1127

1128 1129 1130 1131 1132 1133
clean-ext-libraries-all:
	rm -rf bzip2* snappy* zlib* lz4* zstd*

clean-ext-libraries-bin:
	find . -maxdepth 1 -type d \( -name bzip2\* -or -name snappy\* -or -name zlib\* -or -name lz4\* -or -name zstd\* \) -prune -exec rm -rf {} \;

1134
tags:
1135
	ctags -R .
1136
	cscope -b `$(FIND) . -name '*.cc'` `$(FIND) . -name '*.h'` `$(FIND) . -name '*.c'`
L
Leonidas Galanis 已提交
1137
	ctags -e -R -o etags *
1138

1139 1140 1141 1142 1143 1144 1145
tags0:
	ctags -R .
	cscope -b `$(FIND) . -name '*.cc' -and ! -name '*_test.cc'` \
		  `$(FIND) . -name '*.c' -and ! -name '*_test.c'` \
		  `$(FIND) . -name '*.h' -and ! -name '*_test.h'`
	ctags -e -R -o etags *

1146
format:
Y
Yueh-Hsuan Chiang 已提交
1147
	build_tools/format-diff.sh
1148

1149 1150 1151 1152 1153 1154
check-format:
	build_tools/format-diff.sh -c

check-buck-targets:
	buckifier/check_buck_targets.sh

1155
package:
Y
Yueh-Hsuan Chiang 已提交
1156
	bash build_tools/make_package.sh $(SHARED_MAJOR).$(SHARED_MINOR)
1157

1158 1159 1160
# ---------------------------------------------------------------------------
# 	Unit tests and tools
# ---------------------------------------------------------------------------
1161 1162 1163
$(STATIC_LIBRARY): $(LIB_OBJECTS)
	$(AM_V_AR)rm -f $@ $(SHARED1) $(SHARED2) $(SHARED3) $(SHARED4)
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $(LIB_OBJECTS)
J
jorlow@chromium.org 已提交
1164

1165 1166
$(STATIC_TEST_LIBRARY): $(TEST_OBJECTS)
	$(AM_V_AR)rm -f $@ $(SHARED_TEST_LIBRARY)
1167 1168
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

1169 1170
$(STATIC_TOOLS_LIBRARY): $(BENCH_OBJECTS) $(TOOL_OBJECTS) $(TESTUTIL)
	$(AM_V_AR)rm -f $@ $(SHARED_TOOLS_LIBRARY)
1171 1172
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

P
Peter Dillinger 已提交
1173
ifeq ($(DEBUG_LEVEL),0)
1174 1175 1176
$(STATIC_STRESS_LIBRARY): $(TESTUTIL) $(ANALYZE_OBJECTS) $(STRESS_OBJECTS)
	$(AM_V_AR)rm -f $@ $(SHARED_STRESS_LIBRARY)
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^
P
Peter Dillinger 已提交
1177 1178 1179 1180 1181
else
$(STATIC_STRESS_LIBRARY): $(TEST_OBJECTS) $(ANALYZE_OBJECTS) $(STRESS_OBJECTS)
	$(AM_V_AR)rm -f $@ $(SHARED_STRESS_LIBRARY)
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^
endif
1182 1183 1184 1185 1186 1187 1188 1189 1190

$(SHARED_TEST_LIBRARY): $(TEST_OBJECTS) $(SHARED1)
	$(AM_V_AR)rm -f $@ $(STATIC_TEST_LIBRARY)
	$(AM_SHARE)

$(SHARED_TOOLS_LIBRARY): $(TOOL_OBJECTS) $(TESTUTIL) $(SHARED1)
	$(AM_V_AR)rm -f $@ $(STATIC_TOOLS_LIBRARY)
	$(AM_SHARE)

1191
$(SHARED_STRESS_LIBRARY): $(ANALYZE_OBJECTS) $(STRESS_OBJECTS) $(STRESS_LIBRARY_RUNTIME_DEPS) $(SHARED1)
1192 1193 1194 1195
	$(AM_V_AR)rm -f $@ $(STATIC_STRESS_LIBRARY)
	$(AM_SHARE)

librocksdb_env_basic_test.a: $(OBJ_DIR)/env/env_basic_test.o $(LIB_OBJECTS) $(TESTHARNESS)
1196 1197 1198
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

1199
db_bench: $(OBJ_DIR)/tools/db_bench.o $(BENCH_OBJECTS) $(TESTUTIL) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1200
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1201

1202
trace_analyzer: $(OBJ_DIR)/tools/trace_analyzer.o $(ANALYZE_OBJECTS) $(TOOLS_LIBRARY) $(LIBRARY)
1203 1204
	$(AM_LINK)

1205
block_cache_trace_analyzer: $(OBJ_DIR)/tools/block_cache_analyzer/block_cache_trace_analyzer_tool.o $(ANALYZE_OBJECTS) $(TOOLS_LIBRARY) $(LIBRARY)
1206 1207
	$(AM_LINK)

1208
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
1209
folly_synchronization_distributed_mutex_test: $(OBJ_DIR)/third-party/folly/folly/synchronization/test/DistributedMutexTest.o $(TEST_LIBRARY) $(LIBRARY)
1210 1211 1212
	$(AM_LINK)
endif

1213
cache_bench: $(OBJ_DIR)/cache/cache_bench.o $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1214
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1215

1216
persistent_cache_bench: $(OBJ_DIR)/utilities/persistent_cache/persistent_cache_bench.o $(LIBRARY)
1217 1218
	$(AM_LINK)

1219
memtablerep_bench: $(OBJ_DIR)/memtable/memtablerep_bench.o $(TESTUTIL) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1220
	$(AM_LINK)
A
Ameya Gupte 已提交
1221

1222
filter_bench: $(OBJ_DIR)/util/filter_bench.o $(LIBRARY)
1223 1224
	$(AM_LINK)

1225
db_stress: $(OBJ_DIR)/db_stress_tool/db_stress.o $(STRESS_LIBRARY) $(STRESS_LIBRARY_RUNTIME_DEPS) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1226
	$(AM_LINK)
P
Peter Dillinger 已提交
1227

1228
write_stress: $(OBJ_DIR)/tools/write_stress.o $(LIBRARY)
I
Igor Canadi 已提交
1229 1230
	$(AM_LINK)

1231
db_sanity_test: $(OBJ_DIR)/tools/db_sanity_test.o $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1232
	$(AM_LINK)
1233

1234
db_repl_stress: $(OBJ_DIR)/tools/db_repl_stress.o $(TESTUTIL) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1235
	$(AM_LINK)
1236

1237
arena_test: $(OBJ_DIR)/memory/arena_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1238
	$(AM_LINK)
1239

1240
memkind_kmem_allocator_test: memory/memkind_kmem_allocator_test.o $(TEST_LIBRARY) $(LIBRARY)
1241
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1242

1243
autovector_test: $(OBJ_DIR)/util/autovector_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1244
	$(AM_LINK)
K
kailiu 已提交
1245

1246
column_family_test: $(OBJ_DIR)/db/column_family_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1247
	$(AM_LINK)
1248

1249
table_properties_collector_test: $(OBJ_DIR)/db/table_properties_collector_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1250
	$(AM_LINK)
1251

1252
bloom_test: $(OBJ_DIR)/util/bloom_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1253
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
1254

1255
dynamic_bloom_test: $(OBJ_DIR)/util/dynamic_bloom_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1256
	$(AM_LINK)
1257

1258
c_test: $(OBJ_DIR)/db/c_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1259
	$(AM_LINK)
1260

1261
cache_test: $(OBJ_DIR)/cache/cache_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1262
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1263

1264
coding_test: $(OBJ_DIR)/util/coding_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1265
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1266

1267
hash_test: $(OBJ_DIR)/util/hash_test.o $(TEST_LIBRARY) $(LIBRARY)
1268 1269
	$(AM_LINK)

1270
random_test: $(OBJ_DIR)/util/random_test.o  $(TEST_LIBRARY) $(LIBRARY)
1271 1272
	$(AM_LINK)

1273
option_change_migration_test: $(OBJ_DIR)/utilities/option_change_migration/option_change_migration_test.o $(TEST_LIBRARY) $(LIBRARY)
1274 1275
	$(AM_LINK)

1276
stringappend_test: $(OBJ_DIR)/utilities/merge_operators/string_append/stringappend_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1277
	$(AM_LINK)
1278

1279
cassandra_format_test: $(OBJ_DIR)/utilities/cassandra/cassandra_format_test.o $(OBJ_DIR)/utilities/cassandra/test_utils.o $(TEST_LIBRARY) $(LIBRARY)
1280 1281
	$(AM_LINK)

1282
cassandra_functional_test: $(OBJ_DIR)/utilities/cassandra/cassandra_functional_test.o $(OBJ_DIR)/utilities/cassandra/test_utils.o $(TEST_LIBRARY) $(LIBRARY)
1283 1284
	$(AM_LINK)

1285
cassandra_row_merge_test: $(OBJ_DIR)/utilities/cassandra/cassandra_row_merge_test.o $(OBJ_DIR)/utilities/cassandra/test_utils.o $(TEST_LIBRARY) $(LIBRARY)
1286 1287
	$(AM_LINK)

1288
cassandra_serialize_test: $(OBJ_DIR)/utilities/cassandra/cassandra_serialize_test.o $(TEST_LIBRARY) $(LIBRARY)
1289 1290
	$(AM_LINK)

1291
hash_table_test: $(OBJ_DIR)/utilities/persistent_cache/hash_table_test.o $(TEST_LIBRARY) $(LIBRARY)
1292 1293
	$(AM_LINK)

1294
histogram_test: $(OBJ_DIR)/monitoring/histogram_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1295
	$(AM_LINK)
A
Abhishek Kona 已提交
1296

1297
thread_local_test: $(OBJ_DIR)/util/thread_local_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1298
	$(AM_LINK)
L
Lei Jin 已提交
1299

1300
work_queue_test: $(OBJ_DIR)/util/work_queue_test.o $(TEST_LIBRARY) $(LIBRARY)
1301 1302
	$(AM_LINK)

1303
corruption_test: $(OBJ_DIR)/db/corruption_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1304
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1305

1306
crc32c_test: $(OBJ_DIR)/util/crc32c_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1307
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1308

1309
slice_test: $(OBJ_DIR)/util/slice_test.o $(TEST_LIBRARY) $(LIBRARY)
1310 1311
	$(AM_LINK)

1312
slice_transform_test: $(OBJ_DIR)/util/slice_transform_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1313
	$(AM_LINK)
1314

1315
db_basic_test: $(OBJ_DIR)/db/db_basic_test.o $(TEST_LIBRARY) $(LIBRARY)
E
Ewout Prangsma 已提交
1316 1317
	$(AM_LINK)

1318
db_with_timestamp_basic_test: $(OBJ_DIR)/db/db_with_timestamp_basic_test.o $(TEST_LIBRARY) $(LIBRARY)
1319 1320
	$(AM_LINK)

1321
db_with_timestamp_compaction_test: db/db_with_timestamp_compaction_test.o $(TEST_LIBRARY) $(LIBRARY)
1322 1323
	$(AM_LINK)

1324
db_encryption_test: $(OBJ_DIR)/db/db_encryption_test.o $(TEST_LIBRARY) $(LIBRARY)
1325 1326
	$(AM_LINK)

1327
db_test: $(OBJ_DIR)/db/db_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yueh-Hsuan Chiang 已提交
1328
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1329

1330
db_test2: $(OBJ_DIR)/db/db_test2.o $(TEST_LIBRARY) $(LIBRARY)
1331 1332
	$(AM_LINK)

1333
db_logical_block_size_cache_test: $(OBJ_DIR)/db/db_logical_block_size_cache_test.o $(TEST_LIBRARY) $(LIBRARY)
1334 1335
	$(AM_LINK)

1336
db_blob_index_test: $(OBJ_DIR)/db/blob/db_blob_index_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1337 1338
	$(AM_LINK)

1339
db_block_cache_test: $(OBJ_DIR)/db/db_block_cache_test.o $(TEST_LIBRARY) $(LIBRARY)
1340 1341
	$(AM_LINK)

1342
db_bloom_filter_test: $(OBJ_DIR)/db/db_bloom_filter_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1343 1344
	$(AM_LINK)

1345
db_log_iter_test: $(OBJ_DIR)/db/db_log_iter_test.o $(TEST_LIBRARY) $(LIBRARY)
1346
	$(AM_LINK)
1347

1348
db_compaction_filter_test: $(OBJ_DIR)/db/db_compaction_filter_test.o $(TEST_LIBRARY) $(LIBRARY)
1349 1350
	$(AM_LINK)

1351
db_compaction_test: $(OBJ_DIR)/db/db_compaction_test.o $(TEST_LIBRARY) $(LIBRARY)
1352 1353
	$(AM_LINK)

1354
db_dynamic_level_test: $(OBJ_DIR)/db/db_dynamic_level_test.o $(TEST_LIBRARY) $(LIBRARY)
1355 1356
	$(AM_LINK)

1357
db_flush_test: $(OBJ_DIR)/db/db_flush_test.o $(TEST_LIBRARY) $(LIBRARY)
1358 1359
	$(AM_LINK)

1360
db_inplace_update_test: $(OBJ_DIR)/db/db_inplace_update_test.o $(TEST_LIBRARY) $(LIBRARY)
1361 1362
	$(AM_LINK)

1363
db_iterator_test: $(OBJ_DIR)/db/db_iterator_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1364 1365
	$(AM_LINK)

1366
db_memtable_test: $(OBJ_DIR)/db/db_memtable_test.o $(TEST_LIBRARY) $(LIBRARY)
1367 1368
	$(AM_LINK)

1369
db_merge_operator_test: $(OBJ_DIR)/db/db_merge_operator_test.o $(TEST_LIBRARY) $(LIBRARY)
1370 1371
	$(AM_LINK)

1372
db_merge_operand_test: $(OBJ_DIR)/db/db_merge_operand_test.o $(TEST_LIBRARY) $(LIBRARY)
1373
	$(AM_LINK)
1374

1375
db_options_test: $(OBJ_DIR)/db/db_options_test.o $(TEST_LIBRARY) $(LIBRARY)
1376 1377
	$(AM_LINK)

1378
db_range_del_test: $(OBJ_DIR)/db/db_range_del_test.o $(TEST_LIBRARY) $(LIBRARY)
1379 1380
	$(AM_LINK)

1381
db_sst_test: $(OBJ_DIR)/db/db_sst_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1382 1383
	$(AM_LINK)

1384
db_statistics_test: $(OBJ_DIR)/db/db_statistics_test.o $(TEST_LIBRARY) $(LIBRARY)
1385 1386
	$(AM_LINK)

1387
db_write_test: $(OBJ_DIR)/db/db_write_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1388 1389
	$(AM_LINK)

1390
error_handler_fs_test: $(OBJ_DIR)/db/error_handler_fs_test.o $(TEST_LIBRARY) $(LIBRARY)
1391 1392
	$(AM_LINK)

1393
external_sst_file_basic_test: $(OBJ_DIR)/db/external_sst_file_basic_test.o $(TEST_LIBRARY) $(LIBRARY)
S
Siying Dong 已提交
1394 1395
	$(AM_LINK)

1396
external_sst_file_test: $(OBJ_DIR)/db/external_sst_file_test.o $(TEST_LIBRARY) $(LIBRARY)
1397 1398
	$(AM_LINK)

1399
import_column_family_test: $(OBJ_DIR)/db/import_column_family_test.o $(TEST_LIBRARY) $(LIBRARY)
1400 1401
	$(AM_LINK)

1402
db_tailing_iter_test: $(OBJ_DIR)/db/db_tailing_iter_test.o $(TEST_LIBRARY) $(LIBRARY)
1403 1404
	$(AM_LINK)

1405
db_iter_test: $(OBJ_DIR)/db/db_iter_test.o $(TEST_LIBRARY) $(LIBRARY)
1406
	$(AM_LINK)
S
Stanislau Hlebik 已提交
1407

1408
db_iter_stress_test: $(OBJ_DIR)/db/db_iter_stress_test.o $(TEST_LIBRARY) $(LIBRARY)
1409 1410
	$(AM_LINK)

1411
db_universal_compaction_test: $(OBJ_DIR)/db/db_universal_compaction_test.o $(TEST_LIBRARY) $(LIBRARY)
1412 1413
	$(AM_LINK)

1414
db_wal_test: $(OBJ_DIR)/db/db_wal_test.o $(TEST_LIBRARY) $(LIBRARY)
S
sdong 已提交
1415 1416
	$(AM_LINK)

1417
db_io_failure_test: $(OBJ_DIR)/db/db_io_failure_test.o $(TEST_LIBRARY) $(LIBRARY)
O
omegaga 已提交
1418 1419
	$(AM_LINK)

1420
db_properties_test: $(OBJ_DIR)/db/db_properties_test.o $(TEST_LIBRARY) $(LIBRARY)
1421 1422
	$(AM_LINK)

1423
db_table_properties_test: $(OBJ_DIR)/db/db_table_properties_test.o $(TEST_LIBRARY) $(LIBRARY)
1424 1425
	$(AM_LINK)

1426
log_write_bench: $(OBJ_DIR)/util/log_write_bench.o $(TEST_LIBRARY) $(LIBRARY)
D
dx9 已提交
1427
	$(AM_LINK) $(PROFILING_FLAGS)
1428

1429
plain_table_db_test: $(OBJ_DIR)/db/plain_table_db_test.o $(TEST_LIBRARY) $(LIBRARY)
1430
	$(AM_LINK)
S
Siying Dong 已提交
1431

1432
comparator_db_test: $(OBJ_DIR)/db/comparator_db_test.o $(TEST_LIBRARY) $(LIBRARY)
1433
	$(AM_LINK)
1434

1435
table_reader_bench: $(OBJ_DIR)/table/table_reader_bench.o $(TEST_LIBRARY) $(LIBRARY)
D
dx9 已提交
1436
	$(AM_LINK) $(PROFILING_FLAGS)
1437

1438 1439
perf_context_test: $(OBJ_DIR)/db/perf_context_test.o $(TEST_LIBRARY) $(LIBRARY)
	$(AM_LINK)
1440

1441 1442
prefix_test: $(OBJ_DIR)/db/prefix_test.o $(TEST_LIBRARY) $(LIBRARY)
	$(AM_LINK)
H
Haobo Xu 已提交
1443

1444
backupable_db_test: $(OBJ_DIR)/utilities/backupable/backupable_db_test.o $(TEST_LIBRARY) $(LIBRARY)
1445
	$(AM_LINK)
I
Igor Canadi 已提交
1446

1447
checkpoint_test: $(OBJ_DIR)/utilities/checkpoint/checkpoint_test.o $(TEST_LIBRARY) $(LIBRARY)
1448 1449
	$(AM_LINK)

1450
cache_simulator_test: $(OBJ_DIR)/utilities/simulator_cache/cache_simulator_test.o $(TEST_LIBRARY) $(LIBRARY)
1451 1452
	$(AM_LINK)

1453
sim_cache_test: $(OBJ_DIR)/utilities/simulator_cache/sim_cache_test.o $(TEST_LIBRARY) $(LIBRARY)
1454 1455
	$(AM_LINK)

1456
env_mirror_test: $(OBJ_DIR)/utilities/env_mirror_test.o $(TEST_LIBRARY) $(LIBRARY)
S
Sage Weil 已提交
1457 1458
	$(AM_LINK)

1459
env_timed_test: $(OBJ_DIR)/utilities/env_timed_test.o $(TEST_LIBRARY) $(LIBRARY)
A
Andrew Kryczka 已提交
1460 1461
	$(AM_LINK)

1462
ifdef ROCKSDB_USE_LIBRADOS
1463 1464
env_librados_test: $(OBJ_DIR)/utilities/env_librados_test.o $(TEST_LIBRARY) $(LIBRARY)
	$(AM_LINK)
1465 1466
endif

1467
object_registry_test: $(OBJ_DIR)/utilities/object_registry_test.o $(TEST_LIBRARY) $(LIBRARY)
1468 1469
	$(AM_LINK)

1470
ttl_test: $(OBJ_DIR)/utilities/ttl/ttl_test.o $(TEST_LIBRARY) $(LIBRARY)
1471
	$(AM_LINK)
1472

1473
write_batch_with_index_test: $(OBJ_DIR)/utilities/write_batch_with_index/write_batch_with_index_test.o $(TEST_LIBRARY) $(LIBRARY)
1474
	$(AM_LINK)
1475

1476
flush_job_test: $(OBJ_DIR)/db/flush_job_test.o $(TEST_LIBRARY) $(LIBRARY)
1477
	$(AM_LINK)
A
Andres Noetzli 已提交
1478

1479
compaction_iterator_test: $(OBJ_DIR)/db/compaction/compaction_iterator_test.o $(TEST_LIBRARY) $(LIBRARY)
A
Andres Noetzli 已提交
1480
	$(AM_LINK)
I
Igor Canadi 已提交
1481

1482
compaction_job_test: $(OBJ_DIR)/db/compaction/compaction_job_test.o $(TEST_LIBRARY) $(LIBRARY)
1483
	$(AM_LINK)
I
Igor Canadi 已提交
1484

1485
compaction_job_stats_test: $(OBJ_DIR)/db/compaction/compaction_job_stats_test.o $(TEST_LIBRARY) $(LIBRARY)
1486 1487
	$(AM_LINK)

1488
compact_on_deletion_collector_test: $(OBJ_DIR)/utilities/table_properties_collectors/compact_on_deletion_collector_test.o $(TEST_LIBRARY) $(LIBRARY)
1489 1490
	$(AM_LINK)

1491
wal_manager_test: $(OBJ_DIR)/db/wal_manager_test.o $(TEST_LIBRARY) $(LIBRARY)
1492
	$(AM_LINK)
I
Igor Canadi 已提交
1493

1494
dbformat_test: $(OBJ_DIR)/db/dbformat_test.o $(TEST_LIBRARY) $(LIBRARY)
1495
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1496

1497
env_basic_test: $(OBJ_DIR)/env/env_basic_test.o $(TEST_LIBRARY) $(LIBRARY)
1498 1499
	$(AM_LINK)

1500
env_test: $(OBJ_DIR)/env/env_test.o $(TEST_LIBRARY) $(LIBRARY)
1501
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1502

1503
io_posix_test: $(OBJ_DIR)/env/io_posix_test.o $(TEST_LIBRARY) $(LIBRARY)
1504 1505
	$(AM_LINK)

1506
fault_injection_test: $(OBJ_DIR)/db/fault_injection_test.o $(TEST_LIBRARY) $(LIBRARY)
1507
	$(AM_LINK)
1508

1509
rate_limiter_test: $(OBJ_DIR)/util/rate_limiter_test.o $(TEST_LIBRARY) $(LIBRARY)
1510
	$(AM_LINK)
L
Lei Jin 已提交
1511

1512
delete_scheduler_test: $(OBJ_DIR)/file/delete_scheduler_test.o $(TEST_LIBRARY) $(LIBRARY)
I
Islam AbdelRahman 已提交
1513 1514
	$(AM_LINK)

1515
filename_test: $(OBJ_DIR)/db/filename_test.o $(TEST_LIBRARY) $(LIBRARY)
1516
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1517

1518
random_access_file_reader_test: $(OBJ_DIR)/file/random_access_file_reader_test.o $(TEST_LIBRARY) $(LIBRARY)
1519 1520
	$(AM_LINK)

1521
file_reader_writer_test: $(OBJ_DIR)/util/file_reader_writer_test.o $(TEST_LIBRARY) $(LIBRARY)
1522 1523
	$(AM_LINK)

1524
block_based_filter_block_test: $(OBJ_DIR)/table/block_based/block_based_filter_block_test.o $(TEST_LIBRARY) $(LIBRARY)
1525
	$(AM_LINK)
1526

1527
block_based_table_reader_test: table/block_based/block_based_table_reader_test.o $(TEST_LIBRARY) $(LIBRARY)
1528 1529
	$(AM_LINK)

1530
full_filter_block_test: $(OBJ_DIR)/table/block_based/full_filter_block_test.o $(TEST_LIBRARY) $(LIBRARY)
1531
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
1532

1533
partitioned_filter_block_test: $(OBJ_DIR)/table/block_based/partitioned_filter_block_test.o $(TEST_LIBRARY) $(LIBRARY)
M
Maysam Yabandeh 已提交
1534 1535
	$(AM_LINK)

1536
log_test: $(OBJ_DIR)/db/log_test.o $(TEST_LIBRARY) $(LIBRARY)
M
Maysam Yabandeh 已提交
1537 1538
	$(AM_LINK)

1539
cleanable_test: $(OBJ_DIR)/table/cleanable_test.o $(TEST_LIBRARY) $(LIBRARY)
1540
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1541

1542
table_test: $(OBJ_DIR)/table/table_test.o $(TEST_LIBRARY) $(LIBRARY)
1543
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1544

1545
block_fetcher_test: table/block_fetcher_test.o $(TEST_LIBRARY) $(LIBRARY)
1546 1547
	$(AM_LINK)

1548
block_test: $(OBJ_DIR)/table/block_based/block_test.o $(TEST_LIBRARY) $(LIBRARY)
1549
	$(AM_LINK)
D
Dhruba Borthakur 已提交
1550

1551
data_block_hash_index_test: $(OBJ_DIR)/table/block_based/data_block_hash_index_test.o $(TEST_LIBRARY) $(LIBRARY)
1552 1553
	$(AM_LINK)

1554
inlineskiplist_test: $(OBJ_DIR)/memtable/inlineskiplist_test.o $(TEST_LIBRARY) $(LIBRARY)
N
Nathan Bronson 已提交
1555 1556
	$(AM_LINK)

1557
skiplist_test: $(OBJ_DIR)/memtable/skiplist_test.o $(TEST_LIBRARY) $(LIBRARY)
1558
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1559

1560
write_buffer_manager_test: $(OBJ_DIR)/memtable/write_buffer_manager_test.o $(TEST_LIBRARY) $(LIBRARY)
1561 1562
	$(AM_LINK)

1563
version_edit_test: $(OBJ_DIR)/db/version_edit_test.o $(TEST_LIBRARY) $(LIBRARY)
1564
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1565

1566
version_set_test: $(OBJ_DIR)/db/version_set_test.o $(TEST_LIBRARY) $(LIBRARY)
1567
	$(AM_LINK)
1568

1569
compaction_picker_test: $(OBJ_DIR)/db/compaction/compaction_picker_test.o $(TEST_LIBRARY) $(LIBRARY)
1570
	$(AM_LINK)
S
sdong 已提交
1571

1572
version_builder_test: $(OBJ_DIR)/db/version_builder_test.o $(TEST_LIBRARY) $(LIBRARY)
1573
	$(AM_LINK)
S
sdong 已提交
1574

1575
file_indexer_test: $(OBJ_DIR)/db/file_indexer_test.o $(TEST_LIBRARY) $(LIBRARY)
1576
	$(AM_LINK)
1577

1578
reduce_levels_test: $(OBJ_DIR)/tools/reduce_levels_test.o $(TOOLS_LIBRARY) $(TEST_LIBRARY) $(LIBRARY)
1579
	$(AM_LINK)
1580

1581
write_batch_test: $(OBJ_DIR)/db/write_batch_test.o $(TEST_LIBRARY) $(LIBRARY)
1582
	$(AM_LINK)
1583

1584
write_controller_test: $(OBJ_DIR)/db/write_controller_test.o $(TEST_LIBRARY) $(LIBRARY)
1585
	$(AM_LINK)
1586

1587
merge_helper_test: $(OBJ_DIR)/db/merge_helper_test.o $(TEST_LIBRARY) $(LIBRARY)
1588 1589
	$(AM_LINK)

1590
memory_test: $(OBJ_DIR)/utilities/memory/memory_test.o $(TEST_LIBRARY) $(LIBRARY)
1591 1592
	$(AM_LINK)

1593
merge_test: $(OBJ_DIR)/db/merge_test.o $(TEST_LIBRARY) $(LIBRARY)
1594
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1595

1596
merger_test: $(OBJ_DIR)/table/merger_test.o $(TEST_LIBRARY) $(LIBRARY)
1597
	$(AM_LINK)
I
Igor Canadi 已提交
1598

1599
util_merge_operators_test: $(OBJ_DIR)/utilities/util_merge_operators_test.o $(TEST_LIBRARY) $(LIBRARY)
1600 1601
	$(AM_LINK)

1602
options_file_test: $(OBJ_DIR)/db/options_file_test.o $(TEST_LIBRARY) $(LIBRARY)
1603 1604
	$(AM_LINK)

1605
deletefile_test: $(OBJ_DIR)/db/deletefile_test.o $(TEST_LIBRARY) $(LIBRARY)
1606
	$(AM_LINK)
1607

1608
obsolete_files_test: $(OBJ_DIR)/db/obsolete_files_test.o $(TEST_LIBRARY) $(LIBRARY)
1609 1610
	$(AM_LINK)

1611
rocksdb_dump: $(OBJ_DIR)/tools/dump/rocksdb_dump.o $(LIBRARY)
1612 1613
	$(AM_LINK)

1614
rocksdb_undump: $(OBJ_DIR)/tools/dump/rocksdb_undump.o $(LIBRARY)
1615 1616
	$(AM_LINK)

1617
cuckoo_table_builder_test: $(OBJ_DIR)/table/cuckoo/cuckoo_table_builder_test.o $(TEST_LIBRARY) $(LIBRARY)
1618
	$(AM_LINK)
1619

1620
cuckoo_table_reader_test: $(OBJ_DIR)/table/cuckoo/cuckoo_table_reader_test.o $(TEST_LIBRARY) $(LIBRARY)
1621
	$(AM_LINK)
1622

1623
cuckoo_table_db_test: $(OBJ_DIR)/db/cuckoo_table_db_test.o $(TEST_LIBRARY) $(LIBRARY)
1624
	$(AM_LINK)
1625

1626
listener_test: $(OBJ_DIR)/db/listener_test.o $(TEST_LIBRARY) $(LIBRARY)
1627
	$(AM_LINK)
1628

1629
thread_list_test: $(OBJ_DIR)/util/thread_list_test.o $(TEST_LIBRARY) $(LIBRARY)
1630
	$(AM_LINK)
Y
Yueh-Hsuan Chiang 已提交
1631

1632
compact_files_test: $(OBJ_DIR)/db/compact_files_test.o $(TEST_LIBRARY) $(LIBRARY)
1633 1634
	$(AM_LINK)

1635
options_test: $(OBJ_DIR)/options/options_test.o $(TEST_LIBRARY) $(LIBRARY)
1636 1637
	$(AM_LINK)

1638
options_settable_test: $(OBJ_DIR)/options/options_settable_test.o $(TEST_LIBRARY) $(LIBRARY)
1639
	$(AM_LINK)
1640

1641
options_util_test: $(OBJ_DIR)/utilities/options/options_util_test.o $(TEST_LIBRARY) $(LIBRARY)
1642 1643
	$(AM_LINK)

1644
db_bench_tool_test: $(OBJ_DIR)/tools/db_bench_tool_test.o $(BENCH_OBJECTS) $(TEST_LIBRARY) $(LIBRARY)
1645 1646
	$(AM_LINK)

1647
trace_analyzer_test: $(OBJ_DIR)/tools/trace_analyzer_test.o $(ANALYZE_OBJECTS) $(TOOLS_LIBRARY) $(TEST_LIBRARY) $(LIBRARY)
Z
Zhichao Cao 已提交
1648 1649
	$(AM_LINK)

1650
event_logger_test: $(OBJ_DIR)/logging/event_logger_test.o $(TEST_LIBRARY) $(LIBRARY)
I
Igor Canadi 已提交
1651 1652
	$(AM_LINK)

1653
timer_queue_test: $(OBJ_DIR)/util/timer_queue_test.o $(TEST_LIBRARY) $(LIBRARY)
A
Anirban Rahut 已提交
1654 1655
	$(AM_LINK)

1656
sst_dump_test: $(OBJ_DIR)/tools/sst_dump_test.o $(TOOLS_LIBRARY) $(TEST_LIBRARY) $(LIBRARY)
1657
	$(AM_LINK)
1658

1659
optimistic_transaction_test: $(OBJ_DIR)/utilities/transactions/optimistic_transaction_test.o  $(TEST_LIBRARY) $(LIBRARY)
A
agiardullo 已提交
1660 1661
	$(AM_LINK)

1662
mock_env_test : $(OBJ_DIR)/env/mock_env_test.o $(TEST_LIBRARY) $(LIBRARY)
1663
	$(AM_LINK)
1664

1665
manual_compaction_test: $(OBJ_DIR)/db/manual_compaction_test.o $(TEST_LIBRARY) $(LIBRARY)
1666
	$(AM_LINK)
1667

1668
filelock_test: $(OBJ_DIR)/util/filelock_test.o $(TEST_LIBRARY) $(LIBRARY)
1669
	$(AM_LINK)
K
Kai Liu 已提交
1670

1671
auto_roll_logger_test: $(OBJ_DIR)/logging/auto_roll_logger_test.o $(TEST_LIBRARY) $(LIBRARY)
1672
	$(AM_LINK)
1673

1674
env_logger_test: $(OBJ_DIR)/logging/env_logger_test.o $(TEST_LIBRARY) $(LIBRARY)
1675 1676
	$(AM_LINK)

1677
memtable_list_test: $(OBJ_DIR)/db/memtable_list_test.o $(TEST_LIBRARY) $(LIBRARY)
A
agiardullo 已提交
1678 1679
	$(AM_LINK)

1680
write_callback_test: $(OBJ_DIR)/db/write_callback_test.o $(TEST_LIBRARY) $(LIBRARY)
A
agiardullo 已提交
1681 1682
	$(AM_LINK)

1683
heap_test: $(OBJ_DIR)/util/heap_test.o $(GTEST)
1684 1685
	$(AM_LINK)

1686
transaction_lock_mgr_test: utilities/transactions/transaction_lock_mgr_test.o $(TEST_LIBRARY) $(LIBRARY)
1687 1688
	$(AM_LINK)

1689
transaction_test: $(OBJ_DIR)/utilities/transactions/transaction_test.o $(TEST_LIBRARY) $(LIBRARY)
A
agiardullo 已提交
1690 1691
	$(AM_LINK)

1692
write_prepared_transaction_test: $(OBJ_DIR)/utilities/transactions/write_prepared_transaction_test.o $(TEST_LIBRARY) $(LIBRARY)
1693 1694
	$(AM_LINK)

1695
write_unprepared_transaction_test: $(OBJ_DIR)/utilities/transactions/write_unprepared_transaction_test.o $(TEST_LIBRARY) $(LIBRARY)
1696 1697
	$(AM_LINK)

1698
sst_dump: $(OBJ_DIR)/tools/sst_dump.o $(TOOLS_LIBRARY) $(LIBRARY)
1699
	$(AM_LINK)
1700

1701
blob_dump: $(OBJ_DIR)/tools/blob_dump.o $(TOOLS_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1702 1703
	$(AM_LINK)

1704
repair_test: $(OBJ_DIR)/db/repair_test.o $(TEST_LIBRARY) $(LIBRARY)
A
Andrew Kryczka 已提交
1705 1706
	$(AM_LINK)

1707
ldb_cmd_test: $(OBJ_DIR)/tools/ldb_cmd_test.o $(TOOLS_LIBRARY) $(TEST_LIBRARY) $(LIBRARY)
1708 1709
	$(AM_LINK)

1710
ldb: $(OBJ_DIR)/tools/ldb.o $(TOOLS_LIBRARY) $(LIBRARY)
1711
	$(AM_LINK)
1712

1713
iostats_context_test: $(OBJ_DIR)/monitoring/iostats_context_test.o $(TEST_LIBRARY) $(LIBRARY)
1714 1715
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)

1716
persistent_cache_test: $(OBJ_DIR)/utilities/persistent_cache/persistent_cache_test.o $(TEST_LIBRARY) $(LIBRARY)
1717 1718
	$(AM_LINK)

1719
statistics_test: $(OBJ_DIR)/monitoring/statistics_test.o $(TEST_LIBRARY) $(LIBRARY)
1720 1721
	$(AM_LINK)

1722
stats_history_test: $(OBJ_DIR)/monitoring/stats_history_test.o $(TEST_LIBRARY) $(LIBRARY)
1723 1724
	$(AM_LINK)

1725
lru_cache_test: $(OBJ_DIR)/cache/lru_cache_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1726 1727
	$(AM_LINK)

1728
range_del_aggregator_test: $(OBJ_DIR)/db/range_del_aggregator_test.o $(TEST_LIBRARY) $(LIBRARY)
A
Andrew Kryczka 已提交
1729 1730
	$(AM_LINK)

1731
range_del_aggregator_bench: $(OBJ_DIR)/db/range_del_aggregator_bench.o $(LIBRARY)
1732 1733
	$(AM_LINK)

1734
blob_db_test: $(OBJ_DIR)/utilities/blob_db/blob_db_test.o $(TEST_LIBRARY) $(LIBRARY)
Y
Yi Wu 已提交
1735 1736
	$(AM_LINK)

1737
repeatable_thread_test: $(OBJ_DIR)/util/repeatable_thread_test.o $(TEST_LIBRARY) $(LIBRARY)
1738 1739
	$(AM_LINK)

1740
range_tombstone_fragmenter_test: $(OBJ_DIR)/db/range_tombstone_fragmenter_test.o $(TEST_LIBRARY) $(LIBRARY)
1741 1742
	$(AM_LINK)

1743
sst_file_reader_test: $(OBJ_DIR)/table/sst_file_reader_test.o $(TEST_LIBRARY) $(LIBRARY)
1744 1745
	$(AM_LINK)

1746
db_secondary_test: $(OBJ_DIR)/db/db_impl/db_secondary_test.o $(TEST_LIBRARY) $(LIBRARY)
1747 1748
	$(AM_LINK)

1749
block_cache_tracer_test: $(OBJ_DIR)/trace_replay/block_cache_tracer_test.o $(TEST_LIBRARY) $(LIBRARY)
H
haoyuhuang 已提交
1750 1751
	$(AM_LINK)

1752
block_cache_trace_analyzer_test: $(OBJ_DIR)/tools/block_cache_analyzer/block_cache_trace_analyzer_test.o $(OBJ_DIR)/tools/block_cache_analyzer/block_cache_trace_analyzer.o $(TEST_LIBRARY) $(LIBRARY)
1753 1754
	$(AM_LINK)

1755
defer_test: $(OBJ_DIR)/util/defer_test.o $(TEST_LIBRARY) $(LIBRARY)
C
Cheng Chang 已提交
1756 1757
	$(AM_LINK)

1758
blob_file_addition_test: $(OBJ_DIR)/db/blob/blob_file_addition_test.o $(TEST_LIBRARY) $(LIBRARY)
1759 1760
	$(AM_LINK)

1761
blob_file_garbage_test: $(OBJ_DIR)/db/blob/blob_file_garbage_test.o $(TEST_LIBRARY) $(LIBRARY)
1762 1763
	$(AM_LINK)

1764
timer_test: $(OBJ_DIR)/util/timer_test.o $(TEST_LIBRARY) $(LIBRARY)
1765 1766
	$(AM_LINK)

1767
testutil_test: $(OBJ_DIR)/test_util/testutil_test.o $(TEST_LIBRARY) $(LIBRARY)
1768
	$(AM_LINK)
1769 1770

io_tracer_test: $(OBJ_DIR)/trace_replay/io_tracer_test.o $(OBJ_DIR)/trace_replay/io_tracer.o $(TEST_LIBRARY) $(LIBRARY)
1771
	$(AM_LINK)
1772

I
Igor Canadi 已提交
1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784 1785 1786
#-------------------------------------------------
# make install related stuff
INSTALL_PATH ?= /usr/local

uninstall:
	rm -rf $(INSTALL_PATH)/include/rocksdb \
	  $(INSTALL_PATH)/lib/$(LIBRARY) \
	  $(INSTALL_PATH)/lib/$(SHARED4) \
	  $(INSTALL_PATH)/lib/$(SHARED3) \
	  $(INSTALL_PATH)/lib/$(SHARED2) \
	  $(INSTALL_PATH)/lib/$(SHARED1)

install-headers:
	install -d $(INSTALL_PATH)/lib
1787
	for header_dir in `$(FIND) "include/rocksdb" -type d`; do \
I
Igor Canadi 已提交
1788 1789
		install -d $(INSTALL_PATH)/$$header_dir; \
	done
1790
	for header in `$(FIND) "include/rocksdb" -type f -name *.h`; do \
I
Igor Canadi 已提交
1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804
		install -C -m 644 $$header $(INSTALL_PATH)/$$header; \
	done

install-static: install-headers $(LIBRARY)
	install -C -m 755 $(LIBRARY) $(INSTALL_PATH)/lib

install-shared: install-headers $(SHARED4)
	install -C -m 755 $(SHARED4) $(INSTALL_PATH)/lib && \
		ln -fs $(SHARED4) $(INSTALL_PATH)/lib/$(SHARED3) && \
		ln -fs $(SHARED4) $(INSTALL_PATH)/lib/$(SHARED2) && \
		ln -fs $(SHARED4) $(INSTALL_PATH)/lib/$(SHARED1)

# install static by default + install shared if it exists
install: install-static
I
Igor Canadi 已提交
1805
	[ -e $(SHARED4) ] && $(MAKE) install-shared || :
I
Igor Canadi 已提交
1806 1807 1808 1809

#-------------------------------------------------


1810 1811 1812 1813
# ---------------------------------------------------------------------------
# Jni stuff
# ---------------------------------------------------------------------------

1814
JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/linux
D
David Bernard 已提交
1815 1816
ifeq ($(PLATFORM), OS_SOLARIS)
	ARCH := $(shell isainfo -b)
1817
else ifeq ($(PLATFORM), OS_OPENBSD)
1818
	ifneq (,$(filter amd64 ppc64 ppc64le arm64 aarch64 sparc64, $(MACHINE)))
1819 1820 1821 1822
		ARCH := 64
	else
		ARCH := 32
	endif
D
David Bernard 已提交
1823 1824 1825
else
	ARCH := $(shell getconf LONG_BIT)
endif
1826

1827 1828 1829 1830 1831 1832 1833 1834 1835 1836 1837
ifeq ($(shell ldd /usr/bin/env 2>/dev/null | grep -q musl; echo $$?),0)
        JNI_LIBC = musl
# GNU LibC (or glibc) is so pervasive we can assume it is the default
# else
#        JNI_LIBC = glibc
endif

ifneq ($(origin JNI_LIBC), undefined)
  JNI_LIBC_POSTFIX = -$(JNI_LIBC)
endif

1838
ifneq (,$(filter ppc% arm64 aarch64 sparc64, $(MACHINE)))
1839
	ROCKSDBJNILIB = librocksdbjni-linux-$(MACHINE)$(JNI_LIBC_POSTFIX).so
1840
else
1841
	ROCKSDBJNILIB = librocksdbjni-linux$(ARCH)$(JNI_LIBC_POSTFIX).so
1842
endif
1843
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux$(ARCH)$(JNI_LIBC_POSTFIX).jar
1844
ROCKSDB_JAR_ALL = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
C
Chris Riccomini 已提交
1845
ROCKSDB_JAVADOCS_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar
1846
ROCKSDB_SOURCES_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar
1847 1848
SHA256_CMD = sha256sum

T
Tomas Kolda 已提交
1849 1850 1851
ZLIB_VER ?= 1.2.11
ZLIB_SHA256 ?= c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1
ZLIB_DOWNLOAD_BASE ?= http://zlib.net
1852 1853 1854
BZIP2_VER ?= 1.0.8
BZIP2_SHA256 ?= ab5a03176ee106d3f0fa90e381da478ddae405918153cca248e682cd0c4a2269
BZIP2_DOWNLOAD_BASE ?= https://sourceware.org/pub/bzip2
1855 1856
SNAPPY_VER ?= 1.1.8
SNAPPY_SHA256 ?= 16b677f07832a612b0836178db7f374e414f94657c138e6993cbfc5dcc58651f
1857
SNAPPY_DOWNLOAD_BASE ?= https://github.com/google/snappy/archive
1858 1859
LZ4_VER ?= 1.9.2
LZ4_SHA256 ?= 658ba6191fa44c92280d4aa2c271b0f4fbc0e34d249578dd05e50e76d0e5efcc
T
Tomas Kolda 已提交
1860
LZ4_DOWNLOAD_BASE ?= https://github.com/lz4/lz4/archive
1861 1862
ZSTD_VER ?= 1.4.4
ZSTD_SHA256 ?= a364f5162c7d1a455cc915e8e3cf5f4bd8b75d09bc0f53965b0c9ca1383c52c8
1863
ZSTD_DOWNLOAD_BASE ?= https://github.com/facebook/zstd/archive
P
Pengchao Wang 已提交
1864
CURL_SSL_OPTS ?= --tlsv1
1865 1866

ifeq ($(PLATFORM), OS_MACOSX)
D
David Bernard 已提交
1867 1868
	ROCKSDBJNILIB = librocksdbjni-osx.jnilib
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar
1869
	SHA256_CMD = openssl sha256 -r
1870 1871 1872 1873 1874
ifneq ("$(wildcard $(JAVA_HOME)/include/darwin)","")
	JAVA_INCLUDE = -I$(JAVA_HOME)/include -I $(JAVA_HOME)/include/darwin
else
	JAVA_INCLUDE = -I/System/Library/Frameworks/JavaVM.framework/Headers/
endif
1875
endif
1876
ifeq ($(PLATFORM), OS_FREEBSD)
1877
	JAVA_INCLUDE = -I$(JAVA_HOME)/include -I$(JAVA_HOME)/include/freebsd
1878 1879 1880
	ROCKSDBJNILIB = librocksdbjni-freebsd$(ARCH).so
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-freebsd$(ARCH).jar
endif
D
David Bernard 已提交
1881 1882 1883 1884
ifeq ($(PLATFORM), OS_SOLARIS)
	ROCKSDBJNILIB = librocksdbjni-solaris$(ARCH).so
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-solaris$(ARCH).jar
	JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/solaris
1885
	SHA256_CMD = digest -a sha256
D
David Bernard 已提交
1886
endif
T
Tomas Kolda 已提交
1887 1888 1889 1890 1891 1892
ifeq ($(PLATFORM), OS_AIX)
	JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/aix
	ROCKSDBJNILIB = librocksdbjni-aix.so
	EXTRACT_SOURCES = gunzip < TAR_GZ | tar xvf -
	SNAPPY_MAKE_TARGET = libsnappy.la
endif
1893 1894 1895 1896 1897
ifeq ($(PLATFORM), OS_OPENBSD)
        JAVA_INCLUDE = -I$(JAVA_HOME)/include -I$(JAVA_HOME)/include/openbsd
	ROCKSDBJNILIB = librocksdbjni-openbsd$(ARCH).so
        ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-openbsd$(ARCH).jar
endif
1898

N
Naveen 已提交
1899
libz.a:
1900
	-rm -rf zlib-$(ZLIB_VER)
1901
ifeq (,$(wildcard ./zlib-$(ZLIB_VER).tar.gz))
1902
	curl --fail --output zlib-$(ZLIB_VER).tar.gz --location ${ZLIB_DOWNLOAD_BASE}/zlib-$(ZLIB_VER).tar.gz
1903
endif
1904 1905 1906 1907 1908 1909
	ZLIB_SHA256_ACTUAL=`$(SHA256_CMD) zlib-$(ZLIB_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(ZLIB_SHA256)" != "$$ZLIB_SHA256_ACTUAL" ]; then \
		echo zlib-$(ZLIB_VER).tar.gz checksum mismatch, expected=\"$(ZLIB_SHA256)\" actual=\"$$ZLIB_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf zlib-$(ZLIB_VER).tar.gz
1910
	cd zlib-$(ZLIB_VER) && CFLAGS='-fPIC ${EXTRA_CFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' ./configure --static && $(MAKE)
1911
	cp zlib-$(ZLIB_VER)/libz.a .
N
Naveen 已提交
1912 1913

libbz2.a:
1914
	-rm -rf bzip2-$(BZIP2_VER)
1915
ifeq (,$(wildcard ./bzip2-$(BZIP2_VER).tar.gz))
1916
	curl --fail --output bzip2-$(BZIP2_VER).tar.gz --location ${CURL_SSL_OPTS} ${BZIP2_DOWNLOAD_BASE}/bzip2-$(BZIP2_VER).tar.gz
1917
endif
1918 1919 1920 1921 1922 1923
	BZIP2_SHA256_ACTUAL=`$(SHA256_CMD) bzip2-$(BZIP2_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(BZIP2_SHA256)" != "$$BZIP2_SHA256_ACTUAL" ]; then \
		echo bzip2-$(BZIP2_VER).tar.gz checksum mismatch, expected=\"$(BZIP2_SHA256)\" actual=\"$$BZIP2_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf bzip2-$(BZIP2_VER).tar.gz
1924
	cd bzip2-$(BZIP2_VER) && $(MAKE) CFLAGS='-fPIC -O2 -g -D_FILE_OFFSET_BITS=64 ${EXTRA_CFLAGS}' AR='ar ${EXTRA_ARFLAGS}'
1925
	cp bzip2-$(BZIP2_VER)/libbz2.a .
N
Naveen 已提交
1926

N
Naveen 已提交
1927
libsnappy.a:
1928
	-rm -rf snappy-$(SNAPPY_VER)
1929
ifeq (,$(wildcard ./snappy-$(SNAPPY_VER).tar.gz))
1930
	curl --fail --output snappy-$(SNAPPY_VER).tar.gz --location ${CURL_SSL_OPTS} ${SNAPPY_DOWNLOAD_BASE}/$(SNAPPY_VER).tar.gz
1931
endif
1932 1933 1934 1935 1936
	SNAPPY_SHA256_ACTUAL=`$(SHA256_CMD) snappy-$(SNAPPY_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(SNAPPY_SHA256)" != "$$SNAPPY_SHA256_ACTUAL" ]; then \
		echo snappy-$(SNAPPY_VER).tar.gz checksum mismatch, expected=\"$(SNAPPY_SHA256)\" actual=\"$$SNAPPY_SHA256_ACTUAL\"; \
		exit 1; \
	fi
1937
	tar xvzf snappy-$(SNAPPY_VER).tar.gz
1938
	mkdir snappy-$(SNAPPY_VER)/build
1939
	cd snappy-$(SNAPPY_VER)/build && CFLAGS='${EXTRA_CFLAGS}' CXXFLAGS='${EXTRA_CXXFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' cmake -DCMAKE_POSITION_INDEPENDENT_CODE=ON .. && $(MAKE) ${SNAPPY_MAKE_TARGET}
1940
	cp snappy-$(SNAPPY_VER)/build/libsnappy.a .
1941

1942
liblz4.a:
1943
	-rm -rf lz4-$(LZ4_VER)
1944
ifeq (,$(wildcard ./lz4-$(LZ4_VER).tar.gz))
1945
	curl --fail --output lz4-$(LZ4_VER).tar.gz --location ${CURL_SSL_OPTS} ${LZ4_DOWNLOAD_BASE}/v$(LZ4_VER).tar.gz
1946
endif
1947 1948 1949 1950 1951 1952
	LZ4_SHA256_ACTUAL=`$(SHA256_CMD) lz4-$(LZ4_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(LZ4_SHA256)" != "$$LZ4_SHA256_ACTUAL" ]; then \
		echo lz4-$(LZ4_VER).tar.gz checksum mismatch, expected=\"$(LZ4_SHA256)\" actual=\"$$LZ4_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf lz4-$(LZ4_VER).tar.gz
1953
	cd lz4-$(LZ4_VER)/lib && $(MAKE) CFLAGS='-fPIC -O2 ${EXTRA_CFLAGS}' all
1954
	cp lz4-$(LZ4_VER)/lib/liblz4.a .
N
Naveen 已提交
1955

1956 1957
libzstd.a:
	-rm -rf zstd-$(ZSTD_VER)
1958
ifeq (,$(wildcard ./zstd-$(ZSTD_VER).tar.gz))
1959
	curl --fail --output zstd-$(ZSTD_VER).tar.gz --location ${CURL_SSL_OPTS} ${ZSTD_DOWNLOAD_BASE}/v$(ZSTD_VER).tar.gz
1960
endif
1961 1962 1963 1964 1965 1966
	ZSTD_SHA256_ACTUAL=`$(SHA256_CMD) zstd-$(ZSTD_VER).tar.gz | cut -d ' ' -f 1`; \
	if [ "$(ZSTD_SHA256)" != "$$ZSTD_SHA256_ACTUAL" ]; then \
		echo zstd-$(ZSTD_VER).tar.gz checksum mismatch, expected=\"$(ZSTD_SHA256)\" actual=\"$$ZSTD_SHA256_ACTUAL\"; \
		exit 1; \
	fi
	tar xvzf zstd-$(ZSTD_VER).tar.gz
1967
	cd zstd-$(ZSTD_VER)/lib && DESTDIR=. PREFIX= $(MAKE) CFLAGS='-fPIC -O2 ${EXTRA_CFLAGS}' install
1968 1969
	cp zstd-$(ZSTD_VER)/lib/libzstd.a .

1970
# A version of each $(LIB_OBJECTS) compiled with -fPIC and a fixed set of static compression libraries
1971
ifneq ($(ROCKSDB_JAVA_NO_COMPRESSION), 1)
1972
JAVA_COMPRESSIONS = libz.a libbz2.a libsnappy.a liblz4.a libzstd.a
1973 1974
endif

1975
JAVA_STATIC_FLAGS = -DZLIB -DBZIP2 -DSNAPPY -DLZ4 -DZSTD
1976
JAVA_STATIC_INCLUDES = -I./zlib-$(ZLIB_VER) -I./bzip2-$(BZIP2_VER) -I./snappy-$(SNAPPY_VER) -I./lz4-$(LZ4_VER)/lib -I./zstd-$(ZSTD_VER)/lib/include
1977 1978 1979
ifneq ($(findstring rocksdbjavastatic, $(MAKECMDGOALS)),)
CXXFLAGS += $(JAVA_STATIC_FLAGS) $(JAVA_STATIC_INCLUDES)
CFLAGS +=  $(JAVA_STATIC_FLAGS) $(JAVA_STATIC_INCLUDES)
A
Andrew Kryczka 已提交
1980
endif
1981
rocksdbjavastatic: $(LIB_OBJECTS) $(JAVA_COMPRESSIONS)
F
fyrz 已提交
1982
	cd java;$(MAKE) javalib;
1983
	rm -f ./java/target/$(ROCKSDBJNILIB)
1984 1985
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC \
	  -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) \
1986
	  $(LIB_OBJECTS) $(COVERAGEFLAGS) \
1987
	  $(JAVA_COMPRESSIONS) $(JAVA_STATIC_LDFLAGS)
1988 1989 1990
	cd java/target;if [ "$(DEBUG_LEVEL)" == "0" ]; then \
		strip $(STRIPFLAGS) $(ROCKSDBJNILIB); \
	fi
1991 1992 1993 1994 1995
	cd java;jar -cf target/$(ROCKSDB_JAR) HISTORY*.md
	cd java/target;jar -uf $(ROCKSDB_JAR) $(ROCKSDBJNILIB)
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR) org/rocksdb/*.class org/rocksdb/util/*.class
	cd java/target/apidocs;jar -cf ../$(ROCKSDB_JAVADOCS_JAR) *
	cd java/src/main/java;jar -cf ../../../target/$(ROCKSDB_SOURCES_JAR) org
N
Naveen 已提交
1996

1997
rocksdbjavastaticrelease: rocksdbjavastatic
1998
	cd java/crossbuild && (vagrant destroy -f || true) && vagrant up linux32 && vagrant halt linux32 && vagrant up linux64 && vagrant halt linux64 && vagrant up linux64-musl && vagrant halt linux64-musl
1999
	cd java;jar -cf target/$(ROCKSDB_JAR_ALL) HISTORY*.md
2000
	cd java/target;jar -uf $(ROCKSDB_JAR_ALL) librocksdbjni-*.so librocksdbjni-*.jnilib
2001
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR_ALL) org/rocksdb/*.class org/rocksdb/util/*.class
2002

2003
rocksdbjavastaticreleasedocker: rocksdbjavastatic rocksdbjavastaticdockerx86 rocksdbjavastaticdockerx86_64 rocksdbjavastaticdockerx86musl rocksdbjavastaticdockerx86_64musl
2004 2005 2006 2007 2008 2009
	cd java;jar -cf target/$(ROCKSDB_JAR_ALL) HISTORY*.md
	cd java/target;jar -uf $(ROCKSDB_JAR_ALL) librocksdbjni-*.so librocksdbjni-*.jnilib
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR_ALL) org/rocksdb/*.class org/rocksdb/util/*.class

rocksdbjavastaticdockerx86:
	mkdir -p java/target
2010
	docker run --rm --name rocksdb_linux_x86-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:centos6_x86-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2011 2012 2013

rocksdbjavastaticdockerx86_64:
	mkdir -p java/target
2014
	docker run --rm --name rocksdb_linux_x64-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:centos6_x64-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2015

2016 2017
rocksdbjavastaticdockerppc64le:
	mkdir -p java/target
2018
	docker run --rm --name rocksdb_linux_ppc64le-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:centos7_ppc64le-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2019

2020 2021
rocksdbjavastaticdockerarm64v8:
	mkdir -p java/target
2022
	docker run --rm --name rocksdb_linux_arm64v8-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:centos7_arm64v8-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2023

2024 2025
rocksdbjavastaticdockerx86musl:
	mkdir -p java/target
2026
	docker run --rm --name rocksdb_linux_x86-musl-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:alpine3_x86-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2027 2028 2029

rocksdbjavastaticdockerx86_64musl:
	mkdir -p java/target
2030
	docker run --rm --name rocksdb_linux_x64-musl-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:alpine3_x64-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2031 2032 2033

rocksdbjavastaticdockerppc64lemusl:
	mkdir -p java/target
2034
	docker run --rm --name rocksdb_linux_ppc64le-musl-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:alpine3_ppc64le-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2035 2036 2037

rocksdbjavastaticdockerarm64v8musl:
	mkdir -p java/target
2038
	docker run --rm --name rocksdb_linux_arm64v8-musl-be --attach stdin --attach stdout --attach stderr --volume $(HOME)/.m2:/root/.m2:ro --volume `pwd`:/rocksdb-host:ro --volume /rocksdb-local-build --volume `pwd`/java/target:/rocksdb-java-target --env DEBUG_LEVEL=$(DEBUG_LEVEL) evolvedbinary/rocksjava:alpine3_arm64v8-be /rocksdb-host/java/crossbuild/docker-build-linux-centos.sh
2039

2040 2041
rocksdbjavastaticpublish: rocksdbjavastaticrelease rocksdbjavastaticpublishcentral

2042 2043
rocksdbjavastaticpublishdocker: rocksdbjavastaticreleasedocker rocksdbjavastaticpublishcentral

2044
rocksdbjavastaticpublishcentral:
2045 2046 2047 2048
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar -Dclassifier=javadoc
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar -Dclassifier=sources
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux64.jar -Dclassifier=linux64
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux32.jar -Dclassifier=linux32
2049 2050
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux64-musl.jar -Dclassifier=linux64-musl
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux32-musl.jar -Dclassifier=linux32-musl
2051
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar -Dclassifier=osx
2052
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-win64.jar -Dclassifier=win64
2053
	mvn gpg:sign-and-deploy-file -Durl=https://oss.sonatype.org/service/local/staging/deploy/maven2/ -DrepositoryId=sonatype-nexus-staging -DpomFile=java/rocksjni.pom -Dfile=java/target/rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
2054

2055
# A version of each $(LIBOBJECTS) compiled with -fPIC
2056

2057 2058
jl/%.o: %.cc
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) -fPIC -c $< -o $@ $(COVERAGEFLAGS)
2059 2060 2061 2062 2063 2064 2065 2066

jl/crc32c_ppc.o: util/crc32c_ppc.c
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@

jl/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@


2067
rocksdbjava: $(LIB_OBJECTS)
2068 2069
	$(AM_V_GEN)cd java;$(MAKE) javalib;
	$(AM_V_at)rm -f ./java/target/$(ROCKSDBJNILIB)
2070
	$(AM_V_at)$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) $(LIB_OBJECTS) $(JAVA_LDFLAGS) $(COVERAGEFLAGS)
2071 2072 2073
	$(AM_V_at)cd java;jar -cf target/$(ROCKSDB_JAR) HISTORY*.md
	$(AM_V_at)cd java/target;jar -uf $(ROCKSDB_JAR) $(ROCKSDBJNILIB)
	$(AM_V_at)cd java/target/classes;jar -uf ../$(ROCKSDB_JAR) org/rocksdb/*.class org/rocksdb/util/*.class
2074 2075 2076 2077

jclean:
	cd java;$(MAKE) clean;

2078 2079 2080 2081 2082 2083
jtest_compile: rocksdbjava
	cd java;$(MAKE) java_test

jtest_run:
	cd java;$(MAKE) run_test

2084
jtest: rocksdbjava
2085
	cd java;$(MAKE) sample;$(MAKE) test;
2086
	$(PYTHON) tools/check_all_python.py # TODO peterd: find a better place for this check in CI targets
2087

2088 2089 2090
jdb_bench:
	cd java;$(MAKE) db_bench;

2091 2092
commit_prereq: build_tools/rocksdb-lego-determinator \
               build_tools/precommit_checker.py
2093
	J=$(J) build_tools/precommit_checker.py unit unit_481 clang_unit release release_481 clang_release tsan asan ubsan lite unit_non_shm
2094
	$(MAKE) clean && $(MAKE) jclean && $(MAKE) rocksdbjava;
2095

2096 2097 2098
# ---------------------------------------------------------------------------
#  	Platform-specific compilation
# ---------------------------------------------------------------------------
J
Jim Paton 已提交
2099

2100 2101 2102
ifeq ($(PLATFORM), IOS)
# For iOS, create universal object files to be used on both the simulator and
# a device.
2103 2104
XCODEROOT=$(shell xcode-select -print-path)
PLATFORMSROOT=$(XCODEROOT)/Platforms
H
heyongqiang 已提交
2105 2106
SIMULATORROOT=$(PLATFORMSROOT)/iPhoneSimulator.platform/Developer
DEVICEROOT=$(PLATFORMSROOT)/iPhoneOS.platform/Developer
I
Igor Canadi 已提交
2107
IOSVERSION=$(shell defaults read $(PLATFORMSROOT)/iPhoneOS.platform/version CFBundleShortVersionString)
2108

2109 2110
.cc.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
2111
	$(CXX) $(CXXFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
2112
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
2113
	xcrun -sdk iphoneos $(CXX) $(CXXFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
2114
	lipo ios-x86/$@ ios-arm/$@ -create -output $@
2115 2116 2117

.c.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
2118
	$(CC) $(CFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
2119
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
2120
	xcrun -sdk iphoneos $(CC) $(CFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
2121 2122
	lipo ios-x86/$@ ios-arm/$@ -create -output $@

2123
else
2124
ifeq ($(HAVE_POWER8),1)
2125
$(OBJ_DIR)/util/crc32c_ppc.o: util/crc32c_ppc.c
2126 2127
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@

2128
+$(OBJ_DIR)/util/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
2129 2130
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
endif
2131 2132
$(OBJ_DIR)/%.o: %.cc
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)
2133

2134 2135
$(OBJ_DIR)/%.o: %.cpp
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)
2136

2137
$(OBJ_DIR)/%.o: %.c
2138
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
2139
endif
2140

2141 2142 2143 2144
# ---------------------------------------------------------------------------
#  	Source files dependencies detection
# ---------------------------------------------------------------------------

2145 2146
DEPFILES = $(patsubst %.cc, $(OBJ_DIR)/%.cc.d, $(ALL_SOURCES))
DEPFILES+ = $(patsubst %.c, $(OBJ_DIR)/%.c.d, $(LIB_SOURCES_C) $(TEST_MAIN_SOURCES_C))
2147
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
2148
  DEPFILES +=$(patsubst %.cpp, $(OBJ_DIR)/%.cpp.d, $(FOLLY_SOURCES))
2149
endif
2150

2151 2152 2153 2154 2155
# Add proper dependency support so changing a .h file forces a .cc file to
# rebuild.

# The .d file indicates .cc file's dependencies on .h files. We generate such
# dependency by g++'s -MM option, whose output is a make dependency rule.
2156 2157 2158 2159
$(OBJ_DIR)/%.cc.d: %.cc
	@mkdir -p $(@D) && $(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.cc=.o)' -MT'$(<:%.cc=$(OBJ_DIR)/%.o)' \
          "$<" -o '$@'
2160

2161 2162 2163 2164
$(OBJ_DIR)/%.cpp.d: %.cpp
	@mkdir -p $(@D) && $(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.cpp=.o)' -MT'$(<:%.cpp=$(OBJ_DIR)/%.o)' \
          "$<" -o '$@'
2165

2166
ifeq ($(HAVE_POWER8),1)
2167 2168
DEPFILES_C = $(patsubst %.c, $(OBJ_DIR)/%.c.d, $(LIB_SOURCES_C))
DEPFILES_ASM = $(patsubst %.S, $(OBJ_DIR)/%.S.d, $(LIB_SOURCES_ASM))
2169

2170
$(OBJ_DIR)/%.c.d: %.c
2171 2172 2173
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.c=.o)' "$<" -o '$@'

2174
+$(OBJ_DIR)/%.S.d: %.S
2175 2176 2177 2178 2179 2180 2181 2182
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.S=.o)' "$<" -o '$@'

$(DEPFILES_C): %.c.d

$(DEPFILES_ASM): %.S.d
depend: $(DEPFILES) $(DEPFILES_C) $(DEPFILES_ASM)
else
2183
depend: $(DEPFILES)
2184
endif
2185

2186 2187 2188 2189
# if the make goal is either "clean" or "format", we shouldn't
# try to import the *.d files.
# TODO(kailiu) The unfamiliarity of Make's conditions leads to the ugly
# working solution.
2190
ifneq ($(MAKECMDGOALS),clean)
2191
ifneq ($(MAKECMDGOALS),format)
2192 2193
ifneq ($(MAKECMDGOALS),jclean)
ifneq ($(MAKECMDGOALS),jtest)
2194
ifneq ($(MAKECMDGOALS),package)
2195
ifneq ($(MAKECMDGOALS),analyze)
2196 2197
-include $(DEPFILES)
endif
2198
endif
2199 2200
endif
endif
2201
endif
2202
endif