Makefile 75.7 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
PYTHON?=$(shell which python)
J
Jonathan Lee 已提交
12

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

21 22
# Transform parallel LOG output into something more readable.
perl_command = perl -n \
23 24 25
  -e '@a=split("\t",$$_,-1); $$t=$$a[8];'				\
  -e '$$t =~ /.*if\s\[\[\s"(.*?\.[\w\/]+)/ and $$t=$$1;'		\
  -e '$$t =~ s,^\./,,;'							\
Y
Yueh-Hsuan Chiang 已提交
26 27 28
  -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'
29 30
quoted_perl_command = $(subst ','\'',$(perl_command))

31 32 33 34 35 36 37 38 39
# 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 已提交
40
# with debug level 0. To compile with level 0, run `make shared_lib`,
41 42
# `make install-shared`, `make static_lib`, `make install-static` or
# `make install`
43 44 45

# Set the default DEBUG_LEVEL to 1
DEBUG_LEVEL?=1
46 47

ifeq ($(MAKECMDGOALS),dbg)
Y
Yueh-Hsuan Chiang 已提交
48
	DEBUG_LEVEL=2
49
endif
50

51 52 53 54 55 56 57 58
ifeq ($(MAKECMDGOALS),clean)
	DEBUG_LEVEL=0
endif

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

59
ifeq ($(MAKECMDGOALS),shared_lib)
Y
Yueh-Hsuan Chiang 已提交
60
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
61
endif
I
Igor Canadi 已提交
62

I
Igor Canadi 已提交
63
ifeq ($(MAKECMDGOALS),install-shared)
Y
Yueh-Hsuan Chiang 已提交
64
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
65 66
endif

I
Igor Canadi 已提交
67
ifeq ($(MAKECMDGOALS),static_lib)
Y
Yueh-Hsuan Chiang 已提交
68
	DEBUG_LEVEL=0
69
endif
I
Igor Canadi 已提交
70

I
Igor Canadi 已提交
71
ifeq ($(MAKECMDGOALS),install-static)
Y
Yueh-Hsuan Chiang 已提交
72
	DEBUG_LEVEL=0
I
Igor Canadi 已提交
73 74 75
endif

ifeq ($(MAKECMDGOALS),install)
Y
Yueh-Hsuan Chiang 已提交
76
	DEBUG_LEVEL=0
77 78
endif

79
ifeq ($(MAKECMDGOALS),rocksdbjavastatic)
80 81 82
	ifneq ($(DEBUG_LEVEL),2)
		DEBUG_LEVEL=0
	endif
83 84
endif

Y
Yueh-Hsuan Chiang 已提交
85
ifeq ($(MAKECMDGOALS),rocksdbjavastaticrelease)
86 87 88
	ifneq ($(DEBUG_LEVEL),2)
		DEBUG_LEVEL=0
	endif
Y
Yueh-Hsuan Chiang 已提交
89 90
endif

91
ifeq ($(MAKECMDGOALS),rocksdbjavastaticreleasedocker)
92
	ifneq ($(DEBUG_LEVEL),2)
93
		DEBUG_LEVEL=0
94
	endif
95 96
endif

Y
Yueh-Hsuan Chiang 已提交
97 98 99 100
ifeq ($(MAKECMDGOALS),rocksdbjavastaticpublish)
	DEBUG_LEVEL=0
endif

101 102
$(info $$DEBUG_LEVEL is ${DEBUG_LEVEL})

Y
Yi Wu 已提交
103 104
# Lite build flag.
LITE ?= 0
105 106 107 108 109 110 111 112
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 已提交
113 114
	OPT += -DROCKSDB_LITE
endif
115
endif
Y
Yi Wu 已提交
116 117 118 119 120 121 122 123 124 125

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

126 127
# compile with -O2 if debug level is not 2
ifneq ($(DEBUG_LEVEL), 2)
Y
Yi Wu 已提交
128
OPT += -fno-omit-frame-pointer
129 130
# 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))
131 132 133 134
OPT += -momit-leaf-frame-pointer
endif
endif

135 136 137 138 139 140 141 142 143 144 145 146
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

147
ifeq (,$(shell $(CXX) -fsyntax-only -march=armv8-a+crc+crypto -xc /dev/null 2>&1))
148 149
CXXFLAGS += -march=armv8-a+crc+crypto
CFLAGS += -march=armv8-a+crc+crypto
150 151 152
ARMCRC_SOURCE=1
endif

153
# if we're compiling for release, compile without debug code (-DNDEBUG)
154
ifeq ($(DEBUG_LEVEL),0)
I
Igor Canadi 已提交
155
OPT += -DNDEBUG
S
Siying Dong 已提交
156 157 158 159 160 161

ifneq ($(USE_RTTI), 1)
	CXXFLAGS += -fno-rtti
else
	CXXFLAGS += -DROCKSDB_USE_RTTI
endif
162
else
S
Siying Dong 已提交
163 164 165 166 167 168
ifneq ($(USE_RTTI), 0)
	CXXFLAGS += -DROCKSDB_USE_RTTI
else
	CXXFLAGS += -fno-rtti
endif

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

172
#-----------------------------------------------
173
include src.mk
174

175 176 177 178 179 180
AM_DEFAULT_VERBOSITY = 0

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 已提交
181 182 183 184
AM_V_at = $(am__v_at_$(V))
am__v_at_ = $(am__v_at_$(AM_DEFAULT_VERBOSITY))
am__v_at_0 = @
am__v_at_1 =
185 186 187 188 189 190 191 192 193 194 195

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 =
CCLD = $(CC)
LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@
AM_V_CCLD = $(am__v_CCLD_$(V))
am__v_CCLD_ = $(am__v_CCLD_$(AM_DEFAULT_VERBOSITY))
am__v_CCLD_0 = @echo "  CCLD    " $@;
am__v_CCLD_1 =
J
Jim Meyering 已提交
196 197 198 199
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 =
200

201 202 203 204
ifdef ROCKSDB_USE_LIBRADOS
LIB_SOURCES += utilities/env_librados.cc
LDFLAGS += -lrados
endif
205

206
AM_LINK = $(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(COVERAGEFLAGS)
207
# detect what platform we're building on
208
dummy := $(shell (export ROCKSDB_ROOT="$(CURDIR)"; export PORTABLE="$(PORTABLE)"; "$(CURDIR)/build_tools/build_detect_platform" "$(CURDIR)/make_config.mk"))
S
Sanjay Ghemawat 已提交
209
# this file is generated by the previous line to set build flags and sources
I
Igor Canadi 已提交
210
include make_config.mk
211
export JAVAC_ARGS
212
CLEAN_FILES += make_config.mk
J
jorlow@chromium.org 已提交
213

214
missing_make_config_paths := $(shell				\
215
	grep "\./\S*\|/\S*" -o $(CURDIR)/make_config.mk | 	\
216 217 218 219 220
	while read path;					\
		do [ -e $$path ] || echo $$path; 		\
	done | sort | uniq)

$(foreach path, $(missing_make_config_paths), \
221
	$(warning Warning: $(path) does not exist))
222

T
Tomas Kolda 已提交
223 224 225
ifeq ($(PLATFORM), OS_AIX)
# no debug info
else ifneq ($(PLATFORM), IOS)
I
Igor Canadi 已提交
226 227 228 229 230 231 232
CFLAGS += -g
CXXFLAGS += -g
else
# no debug info for IOS, that will make our library big
OPT += -DNDEBUG
endif

T
Tomas Kolda 已提交
233 234 235 236 237
ifeq ($(PLATFORM), OS_AIX)
ARFLAGS = -X64 rs
STRIPFLAGS = -X64 -x
endif

D
David Bernard 已提交
238 239 240
ifeq ($(PLATFORM), OS_SOLARIS)
	PLATFORM_CXXFLAGS += -D _GLIBCXX_USE_C99
endif
241
ifneq ($(filter -DROCKSDB_LITE,$(OPT)),)
Y
Yueh-Hsuan Chiang 已提交
242 243 244
	# found
	CFLAGS += -fno-exceptions
	CXXFLAGS += -fno-exceptions
245 246
	# LUA is not supported under ROCKSDB_LITE
	LUA_PATH =
247 248
endif

I
Igor Canadi 已提交
249 250
# 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 已提交
251 252 253 254
	DISABLE_JEMALLOC=1
	EXEC_LDFLAGS += -fsanitize=address
	PLATFORM_CCFLAGS += -fsanitize=address
	PLATFORM_CXXFLAGS += -fsanitize=address
I
Igor Canadi 已提交
255 256 257 258
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 已提交
259
	DISABLE_JEMALLOC=1
S
Siying Dong 已提交
260
	EXEC_LDFLAGS += -fsanitize=thread
261 262
	PLATFORM_CCFLAGS += -fsanitize=thread -fPIC -DFOLLY_SANITIZE_THREAD
	PLATFORM_CXXFLAGS += -fsanitize=thread -fPIC -DFOLLY_SANITIZE_THREAD
263 264
        # Turn off -pg when enabling TSAN testing, because that induces
        # a link failure.  TODO: find the root cause
D
dx9 已提交
265
	PROFILING_FLAGS =
266 267
	# LUA is not supported under TSAN
	LUA_PATH =
268 269 270
	# Limit keys for crash test under TSAN to avoid error:
	# "ThreadSanitizer: DenseSlabAllocator overflow. Dying."
	CRASH_TEST_EXT_ARGS += --max_key=1000000
I
Igor Canadi 已提交
271 272
endif

T
Tomas Kolda 已提交
273 274 275 276 277
# AIX doesn't work with -pg
ifeq ($(PLATFORM), OS_AIX)
	PROFILING_FLAGS =
endif

278 279 280
# 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 已提交
281 282 283 284
	# 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.
285 286 287
	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
288 289
endif

290 291 292 293 294
ifdef ROCKSDB_VALGRIND_RUN
	PLATFORM_CCFLAGS += -DROCKSDB_VALGRIND_RUN
	PLATFORM_CXXFLAGS += -DROCKSDB_VALGRIND_RUN
endif

I
Igor Canadi 已提交
295
ifndef DISABLE_JEMALLOC
296
	ifdef JEMALLOC
T
Tamir Duberstein 已提交
297 298
		PLATFORM_CXXFLAGS += -DROCKSDB_JEMALLOC -DJEMALLOC_NO_DEMANGLE
		PLATFORM_CCFLAGS  += -DROCKSDB_JEMALLOC -DJEMALLOC_NO_DEMANGLE
299
	endif
300 301 302 303
	ifdef WITH_JEMALLOC_FLAG
		PLATFORM_LDFLAGS += -ljemalloc
		JAVA_LDFLAGS += -ljemalloc
	endif
Y
Yueh-Hsuan Chiang 已提交
304 305 306
	EXEC_LDFLAGS := $(JEMALLOC_LIB) $(EXEC_LDFLAGS)
	PLATFORM_CXXFLAGS += $(JEMALLOC_INCLUDE)
	PLATFORM_CCFLAGS += $(JEMALLOC_INCLUDE)
I
Igor Canadi 已提交
307 308
endif

309 310 311 312
ifndef USE_FOLLY_DISTRIBUTED_MUTEX
	USE_FOLLY_DISTRIBUTED_MUTEX=0
endif

T
Tamir Duberstein 已提交
313 314
export GTEST_THROW_ON_FAILURE=1
export GTEST_HAS_EXCEPTIONS=1
315
GTEST_DIR = ./third-party/gtest-1.8.1/fused-src
T
Tomas Kolda 已提交
316 317 318 319 320 321 322 323
# 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 已提交
324

325
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
326 327 328 329 330 331 332 333 334 335
	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
336 337 338 339 340

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
341

342 343 344
# This (the first rule) must depend on "all".
default: all

345
WARNING_FLAGS = -W -Wextra -Wall -Wsign-compare -Wshadow \
346
  -Wunused-parameter
347

348 349 350 351
ifeq ($(PLATFORM), OS_OPENBSD)
	WARNING_FLAGS += -Wno-unused-lambda-capture
endif

352
ifndef DISABLE_WARNING_AS_ERROR
Y
Yueh-Hsuan Chiang 已提交
353
	WARNING_FLAGS += -Werror
354 355
endif

356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378

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
379
EXEC_LDFLAGS += $(LUA_LIB)
380 381 382

endif

383 384 385
ifeq ($(NO_THREEWAY_CRC32C), 1)
	CXXFLAGS += -DNO_THREEWAY_CRC32C
endif
386

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

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

392 393 394
# 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
395
date := $(shell date +%F)
I
Igor Canadi 已提交
396
ifdef FORCE_GIT_SHA
Y
Yueh-Hsuan Chiang 已提交
397
	git_sha := $(FORCE_GIT_SHA)
I
Igor Canadi 已提交
398
else
Y
Yueh-Hsuan Chiang 已提交
399
	git_sha := $(shell git rev-parse HEAD 2>/dev/null)
I
Igor Canadi 已提交
400
endif
401
gen_build_version = sed -e s/@@GIT_SHA@@/$(git_sha)/ -e s/@@GIT_DATE_TIME@@/$(date)/ util/build_version.cc.in
402 403 404 405 406 407

# 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.
408 409
FORCE:
util/build_version.cc: FORCE
Y
Yueh-Hsuan Chiang 已提交
410 411 412 413 414
	$(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
415
endif
416

417
LIBOBJECTS = $(LIB_SOURCES:.cc=.o)
418 419 420 421
ifeq ($(HAVE_POWER8),1)
LIB_CC_OBJECTS = $(LIB_SOURCES:.cc=.o)
LIBOBJECTS += $(LIB_SOURCES_C:.c=.o)
LIBOBJECTS += $(LIB_SOURCES_ASM:.S=.o)
A
Andrew Kryczka 已提交
422 423
else
LIB_CC_OBJECTS = $(LIB_SOURCES:.cc=.o)
424 425
endif

426 427
LIBOBJECTS += $(TOOL_LIB_SOURCES:.cc=.o)
MOCKOBJECTS = $(MOCK_LIB_SOURCES:.cc=.o)
428 429 430
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
  FOLLYOBJECTS = $(FOLLY_SOURCES:.cpp=.o)
endif
J
jorlow@chromium.org 已提交
431

I
Igor Sugak 已提交
432
GTEST = $(GTEST_DIR)/gtest/gtest-all.o
433 434
TESTUTIL = ./test_util/testutil.o
TESTHARNESS = ./test_util/testharness.o $(TESTUTIL) $(MOCKOBJECTS) $(GTEST)
435
VALGRIND_ERROR = 2
436
VALGRIND_VER := $(join $(VALGRIND_VER),valgrind)
437

438
VALGRIND_OPTS = --error-exitcode=$(VALGRIND_ERROR) --leak-check=full
439

O
omegaga 已提交
440
BENCHTOOLOBJECTS = $(BENCH_LIB_SOURCES:.cc=.o) $(LIBOBJECTS) $(TESTUTIL)
441

442 443
ANALYZETOOLOBJECTS = $(ANALYZER_LIB_SOURCES:.cc=.o)

444 445
STRESSTOOLOBJECTS = $(STRESS_LIB_SOURCES:.cc=.o) $(LIBOBJECTS) $(TESTUTIL)

S
Siying Dong 已提交
446
EXPOBJECTS = $(LIBOBJECTS) $(TESTUTIL)
O
omegaga 已提交
447

J
jorlow@chromium.org 已提交
448
TESTS = \
449
	db_basic_test \
450
	db_with_timestamp_basic_test \
E
Ewout Prangsma 已提交
451
	db_encryption_test \
452
	db_test2 \
S
Siying Dong 已提交
453
	external_sst_file_basic_test \
S
Siying Dong 已提交
454 455 456 457 458 459 460 461 462 463
	auto_roll_logger_test \
	bloom_test \
	dynamic_bloom_test \
	c_test \
	checkpoint_test \
	crc32c_test \
	coding_test \
	inlineskiplist_test \
	env_basic_test \
	env_test \
464
	env_logger_test \
465
	io_posix_test \
466
	hash_test \
467
	random_test \
S
Siying Dong 已提交
468
	thread_local_test \
469
	work_queue_test \
S
Siying Dong 已提交
470 471 472 473
	rate_limiter_test \
	perf_context_test \
	iostats_context_test \
	db_wal_test \
474
	db_block_cache_test \
475
	db_test \
476
	db_logical_block_size_cache_test \
Y
Yi Wu 已提交
477
	db_blob_index_test \
478
	db_iter_test \
479
	db_iter_stress_test \
480
	db_log_iter_test \
481
	db_bloom_filter_test \
482
	db_compaction_filter_test \
483
	db_compaction_test \
484
	db_dynamic_level_test \
485
	db_flush_test \
486
	db_inplace_update_test \
Y
Yi Wu 已提交
487
	db_iterator_test \
488
	db_memtable_test \
489
	db_merge_operator_test \
490
	db_merge_operand_test \
491
	db_options_test \
492
	db_range_del_test \
493
	db_secondary_test \
Y
Yi Wu 已提交
494
	db_sst_test \
495
	db_tailing_iter_test \
O
omegaga 已提交
496
	db_io_failure_test \
497
	db_properties_test \
498
	db_table_properties_test \
499
	db_statistics_test \
Y
Yi Wu 已提交
500
	db_write_test \
501
	error_handler_fs_test \
502
	autovector_test \
Y
Yi Wu 已提交
503
	blob_db_test \
M
Maysam Yabandeh 已提交
504
	cleanable_test \
505 506 507 508
	column_family_test \
	table_properties_collector_test \
	arena_test \
	block_test \
509
	data_block_hash_index_test \
510 511
	cache_test \
	corruption_test \
512
	slice_test \
513 514 515 516 517
	slice_transform_test \
	dbformat_test \
	fault_injection_test \
	filelock_test \
	filename_test \
518
	random_access_file_reader_test \
519
	file_reader_writer_test \
520 521
	block_based_filter_block_test \
	full_filter_block_test \
M
Maysam Yabandeh 已提交
522
	partitioned_filter_block_test \
523
	hash_table_test \
524 525 526 527 528 529
	histogram_test \
	log_test \
	manual_compaction_test \
	mock_env_test \
	memtable_list_test \
	merge_helper_test \
530
	memory_test \
531 532
	merge_test \
	merger_test \
533
	util_merge_operators_test \
534
	options_file_test \
535 536 537
	reduce_levels_test \
	plain_table_db_test \
	comparator_db_test \
538
	external_sst_file_test \
539
	import_column_family_test \
540 541
	prefix_test \
	skiplist_test \
542
	write_buffer_manager_test \
543
	stringappend_test \
544
	cassandra_format_test \
545
	cassandra_functional_test \
546 547
	cassandra_row_merge_test \
	cassandra_serialize_test \
548 549
	ttl_test \
	backupable_db_test \
550
	cache_simulator_test \
551
	sim_cache_test \
552 553 554 555 556 557 558 559 560
	version_edit_test \
	version_set_test \
	compaction_picker_test \
	version_builder_test \
	file_indexer_test \
	write_batch_test \
	write_batch_with_index_test \
	write_controller_test\
	deletefile_test \
561
	obsolete_files_test \
562
	table_test \
I
Islam AbdelRahman 已提交
563
	delete_scheduler_test \
564
	options_test \
565
	options_settable_test \
566
	options_util_test \
567
	event_logger_test \
A
Anirban Rahut 已提交
568
	timer_queue_test \
569 570 571 572 573 574
	cuckoo_table_builder_test \
	cuckoo_table_reader_test \
	cuckoo_table_db_test \
	flush_job_test \
	wal_manager_test \
	listener_test \
A
Andres Noetzli 已提交
575
	compaction_iterator_test \
576 577 578 579 580 581
	compaction_job_test \
	thread_list_test \
	sst_dump_test \
	compact_files_test \
	optimistic_transaction_test \
	write_callback_test \
582 583
	heap_test \
	compact_on_deletion_collector_test \
A
agiardullo 已提交
584
	compaction_job_stats_test \
585
	option_change_migration_test \
586
	transaction_test \
587
	ldb_cmd_test \
588
	persistent_cache_test \
589
	statistics_test \
590
	stats_history_test \
Y
Yi Wu 已提交
591
	lru_cache_test \
592
	object_registry_test \
A
Andrew Kryczka 已提交
593
	repair_test \
A
Andrew Kryczka 已提交
594
	env_timed_test \
595
	write_prepared_transaction_test \
596
	write_unprepared_transaction_test \
Z
Zhongyi Xie 已提交
597
	db_universal_compaction_test \
Z
Zhichao Cao 已提交
598
	trace_analyzer_test \
599
	repeatable_thread_test \
600
	range_tombstone_fragmenter_test \
601
	range_del_aggregator_test \
602
	sst_file_reader_test \
603
	db_secondary_test \
H
haoyuhuang 已提交
604
	block_cache_tracer_test \
605
	block_cache_trace_analyzer_test \
C
Cheng Chang 已提交
606
	defer_test \
607 608
	blob_file_addition_test \
	blob_file_garbage_test \
609

610 611 612 613
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
	TESTS += folly_synchronization_distributed_mutex_test
endif

Y
Yi Wu 已提交
614 615
PARALLEL_TEST = \
	backupable_db_test \
616
	db_bloom_filter_test \
Y
Yi Wu 已提交
617 618
	db_compaction_filter_test \
	db_compaction_test \
619
	db_merge_operator_test \
620
	db_sst_test \
Y
Yi Wu 已提交
621 622
	db_test \
	db_universal_compaction_test \
623 624
	db_wal_test \
	external_sst_file_test \
625
	import_column_family_test \
Y
Yi Wu 已提交
626
	fault_injection_test \
627
	file_reader_writer_test \
Y
Yi Wu 已提交
628 629
	inlineskiplist_test \
	manual_compaction_test \
630 631
	persistent_cache_test \
	table_test \
632
	transaction_test \
633
	write_prepared_transaction_test \
634
	write_unprepared_transaction_test \
Y
Yi Wu 已提交
635

636 637 638 639
# 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
I
Islam AbdelRahman 已提交
640 641 642 643 644 645 646 647
SUBSET := $(TESTS)
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
648

649
TOOLS = \
Y
Yueh-Hsuan Chiang 已提交
650 651 652
	sst_dump \
	db_sanity_test \
	db_stress \
I
Igor Canadi 已提交
653
	write_stress \
Y
Yueh-Hsuan Chiang 已提交
654 655 656
	ldb \
	db_repl_stress \
	rocksdb_dump \
Y
Yi Wu 已提交
657 658
	rocksdb_undump \
	blob_dump \
Z
Zhichao Cao 已提交
659
	trace_analyzer \
660
	block_cache_trace_analyzer \
J
jorlow@chromium.org 已提交
661

662 663 664
TEST_LIBS = \
	librocksdb_env_basic_test.a

S
sdong 已提交
665
# TODO: add back forward_iterator_bench, after making it build in all environemnts.
666
BENCHMARKS = db_bench table_reader_bench cache_bench memtablerep_bench filter_bench persistent_cache_bench range_del_aggregator_bench
J
jorlow@chromium.org 已提交
667

668
# if user didn't config LIBNAME, set the default
669
ifeq ($(LIBNAME),)
670 671
# we should only run rocksdb in production with DEBUG_LEVEL 0
ifeq ($(DEBUG_LEVEL),0)
Y
Yueh-Hsuan Chiang 已提交
672
        LIBNAME=librocksdb
673 674 675
else
        LIBNAME=librocksdb_debug
endif
676
endif
677
LIBRARY = ${LIBNAME}.a
678
TOOLS_LIBRARY = ${LIBNAME}_tools.a
679
STRESS_LIBRARY = ${LIBNAME}_stress.a
680

681 682 683
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)
684

685 686
default: all

687 688 689
#-----------------------------------------------
# Create platform independent shared libraries.
#-----------------------------------------------
690
ifneq ($(PLATFORM_SHARED_EXT),)
H
heyongqiang 已提交
691 692

ifneq ($(PLATFORM_SHARED_VERSIONED),true)
693
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
H
heyongqiang 已提交
694 695
SHARED2 = $(SHARED1)
SHARED3 = $(SHARED1)
696
SHARED4 = $(SHARED1)
H
heyongqiang 已提交
697 698
SHARED = $(SHARED1)
else
699 700
SHARED_MAJOR = $(ROCKSDB_MAJOR)
SHARED_MINOR = $(ROCKSDB_MINOR)
701
SHARED_PATCH = $(ROCKSDB_PATCH)
702
SHARED1 = ${LIBNAME}.$(PLATFORM_SHARED_EXT)
703 704 705 706 707 708
ifeq ($(PLATFORM), OS_MACOSX)
SHARED_OSX = $(LIBNAME).$(SHARED_MAJOR)
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
709 710
SHARED2 = $(SHARED1).$(SHARED_MAJOR)
SHARED3 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR)
711
SHARED4 = $(SHARED1).$(SHARED_MAJOR).$(SHARED_MINOR).$(SHARED_PATCH)
712
endif
713 714
SHARED = $(SHARED1) $(SHARED2) $(SHARED3) $(SHARED4)
$(SHARED1): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
715
	ln -fs $(SHARED4) $(SHARED1)
716
$(SHARED2): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
717
	ln -fs $(SHARED4) $(SHARED2)
718
$(SHARED3): $(SHARED4)
Y
Yueh-Hsuan Chiang 已提交
719
	ln -fs $(SHARED4) $(SHARED3)
720
endif
721 722 723 724 725 726 727
ifeq ($(HAVE_POWER8),1)
SHARED_C_OBJECTS = $(LIB_SOURCES_C:.c=.o)
SHARED_ASM_OBJECTS = $(LIB_SOURCES_ASM:.S=.o)
SHARED_C_LIBOBJECTS = $(patsubst %.o,shared-objects/%.o,$(SHARED_C_OBJECTS))
SHARED_ASM_LIBOBJECTS = $(patsubst %.o,shared-objects/%.o,$(SHARED_ASM_OBJECTS))
shared_libobjects = $(patsubst %,shared-objects/%,$(LIB_CC_OBJECTS))
else
728
shared_libobjects = $(patsubst %,shared-objects/%,$(LIBOBJECTS))
729 730
endif

731
CLEAN_FILES += shared-objects
732
shared_all_libobjects = $(shared_libobjects)
733

734 735 736 737 738 739 740 741 742
ifeq ($(HAVE_POWER8),1)
shared-ppc-objects = $(SHARED_C_LIBOBJECTS) $(SHARED_ASM_LIBOBJECTS)

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

shared-objects/util/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
endif
743
$(shared_libobjects): shared-objects/%.o: %.cc
744 745
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) -c $< -o $@

746 747 748 749
ifeq ($(HAVE_POWER8),1)
shared_all_libobjects = $(shared_libobjects) $(shared-ppc-objects)
endif
$(SHARED4): $(shared_all_libobjects)
Z
zhsj 已提交
750
	$(CXX) $(PLATFORM_SHARED_LDFLAGS)$(SHARED3) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) $(shared_all_libobjects) $(LDFLAGS) -o $@
H
heyongqiang 已提交
751 752 753

endif  # PLATFORM_SHARED_EXT

754
.PHONY: blackbox_crash_test check clean coverage crash_test ldb_tests package \
755
	release tags tags0 valgrind_check whitebox_crash_test format static_lib shared_lib all \
Y
Yueh-Hsuan Chiang 已提交
756
	dbg rocksdbjavastatic rocksdbjava install install-static install-shared uninstall \
757
	analyze tools tools_lib \
758
	blackbox_crash_test_with_atomic_flush whitebox_crash_test_with_atomic_flush  \
759
	blackbox_crash_test_with_txn whitebox_crash_test_with_txn
760

M
maurice barnum 已提交
761

762
all: $(LIBRARY) $(BENCHMARKS) tools tools_lib test_libs $(TESTS)
763

764 765
all_but_some_tests: $(LIBRARY) $(BENCHMARKS) tools tools_lib test_libs $(SUBSET)

I
Igor Canadi 已提交
766 767 768 769
static_lib: $(LIBRARY)

shared_lib: $(SHARED)

770 771
stress_lib: $(STRESS_LIBRARY)

M
maurice barnum 已提交
772 773
tools: $(TOOLS)

774 775
tools_lib: $(TOOLS_LIBRARY)

776 777
test_libs: $(TEST_LIBS)

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

780
# creates static library and programs
781
release:
Y
Yueh-Hsuan Chiang 已提交
782
	$(MAKE) clean
783
	DEBUG_LEVEL=0 $(MAKE) static_lib tools db_bench
K
Kai Liu 已提交
784 785

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

Y
Yi Wu 已提交
792 793 794 795 796
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 已提交
797 798
TMPDIR := $(shell echo $${TMPDIR:-/tmp})
TMPD := $(shell f=/dev/shm; test -k $$f || f=$(TMPDIR);     \
Y
Yi Wu 已提交
799 800 801 802 803 804 805 806 807 808 809 810 811 812
  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.
813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830
# 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 已提交
831 832 833 834 835 836 837 838 839 840 841
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 \
842
		TEST_SCRIPT=t/run-$$TEST_BINARY-$${TEST_NAME//\//-}; \
Y
Yi Wu 已提交
843 844 845 846 847
		echo "  GEN     " $$TEST_SCRIPT; \
    printf '%s\n' \
      '#!/bin/sh' \
      "d=\$(TMPD)$$TEST_SCRIPT" \
      'mkdir -p $$d' \
848
      "TEST_TMPDIR=\$$d $(DRIVER) ./$$TEST_BINARY --gtest_filter=$$TEST_NAME" \
Y
Yi Wu 已提交
849 850 851 852 853 854 855 856
		> $$TEST_SCRIPT; \
		chmod a=rx $$TEST_SCRIPT; \
	done

gen_parallel_tests:
	$(AM_V_at)mkdir -p t
	$(AM_V_at)rm -f t/run-*
	$(MAKE) $(parallel_tests)
857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874

# 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 已提交
875
	^.*SnapshotConcurrentAccessTest.*$$|^t/run-table_test-HarnessTest.Randomized$$|^t/run-db_test-.*(?:FileCreationRandomFailure|EncodeDecompressedBlockSizeTest)$$|^.*RecoverFromCorruptedWALWithoutFlush$$
876
prioritize_long_running_tests =						\
Y
Yueh-Hsuan Chiang 已提交
877 878 879
  perl -pe 's,($(slow_test_regexp)),100 $$1,'				\
    | sort -k1,1gr							\
    | sed 's/^[.0-9]* //'
880 881 882 883 884 885

# "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 已提交
886
J ?= 100%
887

V
Venkatesh Radhakrishnan 已提交
888 889 890
# Use this regexp to select the subset of tests whose names match.
tests-regexp = .

891
.PHONY: check_0
Y
Yi Wu 已提交
892 893
check_0:
	$(AM_V_GEN)export TEST_TMPDIR=$(TMPD); \
Y
Yueh-Hsuan Chiang 已提交
894 895 896
	printf '%s\n' ''						\
	  'To monitor subtest <duration,pass/fail,name>,'		\
	  '  run "make watch-log" in a separate window' '';		\
Y
Yi Wu 已提交
897 898 899
	test -t 1 && eta=--eta || eta=; \
	{ \
		printf './%s\n' $(filter-out $(PARALLEL_TEST),$(TESTS)); \
900
		find t -name 'run-*' -print; \
Y
Yi Wu 已提交
901
	} \
Y
Yueh-Hsuan Chiang 已提交
902 903
	  | $(prioritize_long_running_tests)				\
	  | grep -E '$(tests-regexp)'					\
904
	  | build_tools/gnu_parallel -j$(J) --plain --joblog=LOG $$eta --gnu '{} >& t/log-{/}'
S
sdong 已提交
905

906
valgrind-blacklist-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
907

S
sdong 已提交
908
.PHONY: valgrind_check_0
Y
Yi Wu 已提交
909
valgrind_check_0:
S
sdong 已提交
910 911 912 913 914 915
	$(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 已提交
916
	  printf './%s\n' $(filter-out $(PARALLEL_TEST) %skiplist_test options_settable_test, $(TESTS));		\
917
	  find t -name 'run-*' -print; \
S
sdong 已提交
918 919 920
	}								\
	  | $(prioritize_long_running_tests)				\
	  | grep -E '$(tests-regexp)'					\
921
	  | grep -E -v '$(valgrind-blacklist-regexp)'					\
922
	  | build_tools/gnu_parallel -j$(J) --plain --joblog=LOG $$eta --gnu \
923 924
	  '(if [[ "{}" == "./"* ]] ; then $(DRIVER) {}; else {}; fi) ' \
	  '>& t/valgrind_log-{/}'
925 926

CLEAN_FILES += t LOG $(TMPD)
927

928 929 930 931 932 933 934 935
# 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:
936
	$(WATCH) --interval=0 'sort -k7,7nr -k4,4gr LOG|$(quoted_perl_command)'
937

I
Igor Canadi 已提交
938
# If J != 1 and GNU parallel is installed, run the tests in parallel,
939 940
# via the check_0 rule above.  Otherwise, run them sequentially.
check: all
Y
Yi Wu 已提交
941
	$(MAKE) gen_parallel_tests
Y
Yueh-Hsuan Chiang 已提交
942
	$(AM_V_GEN)if test "$(J)" != 1                                  \
943
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
Y
Yueh-Hsuan Chiang 已提交
944 945 946 947 948 949 950 951
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
	    $(MAKE) T="$$t" TMPD=$(TMPD) check_0;                       \
	else                                                            \
	    for t in $(TESTS); do                                       \
	      echo "===== Running $$t"; ./$$t || exit 1; done;          \
	fi
	rm -rf $(TMPD)
T
Tomas Kolda 已提交
952
ifneq ($(PLATFORM), OS_AIX)
953
	$(PYTHON) tools/check_all_python.py
I
Islam AbdelRahman 已提交
954
ifeq ($(filter -DROCKSDB_LITE,$(OPT)),)
955
	$(PYTHON) tools/ldb_test.py
Y
Yueh-Hsuan Chiang 已提交
956
	sh tools/rocksdb_dump_test.sh
I
Islam AbdelRahman 已提交
957
endif
T
Tomas Kolda 已提交
958
endif
959

S
Siying Dong 已提交
960 961
# TODO add ldb_tests
check_some: $(SUBSET)
Y
Yueh-Hsuan Chiang 已提交
962
	for t in $(SUBSET); do echo "===== Running $$t"; ./$$t || exit 1; done
963 964

.PHONY: ldb_tests
965
ldb_tests: ldb
966
	$(PYTHON) tools/ldb_test.py
967

I
Igor Canadi 已提交
968
crash_test: whitebox_crash_test blackbox_crash_test
969

970 971
crash_test_with_atomic_flush: whitebox_crash_test_with_atomic_flush blackbox_crash_test_with_atomic_flush

972 973
crash_test_with_txn: whitebox_crash_test_with_txn blackbox_crash_test_with_txn

974
blackbox_crash_test: db_stress
975 976
	$(PYTHON) -u tools/db_crashtest.py --simple blackbox $(CRASH_TEST_EXT_ARGS)
	$(PYTHON) -u tools/db_crashtest.py blackbox $(CRASH_TEST_EXT_ARGS)
977

978
blackbox_crash_test_with_atomic_flush: db_stress
979
	$(PYTHON) -u tools/db_crashtest.py --cf_consistency blackbox $(CRASH_TEST_EXT_ARGS)
980

981
blackbox_crash_test_with_txn: db_stress
982
	$(PYTHON) -u tools/db_crashtest.py --txn blackbox $(CRASH_TEST_EXT_ARGS)
983

984 985 986 987
ifeq ($(CRASH_TEST_KILL_ODD),)
  CRASH_TEST_KILL_ODD=888887
endif

988
whitebox_crash_test: db_stress
989
	$(PYTHON) -u tools/db_crashtest.py --simple whitebox --random_kill_odd \
990
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)
991
	$(PYTHON) -u tools/db_crashtest.py whitebox  --random_kill_odd \
992
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)
993

994
whitebox_crash_test_with_atomic_flush: db_stress
995
	$(PYTHON) -u tools/db_crashtest.py --cf_consistency whitebox  --random_kill_odd \
996 997
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)

998
whitebox_crash_test_with_txn: db_stress
999
	$(PYTHON) -u tools/db_crashtest.py --txn whitebox --random_kill_odd \
1000 1001
      $(CRASH_TEST_KILL_ODD) $(CRASH_TEST_EXT_ARGS)

I
Igor Canadi 已提交
1002
asan_check:
Y
Yueh-Hsuan Chiang 已提交
1003 1004 1005
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) check -j32
	$(MAKE) clean
1006 1007

asan_crash_test:
Y
Yueh-Hsuan Chiang 已提交
1008 1009 1010
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test
	$(MAKE) clean
I
Igor Canadi 已提交
1011

1012 1013 1014 1015 1016
asan_crash_test_with_atomic_flush:
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test_with_atomic_flush
	$(MAKE) clean

1017 1018 1019 1020 1021
asan_crash_test_with_txn:
	$(MAKE) clean
	COMPILE_WITH_ASAN=1 $(MAKE) crash_test_with_txn
	$(MAKE) clean

1022 1023 1024 1025 1026 1027 1028 1029 1030 1031
ubsan_check:
	$(MAKE) clean
	COMPILE_WITH_UBSAN=1 $(MAKE) check -j32
	$(MAKE) clean

ubsan_crash_test:
	$(MAKE) clean
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test
	$(MAKE) clean

1032 1033 1034 1035 1036
ubsan_crash_test_with_atomic_flush:
	$(MAKE) clean
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test_with_atomic_flush
	$(MAKE) clean

1037 1038 1039 1040 1041
ubsan_crash_test_with_txn:
	$(MAKE) clean
	COMPILE_WITH_UBSAN=1 $(MAKE) crash_test_with_txn
	$(MAKE) clean

1042
valgrind_test:
1043
	ROCKSDB_VALGRIND_RUN=1 DISABLE_JEMALLOC=1 $(MAKE) valgrind_check
1044

I
Igor Canadi 已提交
1045
valgrind_check: $(TESTS)
1046
	$(MAKE) DRIVER="$(VALGRIND_VER) $(VALGRIND_OPTS)" gen_parallel_tests
S
sdong 已提交
1047
	$(AM_V_GEN)if test "$(J)" != 1                                  \
1048
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
S
sdong 已提交
1049 1050
	        grep -q 'GNU Parallel';                                 \
	then                                                            \
Y
Yi Wu 已提交
1051
      $(MAKE) TMPD=$(TMPD)                                        \
S
sdong 已提交
1052 1053 1054 1055 1056 1057 1058 1059 1060 1061
      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
1062

1063 1064 1065 1066 1067 1068 1069

ifneq ($(PAR_TEST),)
parloop:
	ret_bad=0;							\
	for t in $(PAR_TEST); do		\
		echo "===== Running $$t in parallel $(NUM_PAR)";\
		if [ $(db_test) -eq 1 ]; then \
1070
			seq $(J) | v="$$t" build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{};  export TEST_TMPDIR=$$s;' \
1071 1072
				'timeout 2m ./db_test --gtest_filter=$$v >> $$s/log-{} 2>1'; \
		else\
1073
			seq $(J) | v="./$$t" build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{};' \
1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084
			     '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 已提交
1085 1086 1087 1088 1089 1090 1091
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!'

1092 1093
parallel_check: $(TESTS)
	$(AM_V_GEN)if test "$(J)" > 1                                  \
1094
	    && (build_tools/gnu_parallel --gnu --help 2>/dev/null) |                    \
1095 1096 1097 1098 1099 1100 1101 1102 1103
	        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); \
1104
        seq $(J) | build_tools/gnu_parallel --gnu --plain 's=$(TMPD)/rdb-{}; rm -rf $$s; mkdir $$s'; \
1105
	$(MAKE)  PAR_TEST="$(shell $(test_names))" TMPD=$(TMPD) \
1106 1107 1108 1109
		J=$(J) db_test=1 parloop; \
	$(MAKE) PAR_TEST="$(filter-out db_test, $(TESTS))" \
		TMPD=$(TMPD) J=$(J) db_test=0 parloop;

1110
analyze: clean
1111 1112 1113
	USE_CLANG=1 $(MAKE) analyze_incremental

analyze_incremental:
Y
Yueh-Hsuan Chiang 已提交
1114 1115 1116 1117
	$(CLANG_SCAN_BUILD) --use-analyzer=$(CLANG_ANALYZER) \
		--use-c++=$(CXX) --use-cc=$(CC) --status-bugs \
		-o $(CURDIR)/scan_build_report \
		$(MAKE) dbg
1118

1119 1120
CLEAN_FILES += unity.cc
unity.cc: Makefile
Y
Yueh-Hsuan Chiang 已提交
1121 1122
	rm -f $@ $@-t
	for source_file in $(LIB_SOURCES); do \
E
Evan Shaw 已提交
1123
		echo "#include \"$$source_file\"" >> $@-t; \
Y
Yueh-Hsuan Chiang 已提交
1124 1125 1126
	done
	chmod a=r $@-t
	mv $@-t $@
M
miguelportilla 已提交
1127

E
Evan Shaw 已提交
1128 1129 1130 1131
unity.a: unity.o
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ unity.o

1132 1133

TOOLLIBOBJECTS = $(TOOL_LIB_SOURCES:.cc=.o)
I
Igor Canadi 已提交
1134
# try compiling db_test with unity
1135
unity_test: db/db_test.o db/db_test_util.o $(TESTHARNESS) $(TOOLLIBOBJECTS) unity.a
I
Igor Canadi 已提交
1136 1137 1138
	$(AM_LINK)
	./unity_test

E
Evan Shaw 已提交
1139 1140
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 已提交
1141

1142
clean: clean-ext-libraries-all clean-rocks clean-rocksjava
1143

1144
clean-not-downloaded: clean-ext-libraries-bin clean-rocks clean-not-downloaded-rocksjava
1145 1146

clean-rocks:
1147
	rm -f $(BENCHMARKS) $(TOOLS) $(TESTS) $(PARALLEL_TEST) $(LIBRARY) $(SHARED)
Y
Yueh-Hsuan Chiang 已提交
1148
	rm -rf $(CLEAN_FILES) ios-x86 ios-arm scan_build_report
1149 1150
	$(FIND) . -name "*.[oda]" -exec rm -f {} \;
	$(FIND) . -type f -regex ".*\.\(\(gcda\)\|\(gcno\)\)" -exec rm {} \;
1151 1152 1153 1154 1155 1156

clean-rocksjava:
	cd java && $(MAKE) clean

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

1158 1159 1160 1161 1162 1163
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 {} \;

1164
tags:
1165
	ctags -R .
1166
	cscope -b `$(FIND) . -name '*.cc'` `$(FIND) . -name '*.h'` `$(FIND) . -name '*.c'`
L
Leonidas Galanis 已提交
1167
	ctags -e -R -o etags *
1168

1169 1170 1171 1172 1173 1174 1175
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 *

1176
format:
Y
Yueh-Hsuan Chiang 已提交
1177
	build_tools/format-diff.sh
1178

1179
package:
Y
Yueh-Hsuan Chiang 已提交
1180
	bash build_tools/make_package.sh $(SHARED_MAJOR).$(SHARED_MINOR)
1181

1182 1183 1184
# ---------------------------------------------------------------------------
# 	Unit tests and tools
# ---------------------------------------------------------------------------
1185
$(LIBRARY): $(LIBOBJECTS)
Y
Yueh-Hsuan Chiang 已提交
1186 1187
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $(LIBOBJECTS)
J
jorlow@chromium.org 已提交
1188

1189
$(TOOLS_LIBRARY): $(BENCH_LIB_SOURCES:.cc=.o) $(TOOL_LIB_SOURCES:.cc=.o) $(LIB_SOURCES:.cc=.o) $(TESTUTIL) $(ANALYZER_LIB_SOURCES:.cc=.o)
1190 1191 1192
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

1193 1194 1195 1196
$(STRESS_LIBRARY): $(LIB_SOURCES:.cc=.o) $(TESTUTIL) $(ANALYZER_LIB_SOURCES:.cc=.o) $(STRESS_LIB_SOURCES:.cc=.o)
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

1197
librocksdb_env_basic_test.a: env/env_basic_test.o $(LIBOBJECTS) $(TESTHARNESS)
1198 1199 1200
	$(AM_V_AR)rm -f $@
	$(AM_V_at)$(AR) $(ARFLAGS) $@ $^

1201
db_bench: tools/db_bench.o $(BENCHTOOLOBJECTS)
Y
Yueh-Hsuan Chiang 已提交
1202
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1203

1204 1205 1206
trace_analyzer: tools/trace_analyzer.o $(ANALYZETOOLOBJECTS) $(LIBOBJECTS)
	$(AM_LINK)

1207
block_cache_trace_analyzer: tools/block_cache_analyzer/block_cache_trace_analyzer_tool.o $(ANALYZETOOLOBJECTS) $(LIBOBJECTS)
1208 1209
	$(AM_LINK)

1210 1211 1212 1213 1214
ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
folly_synchronization_distributed_mutex_test: $(LIBOBJECTS) $(TESTHARNESS) $(FOLLYOBJECTS) third-party/folly/folly/synchronization/test/DistributedMutexTest.o
	$(AM_LINK)
endif

1215
cache_bench: cache/cache_bench.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1216
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1217

1218 1219 1220
persistent_cache_bench: utilities/persistent_cache/persistent_cache_bench.o $(LIBOBJECTS) $(TESTUTIL)
	$(AM_LINK)

1221
memtablerep_bench: memtable/memtablerep_bench.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1222
	$(AM_LINK)
A
Ameya Gupte 已提交
1223

1224 1225 1226
filter_bench: util/filter_bench.o $(LIBOBJECTS) $(TESTUTIL)
	$(AM_LINK)

1227
db_stress: db_stress_tool/db_stress.o $(STRESSTOOLOBJECTS)
Y
Yueh-Hsuan Chiang 已提交
1228
	$(AM_LINK)
1229

I
Igor Canadi 已提交
1230 1231 1232
write_stress: tools/write_stress.o $(LIBOBJECTS) $(TESTUTIL)
	$(AM_LINK)

I
Igor Canadi 已提交
1233
db_sanity_test: tools/db_sanity_test.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1234
	$(AM_LINK)
1235

1236
db_repl_stress: tools/db_repl_stress.o $(LIBOBJECTS) $(TESTUTIL)
Y
Yueh-Hsuan Chiang 已提交
1237
	$(AM_LINK)
1238

1239
arena_test: memory/arena_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1240
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1241

K
kailiu 已提交
1242
autovector_test: util/autovector_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1243
	$(AM_LINK)
K
kailiu 已提交
1244

1245
column_family_test: db/column_family_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1246
	$(AM_LINK)
1247

K
kailiu 已提交
1248
table_properties_collector_test: db/table_properties_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1249
	$(AM_LINK)
1250

S
Sanjay Ghemawat 已提交
1251
bloom_test: util/bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1252
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
1253

1254
dynamic_bloom_test: util/dynamic_bloom_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1255
	$(AM_LINK)
1256

1257
c_test: db/c_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1258
	$(AM_LINK)
1259

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

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

1266 1267 1268
hash_test: util/hash_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1269 1270 1271
random_test: util/random_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1272 1273 1274
option_change_migration_test: utilities/option_change_migration/option_change_migration_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1275
stringappend_test: utilities/merge_operators/string_append/stringappend_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1276
	$(AM_LINK)
1277

1278
cassandra_format_test: utilities/cassandra/cassandra_format_test.o utilities/cassandra/test_utils.o $(LIBOBJECTS) $(TESTHARNESS)
1279 1280
	$(AM_LINK)

1281
cassandra_functional_test: utilities/cassandra/cassandra_functional_test.o utilities/cassandra/test_utils.o $(LIBOBJECTS) $(TESTHARNESS)
1282 1283
	$(AM_LINK)

1284
cassandra_row_merge_test: utilities/cassandra/cassandra_row_merge_test.o utilities/cassandra/test_utils.o $(LIBOBJECTS) $(TESTHARNESS)
1285 1286
	$(AM_LINK)

1287
cassandra_serialize_test: utilities/cassandra/cassandra_serialize_test.o $(LIBOBJECTS) $(TESTHARNESS)
1288 1289
	$(AM_LINK)

1290 1291 1292
hash_table_test: utilities/persistent_cache/hash_table_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1293
histogram_test: monitoring/histogram_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1294
	$(AM_LINK)
A
Abhishek Kona 已提交
1295

L
Lei Jin 已提交
1296
thread_local_test: util/thread_local_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1297
	$(AM_LINK)
L
Lei Jin 已提交
1298

1299 1300 1301
work_queue_test: util/work_queue_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

S
sdong 已提交
1302
corruption_test: db/corruption_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1303
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1304 1305

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

1308 1309 1310
slice_test: util/slice_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1311
slice_transform_test: util/slice_transform_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1312
	$(AM_LINK)
1313

1314
db_basic_test: db/db_basic_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
E
Ewout Prangsma 已提交
1315 1316
	$(AM_LINK)

1317 1318 1319
db_with_timestamp_basic_test: db/db_with_timestamp_basic_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

E
Ewout Prangsma 已提交
1320
db_encryption_test: db/db_encryption_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1321 1322
	$(AM_LINK)

1323
db_test: db/db_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yueh-Hsuan Chiang 已提交
1324
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1325

1326 1327 1328
db_test2: db/db_test2.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1329 1330 1331
db_logical_block_size_cache_test: db/db_logical_block_size_cache_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1332
db_blob_index_test: db/blob/db_blob_index_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yi Wu 已提交
1333 1334
	$(AM_LINK)

1335 1336 1337
db_block_cache_test: db/db_block_cache_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

Y
Yi Wu 已提交
1338 1339 1340
db_bloom_filter_test: db/db_bloom_filter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1341
db_log_iter_test: db/db_log_iter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1342
	$(AM_LINK)
1343

1344
db_compaction_filter_test: db/db_compaction_filter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1345 1346
	$(AM_LINK)

1347
db_compaction_test: db/db_compaction_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1348 1349
	$(AM_LINK)

1350
db_dynamic_level_test: db/db_dynamic_level_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1351 1352
	$(AM_LINK)

1353 1354 1355
db_flush_test: db/db_flush_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1356
db_inplace_update_test: db/db_inplace_update_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1357 1358
	$(AM_LINK)

Y
Yi Wu 已提交
1359 1360 1361
db_iterator_test: db/db_iterator_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1362 1363 1364
db_memtable_test: db/db_memtable_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1365 1366 1367
db_merge_operator_test: db/db_merge_operator_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1368 1369
db_merge_operand_test: db/db_merge_operand_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)
1370

1371 1372 1373
db_options_test: db/db_options_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1374 1375 1376
db_range_del_test: db/db_range_del_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

Y
Yi Wu 已提交
1377 1378 1379
db_sst_test: db/db_sst_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1380 1381 1382
db_statistics_test: db/db_statistics_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

Y
Yi Wu 已提交
1383 1384 1385
db_write_test: db/db_write_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1386
error_handler_fs_test: db/error_handler_fs_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1387 1388
	$(AM_LINK)

S
Siying Dong 已提交
1389 1390 1391
external_sst_file_basic_test: db/external_sst_file_basic_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1392 1393 1394
external_sst_file_test: db/external_sst_file_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1395 1396 1397
import_column_family_test: db/import_column_family_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1398
db_tailing_iter_test: db/db_tailing_iter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1399 1400
	$(AM_LINK)

S
Stanislau Hlebik 已提交
1401
db_iter_test: db/db_iter_test.o $(LIBOBJECTS) $(TESTHARNESS)
1402
	$(AM_LINK)
S
Stanislau Hlebik 已提交
1403

1404 1405 1406
db_iter_stress_test: db/db_iter_stress_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1407
db_universal_compaction_test: db/db_universal_compaction_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1408 1409
	$(AM_LINK)

1410
db_wal_test: db/db_wal_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
S
sdong 已提交
1411 1412
	$(AM_LINK)

O
omegaga 已提交
1413 1414 1415
db_io_failure_test: db/db_io_failure_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1416 1417 1418
db_properties_test: db/db_properties_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1419 1420 1421
db_table_properties_test: db/db_table_properties_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1422
log_write_bench: util/log_write_bench.o $(LIBOBJECTS) $(TESTHARNESS)
D
dx9 已提交
1423
	$(AM_LINK) $(PROFILING_FLAGS)
1424

S
Siying Dong 已提交
1425
plain_table_db_test: db/plain_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1426
	$(AM_LINK)
S
Siying Dong 已提交
1427

1428
comparator_db_test: db/comparator_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1429
	$(AM_LINK)
1430

1431
table_reader_bench: table/table_reader_bench.o $(LIBOBJECTS) $(TESTHARNESS)
D
dx9 已提交
1432
	$(AM_LINK) $(PROFILING_FLAGS)
1433

1434
perf_context_test: db/perf_context_test.o $(LIBOBJECTS) $(TESTHARNESS)
1435
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)
1436

H
Haobo Xu 已提交
1437
prefix_test: db/prefix_test.o $(LIBOBJECTS) $(TESTHARNESS)
1438
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)
H
Haobo Xu 已提交
1439

I
Igor Canadi 已提交
1440
backupable_db_test: utilities/backupable/backupable_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1441
	$(AM_LINK)
I
Igor Canadi 已提交
1442

1443 1444 1445
checkpoint_test: utilities/checkpoint/checkpoint_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1446 1447 1448
cache_simulator_test: utilities/simulator_cache/cache_simulator_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1449 1450 1451
sim_cache_test: utilities/simulator_cache/sim_cache_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

S
Sage Weil 已提交
1452 1453 1454
env_mirror_test: utilities/env_mirror_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
Andrew Kryczka 已提交
1455 1456 1457
env_timed_test: utilities/env_timed_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1458 1459 1460 1461 1462
ifdef ROCKSDB_USE_LIBRADOS
env_librados_test: utilities/env_librados_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS) $(COVERAGEFLAGS)
endif

1463
object_registry_test: utilities/object_registry_test.o $(LIBOBJECTS) $(TESTHARNESS)
1464 1465
	$(AM_LINK)

1466
ttl_test: utilities/ttl/ttl_test.o $(LIBOBJECTS) $(TESTHARNESS)
1467
	$(AM_LINK)
1468

1469
write_batch_with_index_test: utilities/write_batch_with_index/write_batch_with_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
1470
	$(AM_LINK)
1471

I
Igor Canadi 已提交
1472
flush_job_test: db/flush_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
1473
	$(AM_LINK)
A
Andres Noetzli 已提交
1474

1475
compaction_iterator_test: db/compaction/compaction_iterator_test.o $(LIBOBJECTS) $(TESTHARNESS)
A
Andres Noetzli 已提交
1476
	$(AM_LINK)
I
Igor Canadi 已提交
1477

1478
compaction_job_test: db/compaction/compaction_job_test.o $(LIBOBJECTS) $(TESTHARNESS)
1479
	$(AM_LINK)
I
Igor Canadi 已提交
1480

1481
compaction_job_stats_test: db/compaction/compaction_job_stats_test.o $(LIBOBJECTS) $(TESTHARNESS)
1482 1483
	$(AM_LINK)

1484 1485 1486
compact_on_deletion_collector_test: utilities/table_properties_collectors/compact_on_deletion_collector_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

I
Igor Canadi 已提交
1487
wal_manager_test: db/wal_manager_test.o $(LIBOBJECTS) $(TESTHARNESS)
1488
	$(AM_LINK)
I
Igor Canadi 已提交
1489

J
jorlow@chromium.org 已提交
1490
dbformat_test: db/dbformat_test.o $(LIBOBJECTS) $(TESTHARNESS)
1491
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1492

1493
env_basic_test: env/env_basic_test.o $(LIBOBJECTS) $(TESTHARNESS)
1494 1495
	$(AM_LINK)

1496
env_test: env/env_test.o $(LIBOBJECTS) $(TESTHARNESS)
1497
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1498

1499 1500 1501
io_posix_test: env/io_posix_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1502
fault_injection_test: db/fault_injection_test.o $(LIBOBJECTS) $(TESTHARNESS)
1503
	$(AM_LINK)
1504

A
Andrew Kryczka 已提交
1505
rate_limiter_test: util/rate_limiter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1506
	$(AM_LINK)
L
Lei Jin 已提交
1507

1508
delete_scheduler_test: file/delete_scheduler_test.o $(LIBOBJECTS) $(TESTHARNESS)
I
Islam AbdelRahman 已提交
1509 1510
	$(AM_LINK)

J
jorlow@chromium.org 已提交
1511
filename_test: db/filename_test.o $(LIBOBJECTS) $(TESTHARNESS)
1512
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1513

1514 1515 1516
random_access_file_reader_test: file/random_access_file_reader_test.o $(LIBOBJECTS) $(TESTHARNESS) $(TESTUTIL)
	$(AM_LINK)

1517 1518 1519
file_reader_writer_test: util/file_reader_writer_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1520
block_based_filter_block_test: table/block_based/block_based_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
1521
	$(AM_LINK)
1522

1523
full_filter_block_test: table/block_based/full_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
1524
	$(AM_LINK)
S
Sanjay Ghemawat 已提交
1525

1526
partitioned_filter_block_test: table/block_based/partitioned_filter_block_test.o $(LIBOBJECTS) $(TESTHARNESS)
M
Maysam Yabandeh 已提交
1527 1528
	$(AM_LINK)

J
jorlow@chromium.org 已提交
1529
log_test: db/log_test.o $(LIBOBJECTS) $(TESTHARNESS)
M
Maysam Yabandeh 已提交
1530 1531 1532
	$(AM_LINK)

cleanable_test: table/cleanable_test.o $(LIBOBJECTS) $(TESTHARNESS)
1533
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1534 1535

table_test: table/table_test.o $(LIBOBJECTS) $(TESTHARNESS)
1536
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1537

1538
block_test: table/block_based/block_test.o $(LIBOBJECTS) $(TESTHARNESS)
1539
	$(AM_LINK)
D
Dhruba Borthakur 已提交
1540

1541
data_block_hash_index_test: table/block_based/data_block_hash_index_test.o $(LIBOBJECTS) $(TESTHARNESS)
1542 1543
	$(AM_LINK)

1544
inlineskiplist_test: memtable/inlineskiplist_test.o $(LIBOBJECTS) $(TESTHARNESS)
N
Nathan Bronson 已提交
1545 1546
	$(AM_LINK)

1547
skiplist_test: memtable/skiplist_test.o $(LIBOBJECTS) $(TESTHARNESS)
1548
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1549

1550 1551 1552
write_buffer_manager_test: memtable/write_buffer_manager_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
jorlow@chromium.org 已提交
1553
version_edit_test: db/version_edit_test.o $(LIBOBJECTS) $(TESTHARNESS)
1554
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1555

1556
version_set_test: db/version_set_test.o $(LIBOBJECTS) $(TESTHARNESS)
1557
	$(AM_LINK)
1558

1559
compaction_picker_test: db/compaction/compaction_picker_test.o $(LIBOBJECTS) $(TESTHARNESS)
1560
	$(AM_LINK)
S
sdong 已提交
1561

S
sdong 已提交
1562
version_builder_test: db/version_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
1563
	$(AM_LINK)
S
sdong 已提交
1564

1565
file_indexer_test: db/file_indexer_test.o $(LIBOBJECTS) $(TESTHARNESS)
1566
	$(AM_LINK)
1567

1568
reduce_levels_test: tools/reduce_levels_test.o $(LIBOBJECTS) $(TESTHARNESS)
1569
	$(AM_LINK)
1570

J
jorlow@chromium.org 已提交
1571
write_batch_test: db/write_batch_test.o $(LIBOBJECTS) $(TESTHARNESS)
1572
	$(AM_LINK)
1573

1574
write_controller_test: db/write_controller_test.o $(LIBOBJECTS) $(TESTHARNESS)
1575
	$(AM_LINK)
1576

1577 1578 1579
merge_helper_test: db/merge_helper_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1580 1581 1582
memory_test: utilities/memory/memory_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

J
Jim Paton 已提交
1583
merge_test: db/merge_test.o $(LIBOBJECTS) $(TESTHARNESS)
1584
	$(AM_LINK)
J
jorlow@chromium.org 已提交
1585

I
Igor Canadi 已提交
1586
merger_test: table/merger_test.o $(LIBOBJECTS) $(TESTHARNESS)
1587
	$(AM_LINK)
I
Igor Canadi 已提交
1588

1589 1590 1591
util_merge_operators_test: utilities/util_merge_operators_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1592 1593 1594
options_file_test: db/options_file_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

Y
Yanqin Jin 已提交
1595
deletefile_test: db/deletefile_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1596
	$(AM_LINK)
1597

1598
obsolete_files_test: db/obsolete_files_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1599 1600
	$(AM_LINK)

1601 1602 1603 1604 1605 1606
rocksdb_dump: tools/dump/rocksdb_dump.o $(LIBOBJECTS)
	$(AM_LINK)

rocksdb_undump: tools/dump/rocksdb_undump.o $(LIBOBJECTS)
	$(AM_LINK)

1607
cuckoo_table_builder_test: table/cuckoo/cuckoo_table_builder_test.o $(LIBOBJECTS) $(TESTHARNESS)
1608
	$(AM_LINK)
1609

1610
cuckoo_table_reader_test: table/cuckoo/cuckoo_table_reader_test.o $(LIBOBJECTS) $(TESTHARNESS)
1611
	$(AM_LINK)
1612

1613
cuckoo_table_db_test: db/cuckoo_table_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
1614
	$(AM_LINK)
1615

1616
listener_test: db/listener_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1617
	$(AM_LINK)
1618

Y
Yueh-Hsuan Chiang 已提交
1619
thread_list_test: util/thread_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
1620
	$(AM_LINK)
Y
Yueh-Hsuan Chiang 已提交
1621

1622 1623 1624
compact_files_test: db/compact_files_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1625
options_test: options/options_test.o $(LIBOBJECTS) $(TESTHARNESS)
1626 1627
	$(AM_LINK)

1628
options_settable_test: options/options_settable_test.o $(LIBOBJECTS) $(TESTHARNESS)
1629
	$(AM_LINK)
1630

1631 1632 1633
options_util_test: utilities/options/options_util_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1634 1635 1636
db_bench_tool_test: tools/db_bench_tool_test.o $(BENCHTOOLOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1637
trace_analyzer_test: tools/trace_analyzer_test.o $(LIBOBJECTS) $(ANALYZETOOLOBJECTS) $(TESTHARNESS)
Z
Zhichao Cao 已提交
1638 1639
	$(AM_LINK)

1640
event_logger_test: logging/event_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
I
Igor Canadi 已提交
1641 1642
	$(AM_LINK)

A
Anirban Rahut 已提交
1643 1644 1645
timer_queue_test: util/timer_queue_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1646
sst_dump_test: tools/sst_dump_test.o $(LIBOBJECTS) $(TESTHARNESS)
1647
	$(AM_LINK)
1648

A
agiardullo 已提交
1649 1650 1651
optimistic_transaction_test: utilities/transactions/optimistic_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1652
mock_env_test : env/mock_env_test.o $(LIBOBJECTS) $(TESTHARNESS)
1653
	$(AM_LINK)
1654

1655
manual_compaction_test: db/manual_compaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
1656
	$(AM_LINK)
1657

1658
filelock_test: util/filelock_test.o $(LIBOBJECTS) $(TESTHARNESS)
1659
	$(AM_LINK)
K
Kai Liu 已提交
1660

1661
auto_roll_logger_test: logging/auto_roll_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
1662
	$(AM_LINK)
1663

1664 1665 1666
env_logger_test: logging/env_logger_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
agiardullo 已提交
1667 1668 1669
memtable_list_test: db/memtable_list_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

A
agiardullo 已提交
1670 1671 1672
write_callback_test: db/write_callback_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1673 1674 1675
heap_test: util/heap_test.o $(GTEST)
	$(AM_LINK)

A
agiardullo 已提交
1676 1677 1678
transaction_test: utilities/transactions/transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1679 1680 1681
write_prepared_transaction_test: utilities/transactions/write_prepared_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1682 1683 1684
write_unprepared_transaction_test: utilities/transactions/write_unprepared_transaction_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1685
sst_dump: tools/sst_dump.o $(LIBOBJECTS)
1686
	$(AM_LINK)
1687

Y
Yi Wu 已提交
1688 1689 1690
blob_dump: tools/blob_dump.o $(LIBOBJECTS)
	$(AM_LINK)

A
Andrew Kryczka 已提交
1691 1692 1693
repair_test: db/repair_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1694
ldb_cmd_test: tools/ldb_cmd_test.o $(LIBOBJECTS) $(TESTHARNESS)
1695 1696
	$(AM_LINK)

1697
ldb: tools/ldb.o $(LIBOBJECTS)
1698
	$(AM_LINK)
1699

1700
iostats_context_test: monitoring/iostats_context_test.o $(LIBOBJECTS) $(TESTHARNESS)
1701 1702
	$(AM_V_CCLD)$(CXX) $^ $(EXEC_LDFLAGS) -o $@ $(LDFLAGS)

1703 1704 1705
persistent_cache_test: utilities/persistent_cache/persistent_cache_test.o  db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1706
statistics_test: monitoring/statistics_test.o $(LIBOBJECTS) $(TESTHARNESS)
1707 1708
	$(AM_LINK)

1709 1710 1711
stats_history_test: monitoring/stats_history_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1712
lru_cache_test: cache/lru_cache_test.o $(LIBOBJECTS) $(TESTHARNESS)
Y
Yi Wu 已提交
1713 1714
	$(AM_LINK)

A
Andrew Kryczka 已提交
1715 1716 1717
range_del_aggregator_test: db/range_del_aggregator_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1718 1719 1720
range_del_aggregator_bench: db/range_del_aggregator_bench.o $(LIBOBJECTS) $(TESTUTIL)
	$(AM_LINK)

Y
Yi Wu 已提交
1721 1722 1723
blob_db_test: utilities/blob_db/blob_db_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1724 1725 1726
repeatable_thread_test: util/repeatable_thread_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1727 1728 1729
range_tombstone_fragmenter_test: db/range_tombstone_fragmenter_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1730 1731 1732
sst_file_reader_test: table/sst_file_reader_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1733
db_secondary_test: db/db_impl/db_secondary_test.o db/db_test_util.o $(LIBOBJECTS) $(TESTHARNESS)
1734 1735
	$(AM_LINK)

H
haoyuhuang 已提交
1736 1737 1738
block_cache_tracer_test: trace_replay/block_cache_tracer_test.o trace_replay/block_cache_tracer.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1739
block_cache_trace_analyzer_test: tools/block_cache_analyzer/block_cache_trace_analyzer_test.o tools/block_cache_analyzer/block_cache_trace_analyzer.o $(LIBOBJECTS) $(TESTHARNESS)
1740 1741
	$(AM_LINK)

C
Cheng Chang 已提交
1742 1743 1744
defer_test: util/defer_test.o $(LIBOBJECTS) $(TESTHARNESS)
	$(AM_LINK)

1745
blob_file_addition_test: db/blob/blob_file_addition_test.o $(LIBOBJECTS) $(TESTHARNESS)
1746 1747
	$(AM_LINK)

1748
blob_file_garbage_test: db/blob/blob_file_garbage_test.o $(LIBOBJECTS) $(TESTHARNESS)
1749 1750
	$(AM_LINK)

I
Igor Canadi 已提交
1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764
#-------------------------------------------------
# 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
1765
	for header_dir in `$(FIND) "include/rocksdb" -type d`; do \
I
Igor Canadi 已提交
1766 1767
		install -d $(INSTALL_PATH)/$$header_dir; \
	done
1768
	for header in `$(FIND) "include/rocksdb" -type f -name *.h`; do \
I
Igor Canadi 已提交
1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782
		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 已提交
1783
	[ -e $(SHARED4) ] && $(MAKE) install-shared || :
I
Igor Canadi 已提交
1784 1785 1786 1787

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


1788 1789 1790 1791
# ---------------------------------------------------------------------------
# Jni stuff
# ---------------------------------------------------------------------------

1792
JAVA_INCLUDE = -I$(JAVA_HOME)/include/ -I$(JAVA_HOME)/include/linux
D
David Bernard 已提交
1793 1794
ifeq ($(PLATFORM), OS_SOLARIS)
	ARCH := $(shell isainfo -b)
1795
else ifeq ($(PLATFORM), OS_OPENBSD)
1796
	ifneq (,$(filter amd64 ppc64 ppc64le arm64 aarch64 sparc64, $(MACHINE)))
1797 1798 1799 1800
		ARCH := 64
	else
		ARCH := 32
	endif
D
David Bernard 已提交
1801 1802 1803
else
	ARCH := $(shell getconf LONG_BIT)
endif
1804

1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815
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

1816
ifneq (,$(filter ppc% arm64 aarch64 sparc64, $(MACHINE)))
1817
	ROCKSDBJNILIB = librocksdbjni-linux-$(MACHINE)$(JNI_LIBC_POSTFIX).so
1818
else
1819
	ROCKSDBJNILIB = librocksdbjni-linux$(ARCH)$(JNI_LIBC_POSTFIX).so
1820
endif
1821
ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-linux$(ARCH)$(JNI_LIBC_POSTFIX).jar
1822
ROCKSDB_JAR_ALL = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH).jar
C
Chris Riccomini 已提交
1823
ROCKSDB_JAVADOCS_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-javadoc.jar
1824
ROCKSDB_SOURCES_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-sources.jar
1825 1826
SHA256_CMD = sha256sum

T
Tomas Kolda 已提交
1827 1828 1829 1830 1831
ZLIB_VER ?= 1.2.11
ZLIB_SHA256 ?= c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1
ZLIB_DOWNLOAD_BASE ?= http://zlib.net
BZIP2_VER ?= 1.0.6
BZIP2_SHA256 ?= a2848f34fcd5d6cf47def00461fcb528a0484d8edef8208d6d2e2909dc61d9cd
1832
BZIP2_DOWNLOAD_BASE ?= https://downloads.sourceforge.net/project/bzip2
1833 1834
SNAPPY_VER ?= 1.1.8
SNAPPY_SHA256 ?= 16b677f07832a612b0836178db7f374e414f94657c138e6993cbfc5dcc58651f
1835
SNAPPY_DOWNLOAD_BASE ?= https://github.com/google/snappy/archive
1836 1837
LZ4_VER ?= 1.9.2
LZ4_SHA256 ?= 658ba6191fa44c92280d4aa2c271b0f4fbc0e34d249578dd05e50e76d0e5efcc
T
Tomas Kolda 已提交
1838
LZ4_DOWNLOAD_BASE ?= https://github.com/lz4/lz4/archive
1839 1840
ZSTD_VER ?= 1.4.4
ZSTD_SHA256 ?= a364f5162c7d1a455cc915e8e3cf5f4bd8b75d09bc0f53965b0c9ca1383c52c8
1841
ZSTD_DOWNLOAD_BASE ?= https://github.com/facebook/zstd/archive
P
Pengchao Wang 已提交
1842
CURL_SSL_OPTS ?= --tlsv1
1843 1844

ifeq ($(PLATFORM), OS_MACOSX)
D
David Bernard 已提交
1845 1846
	ROCKSDBJNILIB = librocksdbjni-osx.jnilib
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-osx.jar
1847
	SHA256_CMD = openssl sha256 -r
1848 1849 1850 1851 1852
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
1853
endif
1854
ifeq ($(PLATFORM), OS_FREEBSD)
1855
	JAVA_INCLUDE = -I$(JAVA_HOME)/include -I$(JAVA_HOME)/include/freebsd
1856 1857 1858
	ROCKSDBJNILIB = librocksdbjni-freebsd$(ARCH).so
	ROCKSDB_JAR = rocksdbjni-$(ROCKSDB_MAJOR).$(ROCKSDB_MINOR).$(ROCKSDB_PATCH)-freebsd$(ARCH).jar
endif
D
David Bernard 已提交
1859 1860 1861 1862
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
1863
	SHA256_CMD = digest -a sha256
D
David Bernard 已提交
1864
endif
T
Tomas Kolda 已提交
1865 1866 1867 1868 1869 1870
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
1871 1872 1873 1874 1875
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
1876

N
Naveen 已提交
1877
libz.a:
1878
	-rm -rf zlib-$(ZLIB_VER)
1879
ifeq (,$(wildcard ./zlib-$(ZLIB_VER).tar.gz))
1880
	curl --fail --output zlib-$(ZLIB_VER).tar.gz --location ${ZLIB_DOWNLOAD_BASE}/zlib-$(ZLIB_VER).tar.gz
1881
endif
1882 1883 1884 1885 1886 1887
	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
1888
	cd zlib-$(ZLIB_VER) && CFLAGS='-fPIC ${EXTRA_CFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' ./configure --static && $(MAKE)
1889
	cp zlib-$(ZLIB_VER)/libz.a .
N
Naveen 已提交
1890 1891

libbz2.a:
1892
	-rm -rf bzip2-$(BZIP2_VER)
1893
ifeq (,$(wildcard ./bzip2-$(BZIP2_VER).tar.gz))
1894
	curl --fail --output bzip2-$(BZIP2_VER).tar.gz --location ${CURL_SSL_OPTS} ${BZIP2_DOWNLOAD_BASE}/bzip2-$(BZIP2_VER).tar.gz
1895
endif
1896 1897 1898 1899 1900 1901
	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
1902
	cd bzip2-$(BZIP2_VER) && $(MAKE) CFLAGS='-fPIC -O2 -g -D_FILE_OFFSET_BITS=64 ${EXTRA_CFLAGS}' AR='ar ${EXTRA_ARFLAGS}'
1903
	cp bzip2-$(BZIP2_VER)/libbz2.a .
N
Naveen 已提交
1904

N
Naveen 已提交
1905
libsnappy.a:
1906
	-rm -rf snappy-$(SNAPPY_VER)
1907
ifeq (,$(wildcard ./snappy-$(SNAPPY_VER).tar.gz))
1908
	curl --fail --output snappy-$(SNAPPY_VER).tar.gz --location ${CURL_SSL_OPTS} ${SNAPPY_DOWNLOAD_BASE}/$(SNAPPY_VER).tar.gz
1909
endif
1910 1911 1912 1913 1914
	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
1915
	tar xvzf snappy-$(SNAPPY_VER).tar.gz
1916
	mkdir snappy-$(SNAPPY_VER)/build
1917
	cd snappy-$(SNAPPY_VER)/build && CFLAGS='${EXTRA_CFLAGS}' CXXFLAGS='${EXTRA_CXXFLAGS}' LDFLAGS='${EXTRA_LDFLAGS}' cmake -DCMAKE_POSITION_INDEPENDENT_CODE=ON .. && $(MAKE) ${SNAPPY_MAKE_TARGET}
1918
	cp snappy-$(SNAPPY_VER)/build/libsnappy.a .
1919

1920
liblz4.a:
1921
	-rm -rf lz4-$(LZ4_VER)
1922
ifeq (,$(wildcard ./lz4-$(LZ4_VER).tar.gz))
1923
	curl --fail --output lz4-$(LZ4_VER).tar.gz --location ${CURL_SSL_OPTS} ${LZ4_DOWNLOAD_BASE}/v$(LZ4_VER).tar.gz
1924
endif
1925 1926 1927 1928 1929 1930
	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
1931
	cd lz4-$(LZ4_VER)/lib && $(MAKE) CFLAGS='-fPIC -O2 ${EXTRA_CFLAGS}' all
1932
	cp lz4-$(LZ4_VER)/lib/liblz4.a .
N
Naveen 已提交
1933

1934 1935
libzstd.a:
	-rm -rf zstd-$(ZSTD_VER)
1936
ifeq (,$(wildcard ./zstd-$(ZSTD_VER).tar.gz))
1937
	curl --fail --output zstd-$(ZSTD_VER).tar.gz --location ${CURL_SSL_OPTS} ${ZSTD_DOWNLOAD_BASE}/v$(ZSTD_VER).tar.gz
1938
endif
1939 1940 1941 1942 1943 1944
	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
1945
	cd zstd-$(ZSTD_VER)/lib && DESTDIR=. PREFIX= $(MAKE) CFLAGS='-fPIC -O2 ${EXTRA_CFLAGS}' install
1946 1947
	cp zstd-$(ZSTD_VER)/lib/libzstd.a .

1948
# A version of each $(LIBOBJECTS) compiled with -fPIC and a fixed set of static compression libraries
A
Andrew Kryczka 已提交
1949
java_static_libobjects = $(patsubst %,jls/%,$(LIB_CC_OBJECTS))
1950
CLEAN_FILES += jls
A
Andrew Kryczka 已提交
1951
java_static_all_libobjects = $(java_static_libobjects)
1952

1953
ifneq ($(ROCKSDB_JAVA_NO_COMPRESSION), 1)
1954
JAVA_COMPRESSIONS = libz.a libbz2.a libsnappy.a liblz4.a libzstd.a
1955 1956
endif

1957
JAVA_STATIC_FLAGS = -DZLIB -DBZIP2 -DSNAPPY -DLZ4 -DZSTD
1958
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
1959

A
Andrew Kryczka 已提交
1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971 1972 1973 1974
ifeq ($(HAVE_POWER8),1)
JAVA_STATIC_C_LIBOBJECTS = $(patsubst %.c.o,jls/%.c.o,$(LIB_SOURCES_C:.c=.o))
JAVA_STATIC_ASM_LIBOBJECTS = $(patsubst %.S.o,jls/%.S.o,$(LIB_SOURCES_ASM:.S=.o))

java_static_ppc_libobjects = $(JAVA_STATIC_C_LIBOBJECTS) $(JAVA_STATIC_ASM_LIBOBJECTS)

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

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

java_static_all_libobjects += $(java_static_ppc_libobjects)
endif

1975
$(java_static_libobjects): jls/%.o: %.cc $(JAVA_COMPRESSIONS)
1976
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) $(JAVA_STATIC_FLAGS) $(JAVA_STATIC_INCLUDES) -fPIC -c $< -o $@ $(COVERAGEFLAGS)
1977

A
Andrew Kryczka 已提交
1978
rocksdbjavastatic: $(java_static_all_libobjects)
F
fyrz 已提交
1979
	cd java;$(MAKE) javalib;
1980
	rm -f ./java/target/$(ROCKSDBJNILIB)
1981 1982
	$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC \
	  -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) \
A
Andrew Kryczka 已提交
1983
	  $(java_static_all_libobjects) $(COVERAGEFLAGS) \
1984
	  $(JAVA_COMPRESSIONS) $(JAVA_STATIC_LDFLAGS)
1985 1986 1987
	cd java/target;if [ "$(DEBUG_LEVEL)" == "0" ]; then \
		strip $(STRIPFLAGS) $(ROCKSDBJNILIB); \
	fi
1988 1989 1990 1991 1992
	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 已提交
1993

1994
rocksdbjavastaticrelease: rocksdbjavastatic
1995
	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
1996
	cd java;jar -cf target/$(ROCKSDB_JAR_ALL) HISTORY*.md
1997
	cd java/target;jar -uf $(ROCKSDB_JAR_ALL) librocksdbjni-*.so librocksdbjni-*.jnilib
1998
	cd java/target/classes;jar -uf ../$(ROCKSDB_JAR_ALL) org/rocksdb/*.class org/rocksdb/util/*.class
1999

2000
rocksdbjavastaticreleasedocker: rocksdbjavastatic rocksdbjavastaticdockerx86 rocksdbjavastaticdockerx86_64 rocksdbjavastaticdockerx86musl rocksdbjavastaticdockerx86_64musl
2001 2002 2003 2004 2005 2006
	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
2007
	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
2008 2009 2010

rocksdbjavastaticdockerx86_64:
	mkdir -p java/target
2011
	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
2012

2013 2014
rocksdbjavastaticdockerppc64le:
	mkdir -p java/target
2015
	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
2016

2017 2018
rocksdbjavastaticdockerarm64v8:
	mkdir -p java/target
2019
	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
2020

2021 2022
rocksdbjavastaticdockerx86musl:
	mkdir -p java/target
2023
	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
2024 2025 2026

rocksdbjavastaticdockerx86_64musl:
	mkdir -p java/target
2027
	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
2028 2029 2030

rocksdbjavastaticdockerppc64lemusl:
	mkdir -p java/target
2031
	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
2032 2033 2034

rocksdbjavastaticdockerarm64v8musl:
	mkdir -p java/target
2035
	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
2036

2037 2038
rocksdbjavastaticpublish: rocksdbjavastaticrelease rocksdbjavastaticpublishcentral

2039 2040
rocksdbjavastaticpublishdocker: rocksdbjavastaticreleasedocker rocksdbjavastaticpublishcentral

2041
rocksdbjavastaticpublishcentral:
2042 2043 2044 2045
	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
2046 2047
	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
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)-osx.jar -Dclassifier=osx
2049
	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
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).jar
2051

2052
# A version of each $(LIBOBJECTS) compiled with -fPIC
2053 2054 2055 2056 2057 2058 2059 2060 2061
ifeq ($(HAVE_POWER8),1)
JAVA_CC_OBJECTS = $(SHARED_CC_OBJECTS)
JAVA_C_OBJECTS = $(SHARED_C_OBJECTS)
JAVA_ASM_OBJECTS = $(SHARED_ASM_OBJECTS)

JAVA_C_LIBOBJECTS = $(patsubst %.c.o,jl/%.c.o,$(JAVA_C_OBJECTS))
JAVA_ASM_LIBOBJECTS = $(patsubst %.S.o,jl/%.S.o,$(JAVA_ASM_OBJECTS))
endif

S
Sagar Vemuri 已提交
2062
java_libobjects = $(patsubst %,jl/%,$(LIB_CC_OBJECTS))
2063
CLEAN_FILES += jl
2064 2065 2066 2067 2068 2069 2070 2071 2072 2073 2074 2075
java_all_libobjects = $(java_libobjects)

ifeq ($(HAVE_POWER8),1)
java_ppc_libobjects = $(JAVA_C_LIBOBJECTS) $(JAVA_ASM_LIBOBJECTS)

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 $@
java_all_libobjects += $(java_ppc_libobjects)
endif
2076

2077
$(java_libobjects): jl/%.o: %.cc
2078 2079
	$(AM_V_CC)mkdir -p $(@D) && $(CXX) $(CXXFLAGS) -fPIC -c $< -o $@ $(COVERAGEFLAGS)

2080 2081 2082


rocksdbjava: $(java_all_libobjects)
2083 2084
	$(AM_V_GEN)cd java;$(MAKE) javalib;
	$(AM_V_at)rm -f ./java/target/$(ROCKSDBJNILIB)
2085
	$(AM_V_at)$(CXX) $(CXXFLAGS) -I./java/. $(JAVA_INCLUDE) -shared -fPIC -o ./java/target/$(ROCKSDBJNILIB) $(JNI_NATIVE_SOURCES) $(java_all_libobjects) $(JAVA_LDFLAGS) $(COVERAGEFLAGS)
2086 2087 2088
	$(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
2089 2090 2091 2092

jclean:
	cd java;$(MAKE) clean;

2093 2094 2095 2096 2097 2098
jtest_compile: rocksdbjava
	cd java;$(MAKE) java_test

jtest_run:
	cd java;$(MAKE) run_test

2099
jtest: rocksdbjava
2100
	cd java;$(MAKE) sample;$(MAKE) test;
2101
	$(PYTHON) tools/check_all_python.py # TODO peterd: find a better place for this check in CI targets
2102

2103 2104 2105
jdb_bench:
	cd java;$(MAKE) db_bench;

2106 2107
commit_prereq: build_tools/rocksdb-lego-determinator \
               build_tools/precommit_checker.py
2108
	J=$(J) build_tools/precommit_checker.py unit unit_481 clang_unit release release_481 clang_release tsan asan ubsan lite unit_non_shm
2109
	$(MAKE) clean && $(MAKE) jclean && $(MAKE) rocksdbjava;
2110

2111 2112 2113
# ---------------------------------------------------------------------------
#  	Platform-specific compilation
# ---------------------------------------------------------------------------
J
Jim Paton 已提交
2114

2115 2116 2117
ifeq ($(PLATFORM), IOS)
# For iOS, create universal object files to be used on both the simulator and
# a device.
2118 2119
XCODEROOT=$(shell xcode-select -print-path)
PLATFORMSROOT=$(XCODEROOT)/Platforms
H
heyongqiang 已提交
2120 2121
SIMULATORROOT=$(PLATFORMSROOT)/iPhoneSimulator.platform/Developer
DEVICEROOT=$(PLATFORMSROOT)/iPhoneOS.platform/Developer
I
Igor Canadi 已提交
2122
IOSVERSION=$(shell defaults read $(PLATFORMSROOT)/iPhoneOS.platform/version CFBundleShortVersionString)
2123

2124 2125
.cc.o:
	mkdir -p ios-x86/$(dir $@)
I
Igor Canadi 已提交
2126
	$(CXX) $(CXXFLAGS) -isysroot $(SIMULATORROOT)/SDKs/iPhoneSimulator$(IOSVERSION).sdk -arch i686 -arch x86_64 -c $< -o ios-x86/$@
2127
	mkdir -p ios-arm/$(dir $@)
I
Igor Canadi 已提交
2128
	xcrun -sdk iphoneos $(CXX) $(CXXFLAGS) -isysroot $(DEVICEROOT)/SDKs/iPhoneOS$(IOSVERSION).sdk -arch armv6 -arch armv7 -arch armv7s -arch arm64 -c $< -o ios-arm/$@
2129
	lipo ios-x86/$@ ios-arm/$@ -create -output $@
2130 2131 2132

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

2138
else
2139 2140 2141 2142 2143 2144 2145
ifeq ($(HAVE_POWER8),1)
util/crc32c_ppc.o: util/crc32c_ppc.c
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@

util/crc32c_ppc_asm.o: util/crc32c_ppc_asm.S
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
endif
2146
.cc.o:
2147
	$(AM_V_CC)$(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)
2148

2149 2150 2151
.cpp.o:
	$(AM_V_CC)$(CXX) $(CXXFLAGS) -c $< -o $@ $(COVERAGEFLAGS)

2152
.c.o:
2153
	$(AM_V_CC)$(CC) $(CFLAGS) -c $< -o $@
2154
endif
2155 2156 2157 2158
# ---------------------------------------------------------------------------
#  	Source files dependencies detection
# ---------------------------------------------------------------------------

2159
all_sources = $(LIB_SOURCES) $(MAIN_SOURCES) $(MOCK_LIB_SOURCES) $(TOOL_LIB_SOURCES) $(BENCH_LIB_SOURCES) $(TEST_LIB_SOURCES) $(ANALYZER_LIB_SOURCES) $(STRESS_LIB_SOURCES)
2160 2161 2162 2163 2164
DEPFILES = $(all_sources:.cc=.cc.d)

ifeq ($(USE_FOLLY_DISTRIBUTED_MUTEX),1)
  DEPFILES += $(FOLLY_SOURCES:.cpp=.cpp.d)
endif
2165

2166 2167 2168 2169 2170
# 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.
2171
%.cc.d: %.cc
2172
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
2173
	  -MM -MT'$@' -MT'$(<:.cc=.o)' "$<" -o '$@'
2174

2175 2176 2177 2178
%.cpp.d: %.cpp
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.cpp=.o)' "$<" -o '$@'

2179 2180 2181 2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195
ifeq ($(HAVE_POWER8),1)
DEPFILES_C = $(LIB_SOURCES_C:.c=.c.d)
DEPFILES_ASM = $(LIB_SOURCES_ASM:.S=.S.d)

%.c.d: %.c
	@$(CXX) $(CXXFLAGS) $(PLATFORM_SHARED_CFLAGS) \
	  -MM -MT'$@' -MT'$(<:.c=.o)' "$<" -o '$@'

%.S.d: %.S
	@$(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
2196
depend: $(DEPFILES)
2197
endif
2198

2199 2200 2201 2202
# 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.
2203
ifneq ($(MAKECMDGOALS),clean)
2204
ifneq ($(MAKECMDGOALS),format)
2205 2206
ifneq ($(MAKECMDGOALS),jclean)
ifneq ($(MAKECMDGOALS),jtest)
2207
ifneq ($(MAKECMDGOALS),package)
2208
ifneq ($(MAKECMDGOALS),analyze)
2209 2210
-include $(DEPFILES)
endif
2211
endif
2212 2213
endif
endif
2214
endif
2215
endif