make-linux.mk 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607
  1. # Automagically pick CLANG or RH/CentOS newer GCC if present
  2. # This is only done if we have not overridden these with an environment or CLI variable
  3. ifeq ($(origin CC),default)
  4. CC:=$(shell if [ -e /usr/bin/clang ]; then echo clang; else echo gcc; fi)
  5. CC:=$(shell if [ -e /opt/rh/devtoolset-8/root/usr/bin/gcc ]; then echo /opt/rh/devtoolset-8/root/usr/bin/gcc; else echo $(CC); fi)
  6. endif
  7. ifeq ($(origin CXX),default)
  8. CXX:=$(shell if [ -e /usr/bin/clang++ ]; then echo clang++; else echo g++; fi)
  9. CXX:=$(shell if [ -e /opt/rh/devtoolset-8/root/usr/bin/g++ ]; then echo /opt/rh/devtoolset-8/root/usr/bin/g++; else echo $(CXX); fi)
  10. endif
  11. INCLUDES?=-Irustybits/target -isystem ext -Iext/prometheus-cpp-lite-1.0/core/include -Iext-prometheus-cpp-lite-1.0/3rdparty/http-client-lite/include -Iext/prometheus-cpp-lite-1.0/simpleapi/include
  12. DEFS?=
  13. LDLIBS?=
  14. DESTDIR?=
  15. EXTRA_DEPS?=
  16. ZT_CARGO_FLAGS?=
  17. include objects.mk
  18. ifeq ($(ZT_CONTROLLER),1)
  19. ZT_NONFREE=1
  20. endif
  21. ifeq ($(ZT_NONFREE),1)
  22. include objects-nonfree.mk
  23. ONE_OBJS+=$(CONTROLLER_OBJS)
  24. override DEFS += -DZT_NONFREE_CONTROLLER
  25. endif
  26. ifeq ($(ZT_EXTOSDEP),1)
  27. ONE_OBJS+=osdep/ExtOsdep.o
  28. override DEFS += -DZT_EXTOSDEP
  29. else
  30. ONE_OBJS+=osdep/LinuxEthernetTap.o
  31. ONE_OBJS+=osdep/LinuxNetLink.o
  32. endif
  33. # for central controller buildsk
  34. TIMESTAMP=$(shell date +"%Y%m%d%H%M")
  35. # Auto-detect miniupnpc and nat-pmp as well and use system libs if present,
  36. # otherwise build into binary as done on Mac and Windows.
  37. ONE_OBJS+=osdep/PortMapper.o
  38. override DEFS+=-DZT_USE_MINIUPNPC
  39. MINIUPNPC_IS_NEW_ENOUGH=$(shell grep -sqr '.*define.*MINIUPNPC_VERSION.*"2..*"' /usr/include/miniupnpc/miniupnpc.h && echo 1)
  40. #MINIUPNPC_IS_NEW_ENOUGH=$(shell grep -sqr '.*define.*MINIUPNPC_VERSION.*"2.."' /usr/include/miniupnpc/miniupnpc.h && echo 1)
  41. ifeq ($(MINIUPNPC_IS_NEW_ENOUGH),1)
  42. override DEFS+=-DZT_USE_SYSTEM_MINIUPNPC
  43. LDLIBS+=-lminiupnpc
  44. else
  45. override DEFS+=-DMINIUPNP_STATICLIB -DMINIUPNPC_SET_SOCKET_TIMEOUT -DMINIUPNPC_GET_SRC_ADDR -D_BSD_SOURCE -D_DEFAULT_SOURCE -D_XOPEN_SOURCE=600 -DOS_STRING="\"Linux\"" -DMINIUPNPC_VERSION_STRING="\"2.0\"" -DUPNP_VERSION_STRING="\"UPnP/1.1\"" -DENABLE_STRNATPMPERR
  46. ONE_OBJS+=ext/miniupnpc/connecthostport.o ext/miniupnpc/igd_desc_parse.o ext/miniupnpc/minisoap.o ext/miniupnpc/minissdpc.o ext/miniupnpc/miniupnpc.o ext/miniupnpc/miniwget.o ext/miniupnpc/minixml.o ext/miniupnpc/portlistingparse.o ext/miniupnpc/receivedata.o ext/miniupnpc/upnpcommands.o ext/miniupnpc/upnpdev.o ext/miniupnpc/upnperrors.o ext/miniupnpc/upnpreplyparse.o
  47. endif
  48. ifeq ($(wildcard /usr/include/natpmp.h),)
  49. ONE_OBJS+=ext/libnatpmp/natpmp.o ext/libnatpmp/getgateway.o
  50. else
  51. LDLIBS+=-lnatpmp
  52. override DEFS+=-DZT_USE_SYSTEM_NATPMP
  53. endif
  54. # Use bundled http-parser since distribution versions are NOT API-stable or compatible!
  55. # Trying to use dynamically linked libhttp-parser causes tons of compatibility problems.
  56. ONE_OBJS+=ext/http-parser/http_parser.o
  57. ifeq ($(ZT_RULES_ENGINE_DEBUGGING),1)
  58. override DEFS+=-DZT_RULES_ENGINE_DEBUGGING
  59. endif
  60. ifeq ($(ZT_DEBUG_TRACE),1)
  61. override DEFS+=-DZT_DEBUG_TRACE
  62. endif
  63. # Build with address sanitization library for advanced debugging (clang)
  64. ifeq ($(ZT_SANITIZE),1)
  65. override DEFS+=-fsanitize=address -DASAN_OPTIONS=symbolize=1
  66. endif
  67. ifeq ($(ZT_DEBUG),1)
  68. override CFLAGS+=-Wall -Wno-deprecated -g -O -pthread $(INCLUDES) $(DEFS)
  69. override CXXFLAGS+=-Wall -Wno-deprecated -g -O -std=c++17 -pthread $(INCLUDES) $(DEFS)
  70. ZT_TRACE=1
  71. # The following line enables optimization for the crypto code, since
  72. # C25519 in particular is almost UNUSABLE in -O0 even on a 3ghz box!
  73. node/Salsa20.o node/SHA512.o node/C25519.o node/Poly1305.o: CXXFLAGS=-Wall -O2 -g -pthread $(INCLUDES) $(DEFS)
  74. else
  75. CFLAGS?=-O3 -fstack-protector
  76. override CFLAGS+=-Wall -Wno-deprecated -pthread $(INCLUDES) -DNDEBUG $(DEFS)
  77. CXXFLAGS?=-O3 -fstack-protector
  78. override CXXFLAGS+=-Wall -Wno-deprecated -std=c++17 -pthread $(INCLUDES) -DNDEBUG $(DEFS)
  79. LDFLAGS?=-pie -Wl,-z,relro,-z,now
  80. ZT_CARGO_FLAGS+=--release
  81. endif
  82. ifeq ($(ZT_QNAP), 1)
  83. override DEFS+=-D__QNAP__
  84. ZT_EMBEDDED=1
  85. endif
  86. ifeq ($(ZT_UBIQUITI), 1)
  87. override DEFS+=-D__UBIQUITI__
  88. ZT_EMBEDDED=1
  89. endif
  90. ifeq ($(ZT_SYNOLOGY), 1)
  91. override DEFS+=-D__SYNOLOGY__
  92. ZT_EMBEDDED=1
  93. endif
  94. ifeq ($(ZT_TRACE),1)
  95. override DEFS+=-DZT_TRACE
  96. endif
  97. ifeq ($(ZT_DEBUG),1)
  98. override DEFS+=-DZT_DEBUG
  99. endif
  100. ifeq ($(ZT_USE_TEST_TAP),1)
  101. override DEFS+=-DZT_USE_TEST_TAP
  102. endif
  103. ifeq ($(ZT_VAULT_SUPPORT),1)
  104. override DEFS+=-DZT_VAULT_SUPPORT=1
  105. override LDLIBS+=-lcurl
  106. endif
  107. # Determine system build architecture from compiler target. This is hairy due to "ARM wrestling."
  108. CC_MACH=$(shell $(CC) -dumpmachine | cut -d '-' -f 1)
  109. ZT_ARCHITECTURE=999
  110. ifeq ($(CC_MACH),x86_64)
  111. ZT_ARCHITECTURE=2
  112. ZT_USE_X64_ASM_SALSA=1
  113. ZT_USE_X64_ASM_ED25519=1
  114. override CFLAGS+=-msse -msse2
  115. override CXXFLAGS+=-msse -msse2
  116. ZT_SSO_SUPPORTED=1
  117. ifeq ($(ZT_CONTROLLER),1)
  118. EXT_ARCH=amd64
  119. endif
  120. endif
  121. ifeq ($(CC_MACH),amd64)
  122. ZT_ARCHITECTURE=2
  123. ZT_USE_X64_ASM_SALSA=1
  124. ZT_USE_X64_ASM_ED25519=1
  125. override CFLAGS+=-msse -msse2
  126. override CXXFLAGS+=-msse -msse2
  127. ZT_SSO_SUPPORTED=1
  128. ifeq ($(ZT_CONTROLLER),1)
  129. EXT_ARCH=amd64
  130. endif
  131. endif
  132. ifeq ($(CC_MACH),powerpc64le)
  133. ZT_ARCHITECTURE=8
  134. override DEFS+=-DZT_NO_TYPE_PUNNING
  135. endif
  136. ifeq ($(CC_MACH),powerpc)
  137. ZT_ARCHITECTURE=8
  138. override DEFS+=-DZT_NO_TYPE_PUNNING
  139. override DEFS+=-DZT_NO_CAPABILITIES
  140. endif
  141. ifeq ($(CC_MACH),ppc64le)
  142. ZT_ARCHITECTURE=8
  143. endif
  144. ifeq ($(CC_MACH),ppc64el)
  145. ZT_ARCHITECTURE=8
  146. endif
  147. ifeq ($(CC_MACH),e2k)
  148. ZT_ARCHITECTURE=2
  149. endif
  150. ifeq ($(CC_MACH),e2k64)
  151. ZT_ARCHITECTURE=2
  152. endif
  153. ifeq ($(CC_MACH),i386)
  154. ZT_ARCHITECTURE=1
  155. ZT_SSO_SUPPORTED=1
  156. endif
  157. ifeq ($(CC_MACH),i486)
  158. ZT_ARCHITECTURE=1
  159. ZT_SSO_SUPPORTED=1
  160. endif
  161. ifeq ($(CC_MACH),i586)
  162. ZT_ARCHITECTURE=1
  163. ZT_SSO_SUPPORTED=1
  164. endif
  165. ifeq ($(CC_MACH),i686)
  166. ZT_ARCHITECTURE=1
  167. ZT_SSO_SUPPORTED=1
  168. endif
  169. ifeq ($(CC_MACH),arm)
  170. ZT_ARCHITECTURE=3
  171. override DEFS+=-DZT_NO_TYPE_PUNNING
  172. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  173. endif
  174. ifeq ($(CC_MACH),armel)
  175. ZT_ARCHITECTURE=3
  176. override DEFS+=-DZT_NO_TYPE_PUNNING
  177. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  178. endif
  179. ifeq ($(CC_MACH),armhf)
  180. ZT_ARCHITECTURE=3
  181. override DEFS+=-DZT_NO_TYPE_PUNNING
  182. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  183. ZT_SSO_SUPPORTED=1
  184. endif
  185. ifeq ($(CC_MACH),armv6)
  186. ZT_ARCHITECTURE=3
  187. override DEFS+=-DZT_NO_TYPE_PUNNING
  188. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  189. endif
  190. ifeq ($(CC_MACH),armv6l)
  191. ZT_ARCHITECTURE=3
  192. override DEFS+=-DZT_NO_TYPE_PUNNING
  193. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  194. endif
  195. ifeq ($(CC_MACH),armv6zk)
  196. ZT_ARCHITECTURE=3
  197. override DEFS+=-DZT_NO_TYPE_PUNNING
  198. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  199. endif
  200. ifeq ($(CC_MACH),armv6kz)
  201. ZT_ARCHITECTURE=3
  202. override DEFS+=-DZT_NO_TYPE_PUNNING
  203. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  204. endif
  205. ifeq ($(CC_MACH),armv6k)
  206. ZT_ARCHITECTURE=3
  207. override DEFS+=-DZT_NO_TYPE_PUNNING
  208. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  209. endif
  210. ifeq ($(CC_MACH),armv7)
  211. ZT_ARCHITECTURE=3
  212. override DEFS+=-DZT_NO_TYPE_PUNNING
  213. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  214. endif
  215. ifeq ($(CC_MACH),armv7l)
  216. ZT_ARCHITECTURE=3
  217. override DEFS+=-DZT_NO_TYPE_PUNNING
  218. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  219. endif
  220. ifeq ($(CC_MACH),armv7hl)
  221. ZT_ARCHITECTURE=3
  222. override DEFS+=-DZT_NO_TYPE_PUNNING
  223. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  224. endif
  225. ifeq ($(CC_MACH),armv7ve)
  226. ZT_ARCHITECTURE=3
  227. override DEFS+=-DZT_NO_TYPE_PUNNING
  228. ZT_USE_ARM32_NEON_ASM_CRYPTO=1
  229. endif
  230. ifeq ($(CC_MACH),arm64)
  231. ZT_ARCHITECTURE=4
  232. ZT_SSO_SUPPORTED=1
  233. ZT_USE_X64_ASM_ED25519=0
  234. override DEFS+=-DZT_NO_TYPE_PUNNING -DZT_ARCH_ARM_HAS_NEON -march=armv8-a+crypto -mtune=generic -mstrict-align
  235. endif
  236. ifeq ($(CC_MACH),aarch64)
  237. ZT_ARCHITECTURE=4
  238. ZT_SSO_SUPPORTED=1
  239. ZT_USE_X64_ASM_ED25519=0
  240. override DEFS+=-DZT_NO_TYPE_PUNNING -DZT_ARCH_ARM_HAS_NEON -march=armv8-a+crypto -mtune=generic -mstrict-align
  241. ifeq ($(ZT_CONTROLLER),1)
  242. EXT_ARCH=arm64
  243. endif
  244. endif
  245. ifeq ($(CC_MACH),mipsel)
  246. ZT_ARCHITECTURE=5
  247. override DEFS+=-DZT_NO_TYPE_PUNNING
  248. endif
  249. ifeq ($(CC_MACH),mips)
  250. ZT_ARCHITECTURE=5
  251. override DEFS+=-DZT_NO_TYPE_PUNNING
  252. endif
  253. ifeq ($(CC_MACH),mips64)
  254. ZT_ARCHITECTURE=6
  255. override DEFS+=-DZT_NO_TYPE_PUNNING
  256. endif
  257. ifeq ($(CC_MACH),mips64el)
  258. ZT_ARCHITECTURE=6
  259. override DEFS+=-DZT_NO_TYPE_PUNNING
  260. endif
  261. ifeq ($(CC_MACH),s390x)
  262. ZT_ARCHITECTURE=16
  263. endif
  264. ifeq ($(CC_MACH),riscv64)
  265. ZT_ARCHITECTURE=0
  266. endif
  267. ifeq ($(CC_MACH),loongarch64)
  268. ZT_ARCHITECTURE=17
  269. override DEFS+=-DZT_NO_TYPE_PUNNING
  270. endif
  271. ifeq ($(ZT_EXTOSDEP), 1)
  272. ZT_SSO_SUPPORTED=0
  273. endif
  274. # Fail if system architecture could not be determined
  275. ifeq ($(ZT_ARCHITECTURE),999)
  276. ERR=$(error FATAL: architecture could not be determined from $(CC) -dumpmachine: $(CC_MACH))
  277. .PHONY: err
  278. err: ; $(ERR)
  279. endif
  280. # Flag for Intel 32-bit processors since some machine images are incorrectly marked as i386
  281. ifeq ($(ZT_IA32),1)
  282. override LDFLAGS+=-m32
  283. override CFLAGS+=-m32
  284. override CXXFLAGS+=-m32
  285. # Prevent the use of X64 crypto
  286. ZT_USE_X64_ASM_SALSA=0
  287. ZT_USE_X64_ASM_ED25519=0
  288. endif
  289. ifeq ($(ZT_SSO_SUPPORTED), 1)
  290. ifeq ($(ZT_EMBEDDED),)
  291. override DEFS+=-DZT_SSO_SUPPORTED=1
  292. ifeq ($(ZT_DEBUG),1)
  293. LDLIBS+=rustybits/target/debug/librustybits.a -ldl -lssl -lcrypto
  294. else
  295. LDLIBS+=rustybits/target/release/librustybits.a -ldl -lssl -lcrypto
  296. endif
  297. endif
  298. endif
  299. OTEL_VERSION=1.21.0
  300. ifeq (${ZT_OTEL},1)
  301. OTEL_INSTALL_DIR=ext/opentelemetry-cpp-${OTEL_VERSION}/localinstall
  302. override DEFS+=-DZT_OPENTELEMETRY_ENABLED=1
  303. INCLUDES+=-I${OTEL_INSTALL_DIR}/include
  304. LDLIBS+=-L${OTEL_INSTALL_DIR}/lib -lopentelemetry_exporter_in_memory_metric -lopentelemetry_exporter_in_memory -lopentelemetry_exporter_ostream_logs -lopentelemetry_exporter_ostream_metrics -lopentelemetry_exporter_ostream_span -lopentelemetry_exporter_otlp_grpc -lopentelemetry_exporter_otlp_grpc_client -lopentelemetry_exporter_otlp_grpc_log -lopentelemetry_exporter_otlp_grpc_metrics -lopentelemetry_otlp_recordable -lopentelemetry_common -lopentelemetry_trace -lopentelemetry_common -lopentelemetry_resources -lopentelemetry_logs -lopentelemetry_metrics -lopentelemetry_proto -lopentelemetry_proto_grpc -lopentelemetry_version -lprotobuf -lgrpc++
  305. else
  306. OTEL_INSTALL_DIR=ext/opentelemetry-cpp-api-only
  307. INCLUDES+=-I${OTEL_INSTALL_DIR}/include
  308. endif
  309. # Disable software updates by default on Linux since that is normally done with package management
  310. override DEFS+=-DZT_BUILD_PLATFORM=1 -DZT_BUILD_ARCHITECTURE=$(ZT_ARCHITECTURE) -DZT_SOFTWARE_UPDATE_DEFAULT="\"disable\""
  311. # This forces libstdc++ not to include these abominations, especially mt and pool
  312. override DEFS+=-D_MT_ALLOCATOR_H -D_POOL_ALLOCATOR_H -D_EXTPTR_ALLOCATOR_H -D_DEBUG_ALLOCATOR_H
  313. # Static builds, which are currently done for a number of Linux targets
  314. ifeq ($(ZT_STATIC),1)
  315. override LDFLAGS+=-static
  316. endif
  317. # For building an official semi-static binary on CentOS 7
  318. #ifeq ($(ZT_OFFICIAL),1)
  319. # CORE_OBJS+=ext/misc/linux-old-glibc-compat.o
  320. # override LDFLAGS+=-Wl,--wrap=memcpy -static-libstdc++
  321. #endif
  322. ifeq ($(ZT_CONTROLLER),1)
  323. override CXXFLAGS+=-Wall -Wno-deprecated -std=c++17 -pthread $(INCLUDES) -DNDEBUG $(DEFS)
  324. override LDLIBS+=-Lext/libpqxx-7.7.3/install/ubuntu22.04/$(EXT_ARCH)/lib -lpqxx -lpq ext/hiredis-1.0.2/lib/ubuntu22.04/$(EXT_ARCH)/libhiredis.a ext/redis-plus-plus-1.3.3/install/ubuntu22.04/$(EXT_ARCH)/lib/libredis++.a -lssl -lcrypto
  325. override DEFS+=-DZT_CONTROLLER_USE_LIBPQ -DZT_NO_PEER_METRICS -DZT_OPENTELEMETRY_ENABLED
  326. override INCLUDES+=-I/usr/include/postgresql -Iext/libpqxx-7.7.3/install/ubuntu22.04/$(EXT_ARCH)/include -Iext/hiredis-1.0.2/include/ -Iext/redis-plus-plus-1.3.3/install/ubuntu22.04/$(EXT_ARCH)/include
  327. override ZT_CARGO_FLAGS+=-F ztcontroller
  328. ifeq ($(ZT_DEBUG),1)
  329. override LDLIBS+=rustybits/target/debug/librustybits.a
  330. else
  331. override LDLIBS+=rustybits/target/release/librustybits.a
  332. endif
  333. endif
  334. # ARM32 hell -- use conservative CFLAGS
  335. ifeq ($(ZT_ARCHITECTURE),3)
  336. ifeq ($(shell if [ -e /usr/bin/dpkg ]; then dpkg --print-architecture; fi),armel)
  337. override CFLAGS+=-march=armv5t -mfloat-abi=soft -msoft-float -mno-unaligned-access -marm
  338. override CXXFLAGS+=-march=armv5t -mfloat-abi=soft -msoft-float -mno-unaligned-access -marm
  339. ZT_USE_ARM32_NEON_ASM_CRYPTO=0
  340. else
  341. ifeq ($(ZT_EXTOSDEP), 0)
  342. override CFLAGS+=-mfloat-abi=hard -march=armv6zk -marm -mfpu=vfp -mno-unaligned-access -mtp=cp15 -mcpu=arm1176jzf-s
  343. override CXXFLAGS+=-mfloat-abi=hard -march=armv6zk -marm -mfpu=vfp -fexceptions -mno-unaligned-access -mtp=cp15 -mcpu=arm1176jzf-s
  344. else
  345. override DEFS+=-DZT_NO_PEER_METRICS
  346. endif
  347. ZT_USE_ARM32_NEON_ASM_CRYPTO=0
  348. endif
  349. endif
  350. # Build faster crypto on some targets
  351. ifeq ($(ZT_USE_X64_ASM_SALSA),1)
  352. override DEFS+=-DZT_USE_X64_ASM_SALSA2012
  353. override CORE_OBJS+=ext/x64-salsa2012-asm/salsa2012.o
  354. endif
  355. ifeq ($(ZT_USE_X64_ASM_ED25519),1)
  356. override DEFS+=-DZT_USE_FAST_X64_ED25519
  357. override CORE_OBJS+=ext/ed25519-amd64-asm/choose_t.o ext/ed25519-amd64-asm/consts.o ext/ed25519-amd64-asm/fe25519_add.o ext/ed25519-amd64-asm/fe25519_freeze.o ext/ed25519-amd64-asm/fe25519_mul.o ext/ed25519-amd64-asm/fe25519_square.o ext/ed25519-amd64-asm/fe25519_sub.o ext/ed25519-amd64-asm/ge25519_add_p1p1.o ext/ed25519-amd64-asm/ge25519_dbl_p1p1.o ext/ed25519-amd64-asm/ge25519_nielsadd2.o ext/ed25519-amd64-asm/ge25519_nielsadd_p1p1.o ext/ed25519-amd64-asm/ge25519_p1p1_to_p2.o ext/ed25519-amd64-asm/ge25519_p1p1_to_p3.o ext/ed25519-amd64-asm/ge25519_pnielsadd_p1p1.o ext/ed25519-amd64-asm/heap_rootreplaced.o ext/ed25519-amd64-asm/heap_rootreplaced_1limb.o ext/ed25519-amd64-asm/heap_rootreplaced_2limbs.o ext/ed25519-amd64-asm/heap_rootreplaced_3limbs.o ext/ed25519-amd64-asm/sc25519_add.o ext/ed25519-amd64-asm/sc25519_barrett.o ext/ed25519-amd64-asm/sc25519_lt.o ext/ed25519-amd64-asm/sc25519_sub_nored.o ext/ed25519-amd64-asm/ull4_mul.o ext/ed25519-amd64-asm/fe25519_getparity.o ext/ed25519-amd64-asm/fe25519_invert.o ext/ed25519-amd64-asm/fe25519_iseq.o ext/ed25519-amd64-asm/fe25519_iszero.o ext/ed25519-amd64-asm/fe25519_neg.o ext/ed25519-amd64-asm/fe25519_pack.o ext/ed25519-amd64-asm/fe25519_pow2523.o ext/ed25519-amd64-asm/fe25519_setint.o ext/ed25519-amd64-asm/fe25519_unpack.o ext/ed25519-amd64-asm/ge25519_add.o ext/ed25519-amd64-asm/ge25519_base.o ext/ed25519-amd64-asm/ge25519_double.o ext/ed25519-amd64-asm/ge25519_double_scalarmult.o ext/ed25519-amd64-asm/ge25519_isneutral.o ext/ed25519-amd64-asm/ge25519_multi_scalarmult.o ext/ed25519-amd64-asm/ge25519_pack.o ext/ed25519-amd64-asm/ge25519_scalarmult_base.o ext/ed25519-amd64-asm/ge25519_unpackneg.o ext/ed25519-amd64-asm/hram.o ext/ed25519-amd64-asm/index_heap.o ext/ed25519-amd64-asm/sc25519_from32bytes.o ext/ed25519-amd64-asm/sc25519_from64bytes.o ext/ed25519-amd64-asm/sc25519_from_shortsc.o ext/ed25519-amd64-asm/sc25519_iszero.o ext/ed25519-amd64-asm/sc25519_mul.o ext/ed25519-amd64-asm/sc25519_mul_shortsc.o ext/ed25519-amd64-asm/sc25519_slide.o ext/ed25519-amd64-asm/sc25519_to32bytes.o ext/ed25519-amd64-asm/sc25519_window4.o ext/ed25519-amd64-asm/sign.o
  358. endif
  359. ifeq ($(ZT_USE_ARM32_NEON_ASM_CRYPTO),1)
  360. override DEFS+=-DZT_USE_ARM32_NEON_ASM_SALSA2012
  361. override CORE_OBJS+=ext/arm32-neon-salsa2012-asm/salsa2012.o
  362. endif
  363. # Position Independence
  364. override CFLAGS+=-fPIC -fPIE
  365. override CXXFLAGS+=-fPIC -fPIE
  366. # Non-executable stack
  367. override LDFLAGS+=-Wl,-z,noexecstack
  368. .PHONY: all
  369. all: one
  370. .PHONY: one
  371. one: otel zerotier-one zerotier-idtool zerotier-cli
  372. from_builder: FORCE
  373. ln -sf zerotier-one zerotier-idtool
  374. ln -sf zerotier-one zerotier-cli
  375. zerotier-one: $(CORE_OBJS) $(ONE_OBJS) one.o ext/${OTEL_INSTALL_DIR}/include/opentelemetry/version.h
  376. $(CXX) $(CXXFLAGS) $(LDFLAGS) -o zerotier-one $(CORE_OBJS) $(ONE_OBJS) one.o $(LDLIBS)
  377. zerotier-idtool: zerotier-one
  378. ln -sf zerotier-one zerotier-idtool
  379. zerotier-cli: zerotier-one
  380. ln -sf zerotier-one zerotier-cli
  381. $(ONE_OBJS): zeroidc rustybits
  382. libzerotiercore.a: FORCE
  383. make CFLAGS="-O3 -fstack-protector -fPIC" CXXFLAGS="-O3 -std=c++17 -fstack-protector -fPIC" $(CORE_OBJS)
  384. ar rcs libzerotiercore.a $(CORE_OBJS)
  385. ranlib libzerotiercore.a
  386. core: libzerotiercore.a
  387. selftest: $(CORE_OBJS) $(ONE_OBJS) selftest.o
  388. $(CXX) $(CXXFLAGS) $(LDFLAGS) -o zerotier-selftest selftest.o $(CORE_OBJS) $(ONE_OBJS) $(LDLIBS)
  389. zerotier-selftest: selftest
  390. manpages: FORCE
  391. cd doc ; ./build.sh
  392. doc: manpages
  393. ifeq (${ZT_OTEL},1)
  394. otel:
  395. cd ext/opentelemetry-cpp-1.21.0 && mkdir -p localinstall && cmake -B build -S . -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=$(shell pwd)/ext/opentelemetry-cpp-1.21.0/localinstall -DCMAKE_POSITION_INDEPENDENT_CODE=ON -DBUILD_TESTING=OFF -DOPENTELEMETRY_INSTALL=ON -DWITH_BENCHMARK=OFF -DWITH_EXAMPLES=OFF -DWITH_FUNC_TESTS=OFF -DUSE_THIRDPARTY_LIBRARIES=ON -DWITH_OTLP_GRPC=ON -DWITH_OTLP_HTTP=OFF -DWITH_PROMETHEUS=OFF
  396. cd ext/opentelemetry-cpp-1.21.0/build && make -j4 install
  397. else
  398. otel:
  399. @echo "OpenTelemetry exporter not enabled, skipping build."
  400. endif
  401. ext/${OTEL_INSTALL_DIR}/include/opentelemetry/version.h: otel
  402. clean: FORCE
  403. rm -rf *.a *.so *.o node/*.o nonfree/controller/*.o osdep/*.o service/*.o ext/http-parser/*.o ext/miniupnpc/*.o ext/libnatpmp/*.o $(CORE_OBJS) $(ONE_OBJS) zerotier-one zerotier-idtool zerotier-cli zerotier-selftest build-* ZeroTierOneInstaller-* *.deb *.rpm .depend debian/files debian/zerotier-one*.debhelper debian/zerotier-one.substvars debian/*.log debian/zerotier-one doc/node_modules ext/misc/*.o debian/.debhelper debian/debhelper-build-stamp docker/zerotier-one rustybits/target ext/opentelemetry-cpp-${OTEL_VERSION}/localinstall ext/opentelemetry-cpp-${OTEL_VERSION}/build
  404. distclean: clean
  405. realclean: distclean
  406. official: FORCE
  407. make -j`nproc` ZT_OFFICIAL=1 ZT_NONFREE=1 all
  408. docker: FORCE
  409. docker build --no-cache -f ext/installfiles/linux/zerotier-containerized/Dockerfile -t zerotier-containerized .
  410. _buildx:
  411. @echo "docker buildx create"
  412. # docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  413. docker run --privileged --rm tonistiigi/binfmt --install all
  414. @echo docker buildx create --name multiarch --driver docker-container --use
  415. @echo docker buildx inspect --bootstrap
  416. central-controller: FORCE
  417. make ZT_OTEL=1 otel && ZT_OTEL=1 make -j4 ZT_CONTROLLER=1 one
  418. central-controller-docker: _buildx FORCE
  419. docker buildx build --platform linux/amd64,linux/arm64 --no-cache -t registry.zerotier.com/zerotier-central/ztcentral-controller:${TIMESTAMP} -f ext/central-controller-docker/Dockerfile --build-arg git_branch=`git name-rev --name-only HEAD` . --push
  420. @echo Image: registry.zerotier.com/zerotier-central/ztcentral-controller:${TIMESTAMP}
  421. centralv2-controller-docker: _buildx FORCE
  422. docker buildx build --platform linux/amd64,linux/arm64 --no-cache -t us-central1-docker.pkg.dev/zerotier-421eb9/docker-images/ztcentral-controller:$(shell git rev-parse --short HEAD) -f ext/central-controller-docker/Dockerfile --build-arg git_branch=`git name-rev --name-only HEAD` . --push
  423. @echo Image: us-central1-docker.pkg.dev/zerotier-421eb9/docker-images/ztcentral-controller:$(shell git rev-parse --short HEAD)
  424. debug: FORCE
  425. make ZT_DEBUG=1 one
  426. make ZT_DEBUG=1 selftest
  427. ifeq ($(ZT_SSO_SUPPORTED), 1)
  428. ifeq ($(ZT_EMBEDDED),)
  429. zeroidc: FORCE
  430. export PATH=/${HOME}/.cargo/bin:$$PATH; cd rustybits && cargo build $(ZT_CARGO_FLAGS)
  431. endif
  432. else
  433. zeroidc:
  434. endif
  435. # Note: keep the symlinks in /var/lib/zerotier-one to the binaries since these
  436. # provide backward compatibility with old releases where the binaries actually
  437. # lived here. Folks got scripts.
  438. install: FORCE
  439. mkdir -p $(DESTDIR)/usr/sbin
  440. rm -f $(DESTDIR)/usr/sbin/zerotier-one
  441. cp -f zerotier-one $(DESTDIR)/usr/sbin/zerotier-one
  442. rm -f $(DESTDIR)/usr/sbin/zerotier-cli
  443. rm -f $(DESTDIR)/usr/sbin/zerotier-idtool
  444. ln -s zerotier-one $(DESTDIR)/usr/sbin/zerotier-cli
  445. ln -s zerotier-one $(DESTDIR)/usr/sbin/zerotier-idtool
  446. mkdir -p $(DESTDIR)/var/lib/zerotier-one
  447. rm -f $(DESTDIR)/var/lib/zerotier-one/zerotier-one
  448. rm -f $(DESTDIR)/var/lib/zerotier-one/zerotier-cli
  449. rm -f $(DESTDIR)/var/lib/zerotier-one/zerotier-idtool
  450. ln -s ../../../usr/sbin/zerotier-one $(DESTDIR)/var/lib/zerotier-one/zerotier-one
  451. ln -s ../../../usr/sbin/zerotier-one $(DESTDIR)/var/lib/zerotier-one/zerotier-cli
  452. ln -s ../../../usr/sbin/zerotier-one $(DESTDIR)/var/lib/zerotier-one/zerotier-idtool
  453. mkdir -p $(DESTDIR)/usr/share/man/man8
  454. rm -f $(DESTDIR)/usr/share/man/man8/zerotier-one.8.gz
  455. cat doc/zerotier-one.8 | gzip -9 >$(DESTDIR)/usr/share/man/man8/zerotier-one.8.gz
  456. mkdir -p $(DESTDIR)/usr/share/man/man1
  457. rm -f $(DESTDIR)/usr/share/man/man1/zerotier-idtool.1.gz
  458. rm -f $(DESTDIR)/usr/share/man/man1/zerotier-cli.1.gz
  459. cat doc/zerotier-cli.1 | gzip -9 >$(DESTDIR)/usr/share/man/man1/zerotier-cli.1.gz
  460. cat doc/zerotier-idtool.1 | gzip -9 >$(DESTDIR)/usr/share/man/man1/zerotier-idtool.1.gz
  461. cp ext/installfiles/linux/zerotier-one.te $(DESTDIR)/var/lib/zerotier-one/zerotier-one.te
  462. # Uninstall preserves identity.public and identity.secret since the user might
  463. # want to save these. These are your ZeroTier address.
  464. uninstall: FORCE
  465. rm -f $(DESTDIR)/var/lib/zerotier-one/zerotier-one
  466. rm -f $(DESTDIR)/var/lib/zerotier-one/zerotier-cli
  467. rm -f $(DESTDIR)/var/lib/zerotier-one/zerotier-idtool
  468. rm -f $(DESTDIR)/usr/sbin/zerotier-cli
  469. rm -f $(DESTDIR)/usr/sbin/zerotier-idtool
  470. rm -f $(DESTDIR)/usr/sbin/zerotier-one
  471. rm -rf $(DESTDIR)/var/lib/zerotier-one/iddb.d
  472. rm -rf $(DESTDIR)/var/lib/zerotier-one/updates.d
  473. rm -rf $(DESTDIR)/var/lib/zerotier-one/networks.d
  474. rm -f $(DESTDIR)/var/lib/zerotier-one/zerotier-one.port
  475. rm -f $(DESTDIR)/usr/share/man/man8/zerotier-one.8.gz
  476. rm -f $(DESTDIR)/usr/share/man/man1/zerotier-idtool.1.gz
  477. rm -f $(DESTDIR)/usr/share/man/man1/zerotier-cli.1.gz
  478. # These are just for convenience for building Linux packages
  479. echo_flags:
  480. @echo "=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~"
  481. @echo "echo_flags :: CC=$(CC)"
  482. @echo "echo_flags :: CXX=$(CXX)"
  483. @echo "echo_flags :: CFLAGS=$(CFLAGS)"
  484. @echo "echo_flags :: CXXFLAGS=$(CXXFLAGS)"
  485. @echo "echo_flags :: LDFLAGS=$(LDFLAGS)"
  486. @echo "echo_flags :: RUSTFLAGS=$(RUSTFLAGS)"
  487. @echo "=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~=~"
  488. debian: echo_flags
  489. @echo "building deb package"
  490. debuild --no-lintian -I -i -us -uc -nc -b
  491. # debuild --no-lintian -b -uc -us
  492. # debian: FORCE
  493. # debuild --no-lintian -I -i -us -uc -nc -b
  494. debian-clean: FORCE
  495. rm -rf debian/files debian/zerotier-one*.debhelper debian/zerotier-one.substvars debian/*.log debian/zerotier-one debian/.debhelper debian/debhelper-build-stamp
  496. redhat:
  497. @echo "building rpm package"
  498. rpmbuild --target `rpm -q bash --qf "%{arch}"` -ba zerotier-one.spec
  499. # This installs the packages needed to build ZT locally on CentOS 7 and
  500. # is here largely for documentation purposes.
  501. centos-7-setup: FORCE
  502. yum install -y gcc gcc-c++ make epel-release git
  503. yum install -y centos-release-scl
  504. yum install -y devtoolset-8-gcc devtoolset-8-gcc-c++
  505. snap-build-local: FORCE
  506. snapcraft
  507. snap-install: FORCE
  508. snap install zerotier_`git describe --tags --abbrev=0`_${SNAP_ARCH}.snap --dangerous
  509. snap-uninstall: FORCE
  510. snap remove zerotier
  511. snap-build-remote: FORCE
  512. cd pkg && snapcraft remote-build --build-for=amd64,arm64,s390x,ppc64el,armhf,i386
  513. snap-upload: ./pkg/*.snap
  514. for file in $^ ; do \
  515. snapcraft upload --release=beta,edge,candidate $${file} ; \
  516. done
  517. synology-pkg: FORCE
  518. cd pkg/synology ; ./build.sh build
  519. synology-docker: FORCE
  520. cd pkg/synology/dsm7-docker/; ./build.sh build-and-push
  521. munge_rpm:
  522. @:$(call check_defined, VERSION)
  523. @echo "Updating rpm spec to $(VERSION)"
  524. ci/scripts/munge_rpm_spec.sh zerotier-one.spec $(VERSION) "Adam Ierymenko <[email protected]>" "see https://github.com/zerotier/ZeroTierOne for release notes"
  525. munge_deb:
  526. @:$(call check_defined, VERSION)
  527. @echo "Updating debian/changelog to $(VERSION)"
  528. ci/scripts/munge_debian_changelog.sh debian/changelog $(VERSION) "Adam Ierymenko <[email protected]>" "see https://github.com/zerotier/ZeroTierOne for release notes"
  529. FORCE: