diff --git a/.gitmodules b/.gitmodules
index b80b4c2dc..58fd21680 100644
--- a/.gitmodules
+++ b/.gitmodules
@@ -2,16 +2,16 @@
path = app-shared/flutter
url = https://github.com/flutter/flutter.git
[submodule "boost"]
- path = p2p/boost
+ path = lib-shared/boost
url = https://github.com/boostorg/boost.git
[submodule "cppcoro"]
- path = p2p/cppcoro
+ path = lib-shared/cppcoro
url = https://github.com/lewissbaker/cppcoro.git
[submodule "jsoncpp"]
- path = p2p/jsoncpp
+ path = lib-shared/jsoncpp
url = https://github.com/open-source-parsers/jsoncpp.git
[submodule "abseil-cpp"]
- path = min-webrtc/abseil-cpp
+ path = lib-shared/abseil-cpp
url = https://github.com/abseil/abseil-cpp.git
[submodule "libsrtp"]
path = min-webrtc/libsrtp
@@ -20,10 +20,10 @@
path = min-webrtc/webrtc
url = https://webrtc.googlesource.com/src
[submodule "openvpn3"]
- path = p2p/openvpn3
+ path = lib-protocol/openvpn3
url = https://github.com/OpenVPN/openvpn3.git
[submodule "lz4"]
- path = p2p/lz4
+ path = lib-protocol/lz4
url = https://github.com/lz4/lz4.git
[submodule "openzeppelin-solidity"]
path = openzeppelin-solidity
@@ -35,25 +35,25 @@
path = vpn-shared/libevent
url = https://github.com/libevent/libevent.git
[submodule "lwip"]
- path = p2p/lwip
+ path = lib-protocol/lwip
url = https://git.savannah.nongnu.org/git/lwip.git
[submodule "boringtun"]
- path = p2p/boringtun
+ path = lib-protocol/boringtun
url = https://github.com/cloudflare/boringtun.git
[submodule "tor"]
path = vpn-shared/tor
url = https://git.torproject.org/tor.git
[submodule "libutp"]
- path = p2p/libutp
+ path = lib-protocol/libutp
url = https://github.com/bittorrent/libutp.git
[submodule "flutter-desktop-embedding"]
path = app-shared/flutter-desktop-embedding
url = https://github.com/google/flutter-desktop-embedding
[submodule "url"]
- path = p2p/url
+ path = lib-shared/url
url = https://github.com/cpp-netlib/url
[submodule "secp256k1"]
- path = p2p/secp256k1
+ path = lib-shared/secp256k1
url = https://github.com/bitcoin-core/secp256k1.git
[submodule "openssl"]
path = min-openssl/openssl
@@ -65,16 +65,16 @@
path = min-zlib/libz
url = https://chromium.googlesource.com/chromium/src/third_party/zlib.git
[submodule "eEVM"]
- path = p2p/eEVM
+ path = lib-shared/eEVM
url = https://github.com/microsoft/eEVM.git
[submodule "tap-windows6"]
- path = p2p/tap-windows6
+ path = lib-protocol/tap-windows6
url = https://github.com/OpenVPN/tap-windows6
[submodule "sqlite"]
- path = p2p/sqlite
+ path = lib-shared/sqlite
url = https://github.com/mackyle/sqlite.git
[submodule "SPCDNS"]
- path = p2p/SPCDNS
+ path = lib-protocol/SPCDNS
url = https://github.com/spc476/SPCDNS
[submodule "wireshark"]
path = min-wireshark/wireshark
@@ -94,12 +94,6 @@
[submodule "gnulib"]
path = min-glib/gnulib
url = https://git.savannah.gnu.org/git/gnulib.git
-[submodule "libcxxabi"]
- path = env/libcxxabi
- url = https://github.com/llvm-mirror/libcxxabi.git
-[submodule "libcxx"]
- path = env/libcxx
- url = https://github.com/llvm-mirror/libcxx.git
[submodule "pkg-config"]
path = env/pkg-config
url = https://gitlab.freedesktop.org/pkg-config/pkg-config.git
@@ -107,16 +101,16 @@
path = vpn-shared/quickjs
url = https://github.com/bellard/quickjs.git
[submodule "intx"]
- path = p2p/intx
+ path = lib-shared/intx
url = https://github.com/chfast/intx.git
[submodule "expected"]
- path = p2p/expected
+ path = lib-shared/expected
url = https://github.com/TartanLlama/expected.git
[submodule "curl"]
- path = p2p/curl
+ path = lib-protocol/curl
url = https://github.com/curl/curl.git
[submodule "challenge-bypass-ristretto-ffi"]
- path = p2p/challenge-bypass-ristretto-ffi
+ path = lib-protocol/challenge-bypass-ristretto-ffi
url = https://github.com/brave-intl/challenge-bypass-ristretto-ffi.git
[submodule "icu"]
path = min-icu4c/icu
@@ -131,7 +125,7 @@
path = min-v8/trace_event
url = https://chromium.googlesource.com/chromium/src/base/trace_event/common.git
[submodule "protobuf"]
- path = p2p/protobuf
+ path = lib-protocol/protobuf
url = https://chromium.googlesource.com/external/github.com/google/protobuf
[submodule "jinja2"]
path = min-v8/jinja2
@@ -140,19 +134,19 @@
path = min-v8/markupsafe
url = https://chromium.googlesource.com/chromium/src/third_party/markupsafe.git
[submodule "fmt"]
- path = p2p/fmt
+ path = lib-shared/fmt
url = https://github.com/fmtlib/fmt.git
[submodule "leveldb"]
path = tst-explore/leveldb
url = https://github.com/google/leveldb.git
[submodule "c-ares"]
- path = p2p/c-ares
+ path = lib-protocol/c-ares
url = https://github.com/c-ares/c-ares.git
[submodule "SHA3IUF"]
- path = p2p/SHA3IUF
+ path = lib-shared/SHA3IUF
url = https://github.com/brainhub/SHA3IUF.git
[submodule "cpp-jwt"]
- path = p2p/cpp-jwt
+ path = lib-protocol/cpp-jwt
url = https://github.com/arun11299/cpp-jwt.git
[submodule "cairo"]
path = min-cairo/cairo
@@ -164,7 +158,7 @@
path = min-cairo/pixman
url = https://gitlab.freedesktop.org/pixman/pixman.git
[submodule "chains"]
- path = p2p/chains
+ path = lib-protocol/chains
url = https://github.com/ethereum-lists/chains.git
[submodule "engine"]
path = app-shared/engine
@@ -173,16 +167,16 @@
path = min-krypton/vpn-libraries
url = https://github.com/google/vpn-libraries.git
[submodule "compile-time-regular-expressions"]
- path = p2p/ctre
+ path = lib-shared/ctre
url = https://github.com/hanickadot/compile-time-regular-expressions.git
[submodule "trezor-common"]
- path = p2p/trezor-common
+ path = lib-protocol/trezor-common
url = https://github.com/trezor/trezor-common.git
[submodule "bech32"]
- path = p2p/bech32
+ path = lib-shared/bech32
url = https://github.com/sipa/bech32.git
[submodule "pugixml"]
- path = p2p/pugixml
+ path = lib-protocol/pugixml
url = https://github.com/zeux/pugixml.git
[submodule "mediasoup"]
path = eng-mediasoup/mediasoup
@@ -197,7 +191,7 @@
path = min-webrtc/crc32c
url = https://github.com/google/crc32c.git
[submodule "snappy"]
- path = p2p/snappy
+ path = lib-protocol/snappy
url = https://github.com/google/snappy.git
[submodule "pcre2"]
path = min-pcre2/pcre2
@@ -226,6 +220,12 @@
[submodule "mingw-w64"]
path = env/mingw-w64
url = https://git.code.sf.net/p/mingw-w64/mingw-w64
-[submodule "base"]
- path = min-v8/base
- url = https://chromium.googlesource.com/chromium/src/base
+[submodule "FP16"]
+ path = min-v8/FP16
+ url = https://github.com/Maratyszcza/FP16.git
+[submodule "boringssl"]
+ path = min-boringssl/boringssl
+ url = https://boringssl.googlesource.com/boringssl
+[submodule "llvm-project"]
+ path = env/llvm-project
+ url = https://github.com/llvm/llvm-project.git
diff --git a/app-ios/env b/app-ios/env
index f8b6ffdfe..971e97aa3 120000
--- a/app-ios/env
+++ b/app-ios/env
@@ -1 +1 @@
-vpn/shared/p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/app-macos/env b/app-macos/env
index f8b6ffdfe..971e97aa3 120000
--- a/app-macos/env
+++ b/app-macos/env
@@ -1 +1 @@
-vpn/shared/p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/cli-shared/env b/cli-shared/env
index db4309187..971e97aa3 120000
--- a/cli-shared/env
+++ b/cli-shared/env
@@ -1 +1 @@
-vpn/p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/p2p/source/android.cpp b/env/android.cpp
similarity index 97%
rename from p2p/source/android.cpp
rename to env/android.cpp
index 7675f280d..2636e63b5 100644
--- a/p2p/source/android.cpp
+++ b/env/android.cpp
@@ -20,8 +20,6 @@
/* }}} */
-#ifdef __ANDROID__
-
// some rust projects depend indirectly on the nix crate
// and rust object files have leaky translation units :(
// so linking the archive tries to pull in these symbols
@@ -35,5 +33,3 @@ extern "C" int getgrgid_r(gid_t gid, struct group *grp, char *buffer, size_t buf
extern "C" int getgrnam_r(const char *name, struct group *grp, char *buffer, size_t bufsize, struct group **result) {
orc_insist(false);
}
-
-#endif
diff --git a/env/extra/__config_site b/env/extra/__config_site
new file mode 100644
index 000000000..00b0dd9b1
--- /dev/null
+++ b/env/extra/__config_site
@@ -0,0 +1,3 @@
+#define _LIBCPP_ABI_VERSION 2
+#define _LIBCPP_HAS_NO_LIBRARY_ALIGNED_ALLOCATION
+#define _LIBCPP_HAS_NO_VENDOR_AVAILABILITY_ANNOTATIONS
diff --git a/env/libcxx b/env/libcxx
deleted file mode 160000
index 2076f539f..000000000
--- a/env/libcxx
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit 2076f539f410805ef88692b9c0ce0a0b882a7680
diff --git a/env/libcxx b/env/libcxx
new file mode 120000
index 000000000..2981ba46b
--- /dev/null
+++ b/env/libcxx
@@ -0,0 +1 @@
+llvm-project/libcxx
\ No newline at end of file
diff --git a/env/libcxxabi b/env/libcxxabi
deleted file mode 160000
index a88633b46..000000000
--- a/env/libcxxabi
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit a88633b46c401e6be38b93cf08660f137f86664d
diff --git a/env/libcxxabi b/env/libcxxabi
new file mode 120000
index 000000000..50b90ee6b
--- /dev/null
+++ b/env/libcxxabi
@@ -0,0 +1 @@
+llvm-project/libcxxabi
\ No newline at end of file
diff --git a/env/llvm-project b/env/llvm-project
new file mode 160000
index 000000000..c4c5e79dd
--- /dev/null
+++ b/env/llvm-project
@@ -0,0 +1 @@
+Subproject commit c4c5e79dd4b4c78eee7cffd9b0d7394b5bedcf12
diff --git a/env/submodule.sh b/env/submodule.sh
index be48ef39a..9d7bf7741 100755
--- a/env/submodule.sh
+++ b/env/submodule.sh
@@ -3,5 +3,5 @@ set -e
# XXX: flutter needs deep for an unknown reason; maybe this can be fixed?
# XXX: googletest broke recently and doesn't even support HEAD and I sigh
# XXX: the other repositories need uploadpack.allowReachableSHA1InWant :(
-git submodule update --init --recursive "$@" -- app-shared/flutter min-cairo/libpng min-glib/{gnulib,libiconv} min-zlib/googletest p2p/lwip srv-worker/glibc vpn-shared/{libssh,tor}
+git submodule update --init --recursive "$@" -- app-shared/flutter min-cairo/libpng min-glib/{gnulib,libiconv} min-zlib/googletest lib-protocol/lwip srv-worker/glibc vpn-shared/{libssh,tor}
git submodule update --init --recursive "$@" --depth 1
diff --git a/env/target-and.mk b/env/target-and.mk
index 3c33b14e7..d8029e9dd 100644
--- a/env/target-and.mk
+++ b/env/target-and.mk
@@ -91,3 +91,5 @@ lflags += -nostdlib++ -lc++abi
lflags += -lm -llog
wflags += -L$(CURDIR)/env/android
+
+source += env/android.cpp
diff --git a/env/target-cxx.mk b/env/target-cxx.mk
index 81c46af92..5ca57ff65 100644
--- a/env/target-cxx.mk
+++ b/env/target-cxx.mk
@@ -9,11 +9,18 @@
# }}}
+pwd/env := $(pwd)
+
xflags += -nostdinc++
xflags += -isystem $(CURDIR)/$(pwd)/libcxx/include
xflags += -isystem $(CURDIR)/$(pwd)/libcxxabi/include
+xflags += -isystem $(CURDIR)/$(pwd)/extra
+
+cflags/$(pwd)/libcxx/ += -I$(CURDIR)/$(pwd/env)/libcxx/src
+cflags/$(pwd)/libcxxabi/ += -I$(CURDIR)/$(pwd/env)/libcxx/src
source += $(wildcard $(pwd)/libcxx/src/*.cpp)
+source += $(wildcard $(pwd)/libcxx/src/ryu/*.cpp)
qflags += -D_LIBCPP_DISABLE_VISIBILITY_ANNOTATIONS
cflags/$(pwd)/libcxx/ += -D_LIBCPP_BUILDING_LIBRARY=
@@ -26,15 +33,14 @@ else
cflags/$(pwd)/libcxx/ += -D__GLIBCXX__
endif
-cflags/$(pwd)/libcxx/src/exception.cpp += -Wno-\#warnings
-cflags/$(pwd)/libcxxabi/src/cxa_thread_atexit.cpp += -Wno-pointer-bool-conversion
+source += $(pwd)/libcxxabi/src/abort_message.cpp
+source += $(pwd)/libcxxabi/src/cxa_demangle.cpp
+source += $(pwd)/libcxxabi/src/cxa_guard.cpp
+source += $(pwd)/libcxxabi/src/cxa_virtual.cpp
-source += env/libcxxabi/src/abort_message.cpp
-source += env/libcxxabi/src/cxa_demangle.cpp
-source += env/libcxxabi/src/cxa_guard.cpp
-source += env/libcxxabi/src/cxa_virtual.cpp
-
-ifneq ($(target),win)
+ifeq ($(target),win)
+source += $(pwd)/libcxx/src/support/win32/thread_win32.cpp
+else
# this requires _LIBCXXABI_WEAK to be defined
-source += env/libcxxabi/src/cxa_thread_atexit.cpp
+source += $(pwd)/libcxxabi/src/cxa_thread_atexit.cpp
endif
diff --git a/env/target-lld.mk b/env/target-lld.mk
index bd1c399f6..0f303493b 100644
--- a/env/target-lld.mk
+++ b/env/target-lld.mk
@@ -12,7 +12,12 @@
include $(pwd)/target-gnu.mk
wflags += -fuse-ld=lld
-lflags += -Wl,--icf=all
lflags += -Wl,--error-limit=0
+ifeq ($(filter nostrip,$(debug)),)
+lflags += -Wl,--icf=all
+else
+lflags += -Wl,--icf=none
+endif
+
export LLD_VERSION := Linker: LLD
diff --git a/env/target-lnx.mk b/env/target-lnx.mk
index 3b336de50..0796e5415 100644
--- a/env/target-lnx.mk
+++ b/env/target-lnx.mk
@@ -79,12 +79,8 @@ endef
$(each)
ifeq ($(distro),)
-ifneq ($(centos/$(machine)),)
-distro := centos6 $(machine) $(centos/$(machine))
-else
distro := ubuntu bionic 7
endif
-endif
sysroot += $(output)/sysroot
diff --git a/eth-sender/lib b/eth-sender/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/eth-sender/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/eth-sender/makefile b/eth-sender/makefile
index 3fdb928dc..175c4d809 100644
--- a/eth-sender/makefile
+++ b/eth-sender/makefile
@@ -35,7 +35,7 @@ cflags += -I$(pwd)/source
# XXX: this literally crashes clang-tidy and I haven't filed the bug
checks/$(pwd)/source/main.cpp += -bugprone-unchecked-optional-access
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
include env/output.mk
$(output)/%/cj$(exe): $(patsubst %,$(output)/$$*/%,$(object) $(linked))
diff --git a/eth-sender/p2p b/eth-sender/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/eth-sender/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/p2p/SPCDNS b/lib-protocol/SPCDNS
similarity index 100%
rename from p2p/SPCDNS
rename to lib-protocol/SPCDNS
diff --git a/p2p/boringtun b/lib-protocol/boringtun
similarity index 100%
rename from p2p/boringtun
rename to lib-protocol/boringtun
diff --git a/lib-protocol/boringtun.mk b/lib-protocol/boringtun.mk
new file mode 100644
index 000000000..7b1f707d3
--- /dev/null
+++ b/lib-protocol/boringtun.mk
@@ -0,0 +1,23 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+linked += $(pwd)/boringtun/boringtun/librust.a
+cflags += -I$(pwd)/boringtun/boringtun/src
+features/$(pwd)/boringtun/boringtun += ffi-bindings
diff --git a/p2p/c-ares b/lib-protocol/c-ares
similarity index 100%
rename from p2p/c-ares
rename to lib-protocol/c-ares
diff --git a/p2p/c-ares.mk b/lib-protocol/c-ares.mk
similarity index 100%
rename from p2p/c-ares.mk
rename to lib-protocol/c-ares.mk
diff --git a/p2p/chains b/lib-protocol/chains
similarity index 100%
rename from p2p/chains
rename to lib-protocol/chains
diff --git a/p2p/challenge-bypass-ristretto-ffi b/lib-protocol/challenge-bypass-ristretto-ffi
similarity index 100%
rename from p2p/challenge-bypass-ristretto-ffi
rename to lib-protocol/challenge-bypass-ristretto-ffi
diff --git a/p2p/cpp-jwt b/lib-protocol/cpp-jwt
similarity index 100%
rename from p2p/cpp-jwt
rename to lib-protocol/cpp-jwt
diff --git a/p2p/curl b/lib-protocol/curl
similarity index 100%
rename from p2p/curl
rename to lib-protocol/curl
diff --git a/p2p/extra/arch/cc.h b/lib-protocol/extra/arch/cc.h
similarity index 100%
rename from p2p/extra/arch/cc.h
rename to lib-protocol/extra/arch/cc.h
diff --git a/p2p/extra/google/protobuf b/lib-protocol/extra/google/protobuf
similarity index 100%
rename from p2p/extra/google/protobuf
rename to lib-protocol/extra/google/protobuf
diff --git a/p2p/extra/inet.h b/lib-protocol/extra/inet.h
similarity index 100%
rename from p2p/extra/inet.h
rename to lib-protocol/extra/inet.h
diff --git a/p2p/extra/lwipopts.h b/lib-protocol/extra/lwipopts.h
similarity index 100%
rename from p2p/extra/lwipopts.h
rename to lib-protocol/extra/lwipopts.h
diff --git a/p2p/extra/ndisguid.h b/lib-protocol/extra/ndisguid.h
similarity index 100%
rename from p2p/extra/ndisguid.h
rename to lib-protocol/extra/ndisguid.h
diff --git a/p2p/extra/openvpn/netconf/hwaddr.hpp b/lib-protocol/extra/openvpn/netconf/hwaddr.hpp
similarity index 100%
rename from p2p/extra/openvpn/netconf/hwaddr.hpp
rename to lib-protocol/extra/openvpn/netconf/hwaddr.hpp
diff --git a/p2p/extra/ovpncli.hpp b/lib-protocol/extra/ovpncli.hpp
similarity index 100%
rename from p2p/extra/ovpncli.hpp
rename to lib-protocol/extra/ovpncli.hpp
diff --git a/p2p/extra/snappy-stubs-public.h b/lib-protocol/extra/snappy-stubs-public.h
similarity index 100%
rename from p2p/extra/snappy-stubs-public.h
rename to lib-protocol/extra/snappy-stubs-public.h
diff --git a/p2p/extra/sockets.h b/lib-protocol/extra/sockets.h
similarity index 100%
rename from p2p/extra/sockets.h
rename to lib-protocol/extra/sockets.h
diff --git a/p2p/extra/third_party/protobuf b/lib-protocol/extra/third_party/protobuf
similarity index 100%
rename from p2p/extra/third_party/protobuf
rename to lib-protocol/extra/third_party/protobuf
diff --git a/p2p/extra/wincrypt.h b/lib-protocol/extra/wincrypt.h
similarity index 100%
rename from p2p/extra/wincrypt.h
rename to lib-protocol/extra/wincrypt.h
diff --git a/p2p/field.h b/lib-protocol/field.h
similarity index 100%
rename from p2p/field.h
rename to lib-protocol/field.h
diff --git a/lib-protocol/jwt.mk b/lib-protocol/jwt.mk
new file mode 100644
index 000000000..c9c5ee2dd
--- /dev/null
+++ b/lib-protocol/jwt.mk
@@ -0,0 +1,21 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+cflags += -I$(pwd)/cpp-jwt/include
diff --git a/p2p/krypton b/lib-protocol/krypton
similarity index 100%
rename from p2p/krypton
rename to lib-protocol/krypton
diff --git a/p2p/libutp b/lib-protocol/libutp
similarity index 100%
rename from p2p/libutp
rename to lib-protocol/libutp
diff --git a/lib-protocol/libutp.mk b/lib-protocol/libutp.mk
new file mode 100644
index 000000000..ad68deac4
--- /dev/null
+++ b/lib-protocol/libutp.mk
@@ -0,0 +1,34 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+source += $(filter-out \
+ %/libutp_inet_ntop.cpp \
+,$(wildcard $(pwd)/libutp/*.cpp))
+
+cflags += -I$(pwd)/libutp
+cflags/$(pwd)/libutp/ += -Wno-unused-const-variable
+cflags/$(pwd)/libutp/ += -Wno-unused-variable
+
+ifeq ($(target),win)
+source += $(pwd)/libutp/libutp_inet_ntop.cpp
+cflags += -DWIN32
+else
+cflags += -DPOSIX=5
+endif
diff --git a/p2p/lwip b/lib-protocol/lwip
similarity index 100%
rename from p2p/lwip
rename to lib-protocol/lwip
diff --git a/lib-protocol/lwip.mk b/lib-protocol/lwip.mk
new file mode 100644
index 000000000..e3d9a45cf
--- /dev/null
+++ b/lib-protocol/lwip.mk
@@ -0,0 +1,47 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+source += $(wildcard $(pwd)/lwip/src/api/*.c)
+source += $(wildcard $(pwd)/lwip/src/core/*.c)
+source += $(wildcard $(pwd)/lwip/src/core/ipv4/*.c)
+source += $(wildcard $(pwd)/lwip/src/core/ipv6/*.c)
+source += $(pwd)/lwip/src/netif/ethernet.c
+
+ifeq ($(target),and)
+cflags/$(pwd)/lwip/ += -Wno-missing-braces
+endif
+
+ifeq ($(target),win)
+source += $(pwd)/lwip/contrib/ports/win32/sys_arch.c
+cflags/$(pwd)/lwip/contrib/ports/win32/sys_arch.c += -UWIN32_LEAN_AND_MEAN
+cflags += -I$(pwd)/lwip/contrib/ports/win32/include
+else
+source += $(pwd)/lwip/contrib/ports/unix/port/sys_arch.c
+cflags += -I$(pwd)/lwip/contrib/ports/unix/port/include
+endif
+
+cflags += -I$(pwd)/lwip/src/include
+
+cflags += -DLWIP_ERRNO_STDINCLUDE
+cflags += -DLWIP_TCP
+
+ifeq ($(target),lnx)
+cflags += -DTCP_USER_TIMEOUT=18
+endif
diff --git a/p2p/lwip.sh b/lib-protocol/lwip.sh
similarity index 100%
rename from p2p/lwip.sh
rename to lib-protocol/lwip.sh
diff --git a/p2p/lz4 b/lib-protocol/lz4
similarity index 100%
rename from p2p/lz4
rename to lib-protocol/lz4
diff --git a/p2p/openvpn3 b/lib-protocol/openvpn3
similarity index 100%
rename from p2p/openvpn3
rename to lib-protocol/openvpn3
diff --git a/p2p/openvpn3.mk b/lib-protocol/openvpn3.mk
similarity index 100%
rename from p2p/openvpn3.mk
rename to lib-protocol/openvpn3.mk
diff --git a/p2p/protobuf b/lib-protocol/protobuf
similarity index 100%
rename from p2p/protobuf
rename to lib-protocol/protobuf
diff --git a/p2p/protobuf.mk b/lib-protocol/protobuf.mk
similarity index 100%
rename from p2p/protobuf.mk
rename to lib-protocol/protobuf.mk
diff --git a/p2p/pugixml b/lib-protocol/pugixml
similarity index 100%
rename from p2p/pugixml
rename to lib-protocol/pugixml
diff --git a/lib-protocol/pugixml.mk b/lib-protocol/pugixml.mk
new file mode 100644
index 000000000..72eb0e8b9
--- /dev/null
+++ b/lib-protocol/pugixml.mk
@@ -0,0 +1,23 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+source += $(pwd)/pugixml/src/pugixml.cpp
+cflags += -I$(pwd)/pugixml/src
+cflags += -DPUGIXML_HAS_LONG_LONG
diff --git a/lib-protocol/ristretto.mk b/lib-protocol/ristretto.mk
new file mode 100644
index 000000000..a4c1ea532
--- /dev/null
+++ b/lib-protocol/ristretto.mk
@@ -0,0 +1,23 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+linked += $(pwd)/challenge-bypass-ristretto-ffi/librust.a
+cflags += -I$(pwd)/challenge-bypass-ristretto-ffi/src
+source += $(pwd)/challenge-bypass-ristretto-ffi/src/wrapper.cpp
diff --git a/lib-protocol/shared b/lib-protocol/shared
new file mode 120000
index 000000000..005659d22
--- /dev/null
+++ b/lib-protocol/shared
@@ -0,0 +1 @@
+../lib-shared
\ No newline at end of file
diff --git a/p2p/snappy b/lib-protocol/snappy
similarity index 100%
rename from p2p/snappy
rename to lib-protocol/snappy
diff --git a/lib-protocol/snappy.mk b/lib-protocol/snappy.mk
new file mode 100644
index 000000000..b56f730d0
--- /dev/null
+++ b/lib-protocol/snappy.mk
@@ -0,0 +1,23 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+source += $(pwd)/snappy/snappy.cc
+source += $(pwd)/snappy/snappy-sinksource.cc
+cflags += -I$(pwd)/snappy
diff --git a/p2p/source/acceptor.hpp b/lib-protocol/source/acceptor.hpp
similarity index 100%
rename from p2p/source/acceptor.hpp
rename to lib-protocol/source/acceptor.hpp
diff --git a/p2p/source/adapter.hpp b/lib-protocol/source/adapter.hpp
similarity index 100%
rename from p2p/source/adapter.hpp
rename to lib-protocol/source/adapter.hpp
diff --git a/p2p/source/base.cpp b/lib-protocol/source/base.cpp
similarity index 100%
rename from p2p/source/base.cpp
rename to lib-protocol/source/base.cpp
diff --git a/p2p/source/base.hpp b/lib-protocol/source/base.hpp
similarity index 100%
rename from p2p/source/base.hpp
rename to lib-protocol/source/base.hpp
diff --git a/p2p/source/baton.cpp b/lib-protocol/source/baton.cpp
similarity index 100%
rename from p2p/source/baton.cpp
rename to lib-protocol/source/baton.cpp
diff --git a/p2p/source/baton.hpp b/lib-protocol/source/baton.hpp
similarity index 100%
rename from p2p/source/baton.hpp
rename to lib-protocol/source/baton.hpp
diff --git a/p2p/source/bearer.hpp b/lib-protocol/source/bearer.hpp
similarity index 100%
rename from p2p/source/bearer.hpp
rename to lib-protocol/source/bearer.hpp
diff --git a/p2p/source/beast.hpp b/lib-protocol/source/beast.hpp
similarity index 100%
rename from p2p/source/beast.hpp
rename to lib-protocol/source/beast.hpp
diff --git a/p2p/source/bench.hpp b/lib-protocol/source/bench.hpp
similarity index 100%
rename from p2p/source/bench.hpp
rename to lib-protocol/source/bench.hpp
diff --git a/p2p/source/binance.cpp b/lib-protocol/source/binance.cpp
similarity index 100%
rename from p2p/source/binance.cpp
rename to lib-protocol/source/binance.cpp
diff --git a/p2p/source/bonded.hpp b/lib-protocol/source/bonded.hpp
similarity index 100%
rename from p2p/source/bonded.hpp
rename to lib-protocol/source/bonded.hpp
diff --git a/p2p/source/boring.cpp b/lib-protocol/source/boring.cpp
similarity index 100%
rename from p2p/source/boring.cpp
rename to lib-protocol/source/boring.cpp
diff --git a/p2p/source/boring.hpp b/lib-protocol/source/boring.hpp
similarity index 100%
rename from p2p/source/boring.hpp
rename to lib-protocol/source/boring.hpp
diff --git a/p2p/source/butcher.hpp b/lib-protocol/source/butcher.hpp
similarity index 100%
rename from p2p/source/butcher.hpp
rename to lib-protocol/source/butcher.hpp
diff --git a/p2p/source/cache.hpp b/lib-protocol/source/cache.hpp
similarity index 100%
rename from p2p/source/cache.hpp
rename to lib-protocol/source/cache.hpp
diff --git a/p2p/source/cairo.hpp b/lib-protocol/source/cairo.hpp
similarity index 100%
rename from p2p/source/cairo.hpp
rename to lib-protocol/source/cairo.hpp
diff --git a/p2p/source/candidate.cpp b/lib-protocol/source/candidate.cpp
similarity index 100%
rename from p2p/source/candidate.cpp
rename to lib-protocol/source/candidate.cpp
diff --git a/p2p/source/chain.cpp b/lib-protocol/source/chain.cpp
similarity index 100%
rename from p2p/source/chain.cpp
rename to lib-protocol/source/chain.cpp
diff --git a/p2p/source/chain.hpp b/lib-protocol/source/chain.hpp
similarity index 100%
rename from p2p/source/chain.hpp
rename to lib-protocol/source/chain.hpp
diff --git a/p2p/source/chainlink.cpp b/lib-protocol/source/chainlink.cpp
similarity index 100%
rename from p2p/source/chainlink.cpp
rename to lib-protocol/source/chainlink.cpp
diff --git a/p2p/source/chainlink.hpp b/lib-protocol/source/chainlink.hpp
similarity index 100%
rename from p2p/source/chainlink.hpp
rename to lib-protocol/source/chainlink.hpp
diff --git a/p2p/source/channel.cpp b/lib-protocol/source/channel.cpp
similarity index 100%
rename from p2p/source/channel.cpp
rename to lib-protocol/source/channel.cpp
diff --git a/p2p/source/channel.hpp b/lib-protocol/source/channel.hpp
similarity index 100%
rename from p2p/source/channel.hpp
rename to lib-protocol/source/channel.hpp
diff --git a/p2p/source/chart.cpp b/lib-protocol/source/chart.cpp
similarity index 100%
rename from p2p/source/chart.cpp
rename to lib-protocol/source/chart.cpp
diff --git a/p2p/source/chart.hpp b/lib-protocol/source/chart.hpp
similarity index 100%
rename from p2p/source/chart.hpp
rename to lib-protocol/source/chart.hpp
diff --git a/p2p/source/cipher.cpp b/lib-protocol/source/cipher.cpp
similarity index 100%
rename from p2p/source/cipher.cpp
rename to lib-protocol/source/cipher.cpp
diff --git a/p2p/source/cipher.hpp b/lib-protocol/source/cipher.hpp
similarity index 100%
rename from p2p/source/cipher.hpp
rename to lib-protocol/source/cipher.hpp
diff --git a/p2p/source/coinbase.cpp b/lib-protocol/source/coinbase.cpp
similarity index 100%
rename from p2p/source/coinbase.cpp
rename to lib-protocol/source/coinbase.cpp
diff --git a/p2p/source/configuration.hpp b/lib-protocol/source/configuration.hpp
similarity index 100%
rename from p2p/source/configuration.hpp
rename to lib-protocol/source/configuration.hpp
diff --git a/p2p/source/connection.hpp b/lib-protocol/source/connection.hpp
similarity index 100%
rename from p2p/source/connection.hpp
rename to lib-protocol/source/connection.hpp
diff --git a/p2p/source/contract.hpp b/lib-protocol/source/contract.hpp
similarity index 100%
rename from p2p/source/contract.hpp
rename to lib-protocol/source/contract.hpp
diff --git a/p2p/source/currency.cpp b/lib-protocol/source/currency.cpp
similarity index 100%
rename from p2p/source/currency.cpp
rename to lib-protocol/source/currency.cpp
diff --git a/p2p/source/currency.hpp b/lib-protocol/source/currency.hpp
similarity index 100%
rename from p2p/source/currency.hpp
rename to lib-protocol/source/currency.hpp
diff --git a/p2p/source/datagram.cpp b/lib-protocol/source/datagram.cpp
similarity index 100%
rename from p2p/source/datagram.cpp
rename to lib-protocol/source/datagram.cpp
diff --git a/p2p/source/datagram.hpp b/lib-protocol/source/datagram.hpp
similarity index 100%
rename from p2p/source/datagram.hpp
rename to lib-protocol/source/datagram.hpp
diff --git a/p2p/source/defragment.cpp b/lib-protocol/source/defragment.cpp
similarity index 100%
rename from p2p/source/defragment.cpp
rename to lib-protocol/source/defragment.cpp
diff --git a/p2p/source/defragment.hpp b/lib-protocol/source/defragment.hpp
similarity index 100%
rename from p2p/source/defragment.hpp
rename to lib-protocol/source/defragment.hpp
diff --git a/p2p/source/dns.cpp b/lib-protocol/source/dns.cpp
similarity index 100%
rename from p2p/source/dns.cpp
rename to lib-protocol/source/dns.cpp
diff --git a/p2p/source/dns.hpp b/lib-protocol/source/dns.hpp
similarity index 100%
rename from p2p/source/dns.hpp
rename to lib-protocol/source/dns.hpp
diff --git a/p2p/source/drain.hpp b/lib-protocol/source/drain.hpp
similarity index 100%
rename from p2p/source/drain.hpp
rename to lib-protocol/source/drain.hpp
diff --git a/p2p/source/duplex.cpp b/lib-protocol/source/duplex.cpp
similarity index 100%
rename from p2p/source/duplex.cpp
rename to lib-protocol/source/duplex.cpp
diff --git a/p2p/source/duplex.hpp b/lib-protocol/source/duplex.hpp
similarity index 100%
rename from p2p/source/duplex.hpp
rename to lib-protocol/source/duplex.hpp
diff --git a/p2p/source/encoding.cpp b/lib-protocol/source/encoding.cpp
similarity index 100%
rename from p2p/source/encoding.cpp
rename to lib-protocol/source/encoding.cpp
diff --git a/p2p/source/encoding.hpp b/lib-protocol/source/encoding.hpp
similarity index 100%
rename from p2p/source/encoding.hpp
rename to lib-protocol/source/encoding.hpp
diff --git a/p2p/source/endpoint.cpp b/lib-protocol/source/endpoint.cpp
similarity index 100%
rename from p2p/source/endpoint.cpp
rename to lib-protocol/source/endpoint.cpp
diff --git a/p2p/source/endpoint.hpp b/lib-protocol/source/endpoint.hpp
similarity index 100%
rename from p2p/source/endpoint.hpp
rename to lib-protocol/source/endpoint.hpp
diff --git a/p2p/source/ethereum.cpp b/lib-protocol/source/ethereum.cpp
similarity index 100%
rename from p2p/source/ethereum.cpp
rename to lib-protocol/source/ethereum.cpp
diff --git a/p2p/source/ethereum.hpp b/lib-protocol/source/ethereum.hpp
similarity index 100%
rename from p2p/source/ethereum.hpp
rename to lib-protocol/source/ethereum.hpp
diff --git a/p2p/source/event.hpp b/lib-protocol/source/event.hpp
similarity index 100%
rename from p2p/source/event.hpp
rename to lib-protocol/source/event.hpp
diff --git a/p2p/source/execute.hpp b/lib-protocol/source/execute.hpp
similarity index 100%
rename from p2p/source/execute.hpp
rename to lib-protocol/source/execute.hpp
diff --git a/p2p/source/executor.cpp b/lib-protocol/source/executor.cpp
similarity index 100%
rename from p2p/source/executor.cpp
rename to lib-protocol/source/executor.cpp
diff --git a/p2p/source/executor.hpp b/lib-protocol/source/executor.hpp
similarity index 100%
rename from p2p/source/executor.hpp
rename to lib-protocol/source/executor.hpp
diff --git a/p2p/source/fetcher.hpp b/lib-protocol/source/fetcher.hpp
similarity index 100%
rename from p2p/source/fetcher.hpp
rename to lib-protocol/source/fetcher.hpp
diff --git a/p2p/source/fiat.hpp b/lib-protocol/source/fiat.hpp
similarity index 100%
rename from p2p/source/fiat.hpp
rename to lib-protocol/source/fiat.hpp
diff --git a/p2p/source/file.hpp b/lib-protocol/source/file.hpp
similarity index 100%
rename from p2p/source/file.hpp
rename to lib-protocol/source/file.hpp
diff --git a/p2p/source/forge.cpp b/lib-protocol/source/forge.cpp
similarity index 100%
rename from p2p/source/forge.cpp
rename to lib-protocol/source/forge.cpp
diff --git a/p2p/source/forge.hpp b/lib-protocol/source/forge.hpp
similarity index 100%
rename from p2p/source/forge.hpp
rename to lib-protocol/source/forge.hpp
diff --git a/p2p/source/format.hpp b/lib-protocol/source/format.hpp
similarity index 100%
rename from p2p/source/format.hpp
rename to lib-protocol/source/format.hpp
diff --git a/p2p/source/function.hpp b/lib-protocol/source/function.hpp
similarity index 100%
rename from p2p/source/function.hpp
rename to lib-protocol/source/function.hpp
diff --git a/p2p/source/huobi.cpp b/lib-protocol/source/huobi.cpp
similarity index 100%
rename from p2p/source/huobi.cpp
rename to lib-protocol/source/huobi.cpp
diff --git a/p2p/source/huobi.hpp b/lib-protocol/source/huobi.hpp
similarity index 100%
rename from p2p/source/huobi.hpp
rename to lib-protocol/source/huobi.hpp
diff --git a/p2p/source/jsonrpc.hpp b/lib-protocol/source/jsonrpc.hpp
similarity index 100%
rename from p2p/source/jsonrpc.hpp
rename to lib-protocol/source/jsonrpc.hpp
diff --git a/p2p/source/kraken.cpp b/lib-protocol/source/kraken.cpp
similarity index 100%
rename from p2p/source/kraken.cpp
rename to lib-protocol/source/kraken.cpp
diff --git a/p2p/source/layer.hpp b/lib-protocol/source/layer.hpp
similarity index 100%
rename from p2p/source/layer.hpp
rename to lib-protocol/source/layer.hpp
diff --git a/p2p/source/link.hpp b/lib-protocol/source/link.hpp
similarity index 100%
rename from p2p/source/link.hpp
rename to lib-protocol/source/link.hpp
diff --git a/p2p/source/load.cpp b/lib-protocol/source/load.cpp
similarity index 100%
rename from p2p/source/load.cpp
rename to lib-protocol/source/load.cpp
diff --git a/p2p/source/load.hpp b/lib-protocol/source/load.hpp
similarity index 100%
rename from p2p/source/load.hpp
rename to lib-protocol/source/load.hpp
diff --git a/p2p/source/local.cpp b/lib-protocol/source/local.cpp
similarity index 100%
rename from p2p/source/local.cpp
rename to lib-protocol/source/local.cpp
diff --git a/p2p/source/local.hpp b/lib-protocol/source/local.hpp
similarity index 100%
rename from p2p/source/local.hpp
rename to lib-protocol/source/local.hpp
diff --git a/p2p/source/locator.cpp b/lib-protocol/source/locator.cpp
similarity index 100%
rename from p2p/source/locator.cpp
rename to lib-protocol/source/locator.cpp
diff --git a/p2p/source/locator.hpp b/lib-protocol/source/locator.hpp
similarity index 100%
rename from p2p/source/locator.hpp
rename to lib-protocol/source/locator.hpp
diff --git a/p2p/source/logical_.hpp b/lib-protocol/source/logical_.hpp
similarity index 100%
rename from p2p/source/logical_.hpp
rename to lib-protocol/source/logical_.hpp
diff --git a/p2p/source/lwip.cpp b/lib-protocol/source/lwip.cpp
similarity index 100%
rename from p2p/source/lwip.cpp
rename to lib-protocol/source/lwip.cpp
diff --git a/p2p/source/lwip.hpp b/lib-protocol/source/lwip.hpp
similarity index 100%
rename from p2p/source/lwip.hpp
rename to lib-protocol/source/lwip.hpp
diff --git a/p2p/source/manager.hpp b/lib-protocol/source/manager.hpp
similarity index 100%
rename from p2p/source/manager.hpp
rename to lib-protocol/source/manager.hpp
diff --git a/p2p/source/market.cpp b/lib-protocol/source/market.cpp
similarity index 100%
rename from p2p/source/market.cpp
rename to lib-protocol/source/market.cpp
diff --git a/p2p/source/market.hpp b/lib-protocol/source/market.hpp
similarity index 100%
rename from p2p/source/market.hpp
rename to lib-protocol/source/market.hpp
diff --git a/p2p/source/markup.hpp b/lib-protocol/source/markup.hpp
similarity index 100%
rename from p2p/source/markup.hpp
rename to lib-protocol/source/markup.hpp
diff --git a/p2p/source/memory.cpp b/lib-protocol/source/memory.cpp
similarity index 100%
rename from p2p/source/memory.cpp
rename to lib-protocol/source/memory.cpp
diff --git a/p2p/source/memory.hpp b/lib-protocol/source/memory.hpp
similarity index 100%
rename from p2p/source/memory.hpp
rename to lib-protocol/source/memory.hpp
diff --git a/p2p/source/negotiate.cpp b/lib-protocol/source/negotiate.cpp
similarity index 100%
rename from p2p/source/negotiate.cpp
rename to lib-protocol/source/negotiate.cpp
diff --git a/p2p/source/nest.hpp b/lib-protocol/source/nest.hpp
similarity index 100%
rename from p2p/source/nest.hpp
rename to lib-protocol/source/nest.hpp
diff --git a/p2p/source/nested.cpp b/lib-protocol/source/nested.cpp
similarity index 100%
rename from p2p/source/nested.cpp
rename to lib-protocol/source/nested.cpp
diff --git a/p2p/source/nested.hpp b/lib-protocol/source/nested.hpp
similarity index 100%
rename from p2p/source/nested.hpp
rename to lib-protocol/source/nested.hpp
diff --git a/p2p/source/parallel.hpp b/lib-protocol/source/parallel.hpp
similarity index 100%
rename from p2p/source/parallel.hpp
rename to lib-protocol/source/parallel.hpp
diff --git a/p2p/source/peer.cpp b/lib-protocol/source/peer.cpp
similarity index 100%
rename from p2p/source/peer.cpp
rename to lib-protocol/source/peer.cpp
diff --git a/p2p/source/peer.hpp b/lib-protocol/source/peer.hpp
similarity index 100%
rename from p2p/source/peer.hpp
rename to lib-protocol/source/peer.hpp
diff --git a/p2p/source/pile.hpp b/lib-protocol/source/pile.hpp
similarity index 100%
rename from p2p/source/pile.hpp
rename to lib-protocol/source/pile.hpp
diff --git a/p2p/source/pirate.hpp b/lib-protocol/source/pirate.hpp
similarity index 100%
rename from p2p/source/pirate.hpp
rename to lib-protocol/source/pirate.hpp
diff --git a/p2p/source/port.hpp b/lib-protocol/source/port.hpp
similarity index 100%
rename from p2p/source/port.hpp
rename to lib-protocol/source/port.hpp
diff --git a/p2p/source/pricing.hpp b/lib-protocol/source/pricing.hpp
similarity index 100%
rename from p2p/source/pricing.hpp
rename to lib-protocol/source/pricing.hpp
diff --git a/p2p/source/protocol.cpp b/lib-protocol/source/protocol.cpp
similarity index 100%
rename from p2p/source/protocol.cpp
rename to lib-protocol/source/protocol.cpp
diff --git a/p2p/source/protocol.hpp b/lib-protocol/source/protocol.hpp
similarity index 100%
rename from p2p/source/protocol.hpp
rename to lib-protocol/source/protocol.hpp
diff --git a/p2p/source/query.hpp b/lib-protocol/source/query.hpp
similarity index 100%
rename from p2p/source/query.hpp
rename to lib-protocol/source/query.hpp
diff --git a/p2p/source/reader.hpp b/lib-protocol/source/reader.hpp
similarity index 100%
rename from p2p/source/reader.hpp
rename to lib-protocol/source/reader.hpp
diff --git a/p2p/source/regex.hpp b/lib-protocol/source/regex.hpp
similarity index 100%
rename from p2p/source/regex.hpp
rename to lib-protocol/source/regex.hpp
diff --git a/p2p/source/remote.cpp b/lib-protocol/source/remote.cpp
similarity index 100%
rename from p2p/source/remote.cpp
rename to lib-protocol/source/remote.cpp
diff --git a/p2p/source/remote.hpp b/lib-protocol/source/remote.hpp
similarity index 100%
rename from p2p/source/remote.hpp
rename to lib-protocol/source/remote.hpp
diff --git a/p2p/source/request.cpp b/lib-protocol/source/request.cpp
similarity index 100%
rename from p2p/source/request.cpp
rename to lib-protocol/source/request.cpp
diff --git a/p2p/source/request.hpp b/lib-protocol/source/request.hpp
similarity index 100%
rename from p2p/source/request.hpp
rename to lib-protocol/source/request.hpp
diff --git a/p2p/source/response.hpp b/lib-protocol/source/response.hpp
similarity index 100%
rename from p2p/source/response.hpp
rename to lib-protocol/source/response.hpp
diff --git a/p2p/source/retry.hpp b/lib-protocol/source/retry.hpp
similarity index 100%
rename from p2p/source/retry.hpp
rename to lib-protocol/source/retry.hpp
diff --git a/p2p/source/segwit.cpp b/lib-protocol/source/segwit.cpp
similarity index 100%
rename from p2p/source/segwit.cpp
rename to lib-protocol/source/segwit.cpp
diff --git a/p2p/source/segwit.hpp b/lib-protocol/source/segwit.hpp
similarity index 100%
rename from p2p/source/segwit.hpp
rename to lib-protocol/source/segwit.hpp
diff --git a/p2p/source/sequence.hpp b/lib-protocol/source/sequence.hpp
similarity index 100%
rename from p2p/source/sequence.hpp
rename to lib-protocol/source/sequence.hpp
diff --git a/p2p/source/sewer.hpp b/lib-protocol/source/sewer.hpp
similarity index 100%
rename from p2p/source/sewer.hpp
rename to lib-protocol/source/sewer.hpp
diff --git a/p2p/source/signed.hpp b/lib-protocol/source/signed.hpp
similarity index 100%
rename from p2p/source/signed.hpp
rename to lib-protocol/source/signed.hpp
diff --git a/p2p/source/site.cpp b/lib-protocol/source/site.cpp
similarity index 100%
rename from p2p/source/site.cpp
rename to lib-protocol/source/site.cpp
diff --git a/p2p/source/site.hpp b/lib-protocol/source/site.hpp
similarity index 100%
rename from p2p/source/site.hpp
rename to lib-protocol/source/site.hpp
diff --git a/p2p/source/sleep.cpp b/lib-protocol/source/sleep.cpp
similarity index 100%
rename from p2p/source/sleep.cpp
rename to lib-protocol/source/sleep.cpp
diff --git a/p2p/source/sleep.hpp b/lib-protocol/source/sleep.hpp
similarity index 100%
rename from p2p/source/sleep.hpp
rename to lib-protocol/source/sleep.hpp
diff --git a/p2p/source/socket.hpp b/lib-protocol/source/socket.hpp
similarity index 100%
rename from p2p/source/socket.hpp
rename to lib-protocol/source/socket.hpp
diff --git a/p2p/source/spawn.cpp b/lib-protocol/source/spawn.cpp
similarity index 100%
rename from p2p/source/spawn.cpp
rename to lib-protocol/source/spawn.cpp
diff --git a/p2p/source/spawn.hpp b/lib-protocol/source/spawn.hpp
similarity index 100%
rename from p2p/source/spawn.hpp
rename to lib-protocol/source/spawn.hpp
diff --git a/p2p/source/specific.hpp b/lib-protocol/source/specific.hpp
similarity index 100%
rename from p2p/source/specific.hpp
rename to lib-protocol/source/specific.hpp
diff --git a/p2p/source/station.cpp b/lib-protocol/source/station.cpp
similarity index 100%
rename from p2p/source/station.cpp
rename to lib-protocol/source/station.cpp
diff --git a/p2p/source/station.hpp b/lib-protocol/source/station.hpp
similarity index 100%
rename from p2p/source/station.hpp
rename to lib-protocol/source/station.hpp
diff --git a/p2p/source/store.cpp b/lib-protocol/source/store.cpp
similarity index 100%
rename from p2p/source/store.cpp
rename to lib-protocol/source/store.cpp
diff --git a/p2p/source/store.hpp b/lib-protocol/source/store.hpp
similarity index 100%
rename from p2p/source/store.hpp
rename to lib-protocol/source/store.hpp
diff --git a/p2p/source/structured.hpp b/lib-protocol/source/structured.hpp
similarity index 100%
rename from p2p/source/structured.hpp
rename to lib-protocol/source/structured.hpp
diff --git a/p2p/source/sync.hpp b/lib-protocol/source/sync.hpp
similarity index 100%
rename from p2p/source/sync.hpp
rename to lib-protocol/source/sync.hpp
diff --git a/p2p/source/tag.hpp b/lib-protocol/source/tag.hpp
similarity index 100%
rename from p2p/source/tag.hpp
rename to lib-protocol/source/tag.hpp
diff --git a/p2p/source/threads.cpp b/lib-protocol/source/threads.cpp
similarity index 100%
rename from p2p/source/threads.cpp
rename to lib-protocol/source/threads.cpp
diff --git a/p2p/source/threads.hpp b/lib-protocol/source/threads.hpp
similarity index 100%
rename from p2p/source/threads.hpp
rename to lib-protocol/source/threads.hpp
diff --git a/p2p/source/ticket.hpp b/lib-protocol/source/ticket.hpp
similarity index 100%
rename from p2p/source/ticket.hpp
rename to lib-protocol/source/ticket.hpp
diff --git a/p2p/source/token.cpp b/lib-protocol/source/token.cpp
similarity index 100%
rename from p2p/source/token.cpp
rename to lib-protocol/source/token.cpp
diff --git a/p2p/source/token.hpp b/lib-protocol/source/token.hpp
similarity index 100%
rename from p2p/source/token.hpp
rename to lib-protocol/source/token.hpp
diff --git a/p2p/source/trace.cpp b/lib-protocol/source/trace.cpp
similarity index 100%
rename from p2p/source/trace.cpp
rename to lib-protocol/source/trace.cpp
diff --git a/p2p/source/trace.hpp b/lib-protocol/source/trace.hpp
similarity index 100%
rename from p2p/source/trace.hpp
rename to lib-protocol/source/trace.hpp
diff --git a/p2p/source/translate.hpp b/lib-protocol/source/translate.hpp
similarity index 100%
rename from p2p/source/translate.hpp
rename to lib-protocol/source/translate.hpp
diff --git a/p2p/source/transport.cpp b/lib-protocol/source/transport.cpp
similarity index 100%
rename from p2p/source/transport.cpp
rename to lib-protocol/source/transport.cpp
diff --git a/p2p/source/transport.hpp b/lib-protocol/source/transport.hpp
similarity index 100%
rename from p2p/source/transport.hpp
rename to lib-protocol/source/transport.hpp
diff --git a/p2p/source/trezor.cpp b/lib-protocol/source/trezor.cpp
similarity index 100%
rename from p2p/source/trezor.cpp
rename to lib-protocol/source/trezor.cpp
diff --git a/p2p/source/trezor.hpp b/lib-protocol/source/trezor.hpp
similarity index 100%
rename from p2p/source/trezor.hpp
rename to lib-protocol/source/trezor.hpp
diff --git a/p2p/source/try.hpp b/lib-protocol/source/try.hpp
similarity index 100%
rename from p2p/source/try.hpp
rename to lib-protocol/source/try.hpp
diff --git a/p2p/source/tube.hpp b/lib-protocol/source/tube.hpp
similarity index 100%
rename from p2p/source/tube.hpp
rename to lib-protocol/source/tube.hpp
diff --git a/p2p/source/unique.cpp b/lib-protocol/source/unique.cpp
similarity index 100%
rename from p2p/source/unique.cpp
rename to lib-protocol/source/unique.cpp
diff --git a/p2p/source/unique.hpp b/lib-protocol/source/unique.hpp
similarity index 100%
rename from p2p/source/unique.hpp
rename to lib-protocol/source/unique.hpp
diff --git a/p2p/source/uniswap.cpp b/lib-protocol/source/uniswap.cpp
similarity index 100%
rename from p2p/source/uniswap.cpp
rename to lib-protocol/source/uniswap.cpp
diff --git a/p2p/source/uniswap.hpp b/lib-protocol/source/uniswap.hpp
similarity index 100%
rename from p2p/source/uniswap.hpp
rename to lib-protocol/source/uniswap.hpp
diff --git a/p2p/source/updated.hpp b/lib-protocol/source/updated.hpp
similarity index 100%
rename from p2p/source/updated.hpp
rename to lib-protocol/source/updated.hpp
diff --git a/p2p/source/updater.hpp b/lib-protocol/source/updater.hpp
similarity index 100%
rename from p2p/source/updater.hpp
rename to lib-protocol/source/updater.hpp
diff --git a/p2p/source/valve.cpp b/lib-protocol/source/valve.cpp
similarity index 100%
rename from p2p/source/valve.cpp
rename to lib-protocol/source/valve.cpp
diff --git a/p2p/source/valve.hpp b/lib-protocol/source/valve.hpp
similarity index 100%
rename from p2p/source/valve.hpp
rename to lib-protocol/source/valve.hpp
diff --git a/lib-protocol/spcdns.mk b/lib-protocol/spcdns.mk
new file mode 100644
index 000000000..6ea629731
--- /dev/null
+++ b/lib-protocol/spcdns.mk
@@ -0,0 +1,24 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+source += $(pwd)/SPCDNS/src/codec.c
+source += $(pwd)/SPCDNS/src/mappings.c
+source += $(pwd)/SPCDNS/src/output.c
+cflags += -I$(pwd)/SPCDNS/src
diff --git a/p2p/tap-windows6 b/lib-protocol/tap-windows6
similarity index 100%
rename from p2p/tap-windows6
rename to lib-protocol/tap-windows6
diff --git a/lib-protocol/target.mk b/lib-protocol/target.mk
new file mode 100644
index 000000000..ac5e98cdf
--- /dev/null
+++ b/lib-protocol/target.mk
@@ -0,0 +1,42 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+$(call include,shared/target.mk)
+
+source += $(wildcard $(pwd)/source/*.cpp)
+cflags += -I$(pwd)/source
+cflags += -I$(pwd)/extra
+
+ifeq ($(target),and)
+cflags/$(pwd)/source/lwip.cpp += -Wno-missing-braces
+endif
+
+$(call include,boringtun.mk)
+$(call include,c-ares.mk)
+$(call include,jwt.mk)
+$(call include,krypton/target.mk)
+$(call include,libutp.mk)
+$(call include,lwip.mk)
+$(call include,openvpn3.mk)
+$(call include,pugixml.mk)
+$(call include,ristretto.mk)
+$(call include,spcdns.mk)
+$(call include,trezor.mk)
+$(call include,webrtc/target.mk)
diff --git a/p2p/trezor-common b/lib-protocol/trezor-common
similarity index 100%
rename from p2p/trezor-common
rename to lib-protocol/trezor-common
diff --git a/lib-protocol/trezor.mk b/lib-protocol/trezor.mk
new file mode 100644
index 000000000..59c22a5b7
--- /dev/null
+++ b/lib-protocol/trezor.mk
@@ -0,0 +1,31 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+include $(pwd)/protobuf.mk
+
+$(eval $(call protobuf,,$(pwd)/trezor-common/protob))
+source += $(output)/pb/messages.pb.cc
+header += $(output)/pb/messages.pb.h
+source += $(output)/pb/messages-common.pb.cc
+header += $(output)/pb/messages-common.pb.h
+source += $(output)/pb/messages-ethereum.pb.cc
+header += $(output)/pb/messages-ethereum.pb.h
+source += $(output)/pb/messages-management.pb.cc
+header += $(output)/pb/messages-management.pb.h
diff --git a/p2p/rtc b/lib-protocol/webrtc
similarity index 100%
rename from p2p/rtc
rename to lib-protocol/webrtc
diff --git a/p2p/SHA3IUF b/lib-shared/SHA3IUF
similarity index 100%
rename from p2p/SHA3IUF
rename to lib-shared/SHA3IUF
diff --git a/min-webrtc/abseil-cpp b/lib-shared/abseil-cpp
similarity index 100%
rename from min-webrtc/abseil-cpp
rename to lib-shared/abseil-cpp
diff --git a/lib-shared/abseil.mk b/lib-shared/abseil.mk
new file mode 100644
index 000000000..07146725a
--- /dev/null
+++ b/lib-shared/abseil.mk
@@ -0,0 +1,29 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+source += $(filter-out \
+ %_benchmark.cc \
+ %_test.cc \
+ %_test_common.cc \
+ %_testing.cc \
+ %/absl/hash/internal/print_hash_of.cc \
+,$(foreach sub,base container crc debugging hash numeric profiling types strings synchronization time,$(wildcard $(pwd)/abseil-cpp/absl/$(sub)/*.cc $(pwd)/abseil-cpp/absl/$(sub)/internal/*.cc)) $(wildcard $(pwd)/abseil-cpp/absl/time/internal/cctz/src/*.cc))
+
+cflags += -I$(pwd)/abseil-cpp
diff --git a/p2p/asio.mk b/lib-shared/asio.mk
similarity index 100%
rename from p2p/asio.mk
rename to lib-shared/asio.mk
diff --git a/p2p/bech32 b/lib-shared/bech32
similarity index 100%
rename from p2p/bech32
rename to lib-shared/bech32
diff --git a/p2p/boost b/lib-shared/boost
similarity index 100%
rename from p2p/boost
rename to lib-shared/boost
diff --git a/lib-shared/boringssl b/lib-shared/boringssl
new file mode 120000
index 000000000..8c0dcd6e2
--- /dev/null
+++ b/lib-shared/boringssl
@@ -0,0 +1 @@
+../min-boringssl
\ No newline at end of file
diff --git a/p2p/cppcoro b/lib-shared/cppcoro
similarity index 100%
rename from p2p/cppcoro
rename to lib-shared/cppcoro
diff --git a/p2p/ctre b/lib-shared/ctre
similarity index 100%
rename from p2p/ctre
rename to lib-shared/ctre
diff --git a/p2p/eEVM b/lib-shared/eEVM
similarity index 100%
rename from p2p/eEVM
rename to lib-shared/eEVM
diff --git a/p2p/expected b/lib-shared/expected
similarity index 100%
rename from p2p/expected
rename to lib-shared/expected
diff --git a/p2p/extra/fmt/format_header_only.h b/lib-shared/extra/fmt/format_header_only.h
similarity index 100%
rename from p2p/extra/fmt/format_header_only.h
rename to lib-shared/extra/fmt/format_header_only.h
diff --git a/p2p/extra/libsecp256k1-config.h b/lib-shared/extra/libsecp256k1-config.h
similarity index 100%
rename from p2p/extra/libsecp256k1-config.h
rename to lib-shared/extra/libsecp256k1-config.h
diff --git a/p2p/extra/third_party/jsoncpp b/lib-shared/extra/third_party/jsoncpp
similarity index 100%
rename from p2p/extra/third_party/jsoncpp
rename to lib-shared/extra/third_party/jsoncpp
diff --git a/p2p/fmt b/lib-shared/fmt
similarity index 100%
rename from p2p/fmt
rename to lib-shared/fmt
diff --git a/lib-shared/intx b/lib-shared/intx
new file mode 160000
index 000000000..e0732242e
--- /dev/null
+++ b/lib-shared/intx
@@ -0,0 +1 @@
+Subproject commit e0732242e36b3bb08cc8cc23445b2bee7c28b9d0
diff --git a/p2p/jsoncpp b/lib-shared/jsoncpp
similarity index 100%
rename from p2p/jsoncpp
rename to lib-shared/jsoncpp
diff --git a/min-webrtc/ssl b/lib-shared/openssl
similarity index 100%
rename from min-webrtc/ssl
rename to lib-shared/openssl
diff --git a/p2p/secp256k1 b/lib-shared/secp256k1
similarity index 100%
rename from p2p/secp256k1
rename to lib-shared/secp256k1
diff --git a/lib-shared/secp256k1.mk b/lib-shared/secp256k1.mk
new file mode 100644
index 000000000..fa8984c86
--- /dev/null
+++ b/lib-shared/secp256k1.mk
@@ -0,0 +1,36 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+pwd/secp256k1 := $(pwd)/secp256k1
+source += $(pwd/secp256k1)/src/secp256k1.c
+source += $(pwd/secp256k1)/src/precomputed_ecmult.c
+source += $(pwd/secp256k1)/src/precomputed_ecmult_gen.c
+cflags += -I$(pwd/secp256k1)/include
+
+cflags/$(pwd/secp256k1)/ += -I$(pwd/secp256k1)
+cflags/$(pwd/secp256k1)/ += -I$(pwd/secp256k1)/src
+cflags/$(pwd/secp256k1)/ += -Wno-unused-function
+
+cflags += -DSECP256K1_STATIC
+
+cflags += -DENABLE_MODULE_RECOVERY
+cflags += -DENABLE_MODULE_ECDH
+cflags += -DECMULT_WINDOW_SIZE=15
+cflags += -DECMULT_GEN_PREC_BITS=4
diff --git a/p2p/source/address.cpp b/lib-shared/source/address.cpp
similarity index 100%
rename from p2p/source/address.cpp
rename to lib-shared/source/address.cpp
diff --git a/p2p/source/address.hpp b/lib-shared/source/address.hpp
similarity index 100%
rename from p2p/source/address.hpp
rename to lib-shared/source/address.hpp
diff --git a/p2p/source/asio.hpp b/lib-shared/source/asio.hpp
similarity index 100%
rename from p2p/source/asio.hpp
rename to lib-shared/source/asio.hpp
diff --git a/p2p/source/base58.cpp b/lib-shared/source/base58.cpp
similarity index 100%
rename from p2p/source/base58.cpp
rename to lib-shared/source/base58.cpp
diff --git a/p2p/source/base58.hpp b/lib-shared/source/base58.hpp
similarity index 100%
rename from p2p/source/base58.hpp
rename to lib-shared/source/base58.hpp
diff --git a/p2p/source/base64.cpp b/lib-shared/source/base64.cpp
similarity index 100%
rename from p2p/source/base64.cpp
rename to lib-shared/source/base64.cpp
diff --git a/p2p/source/base64.hpp b/lib-shared/source/base64.hpp
similarity index 100%
rename from p2p/source/base64.hpp
rename to lib-shared/source/base64.hpp
diff --git a/p2p/source/buffer.cpp b/lib-shared/source/buffer.cpp
similarity index 100%
rename from p2p/source/buffer.cpp
rename to lib-shared/source/buffer.cpp
diff --git a/p2p/source/buffer.hpp b/lib-shared/source/buffer.hpp
similarity index 100%
rename from p2p/source/buffer.hpp
rename to lib-shared/source/buffer.hpp
diff --git a/p2p/source/category.cpp b/lib-shared/source/category.cpp
similarity index 100%
rename from p2p/source/category.cpp
rename to lib-shared/source/category.cpp
diff --git a/p2p/source/category.hpp b/lib-shared/source/category.hpp
similarity index 100%
rename from p2p/source/category.hpp
rename to lib-shared/source/category.hpp
diff --git a/p2p/source/crypto.cpp b/lib-shared/source/crypto.cpp
similarity index 99%
rename from p2p/source/crypto.cpp
rename to lib-shared/source/crypto.cpp
index c3e6118be..6f8aa1127 100644
--- a/p2p/source/crypto.cpp
+++ b/lib-shared/source/crypto.cpp
@@ -26,6 +26,7 @@
#include
#pragma clang diagnostic pop
+#include
#include
#include
#include
diff --git a/p2p/source/crypto.hpp b/lib-shared/source/crypto.hpp
similarity index 100%
rename from p2p/source/crypto.hpp
rename to lib-shared/source/crypto.hpp
diff --git a/p2p/source/database.hpp b/lib-shared/source/database.hpp
similarity index 100%
rename from p2p/source/database.hpp
rename to lib-shared/source/database.hpp
diff --git a/p2p/source/decimal.hpp b/lib-shared/source/decimal.hpp
similarity index 100%
rename from p2p/source/decimal.hpp
rename to lib-shared/source/decimal.hpp
diff --git a/p2p/source/error.hpp b/lib-shared/source/error.hpp
similarity index 100%
rename from p2p/source/error.hpp
rename to lib-shared/source/error.hpp
diff --git a/p2p/source/fit.hpp b/lib-shared/source/fit.hpp
similarity index 100%
rename from p2p/source/fit.hpp
rename to lib-shared/source/fit.hpp
diff --git a/p2p/source/float.hpp b/lib-shared/source/float.hpp
similarity index 100%
rename from p2p/source/float.hpp
rename to lib-shared/source/float.hpp
diff --git a/p2p/source/integer.hpp b/lib-shared/source/integer.hpp
similarity index 100%
rename from p2p/source/integer.hpp
rename to lib-shared/source/integer.hpp
diff --git a/p2p/source/locked.hpp b/lib-shared/source/locked.hpp
similarity index 100%
rename from p2p/source/locked.hpp
rename to lib-shared/source/locked.hpp
diff --git a/p2p/source/log.cpp b/lib-shared/source/log.cpp
similarity index 100%
rename from p2p/source/log.cpp
rename to lib-shared/source/log.cpp
diff --git a/p2p/source/log.hpp b/lib-shared/source/log.hpp
similarity index 100%
rename from p2p/source/log.hpp
rename to lib-shared/source/log.hpp
diff --git a/p2p/source/main.hpp b/lib-shared/source/main.hpp
similarity index 100%
rename from p2p/source/main.hpp
rename to lib-shared/source/main.hpp
diff --git a/p2p/source/maybe.hpp b/lib-shared/source/maybe.hpp
similarity index 100%
rename from p2p/source/maybe.hpp
rename to lib-shared/source/maybe.hpp
diff --git a/p2p/source/notation.hpp b/lib-shared/source/notation.hpp
similarity index 100%
rename from p2p/source/notation.hpp
rename to lib-shared/source/notation.hpp
diff --git a/p2p/source/scope.hpp b/lib-shared/source/scope.hpp
similarity index 100%
rename from p2p/source/scope.hpp
rename to lib-shared/source/scope.hpp
diff --git a/p2p/source/shared.hpp b/lib-shared/source/shared.hpp
similarity index 100%
rename from p2p/source/shared.hpp
rename to lib-shared/source/shared.hpp
diff --git a/p2p/source/syscall.hpp b/lib-shared/source/syscall.hpp
similarity index 100%
rename from p2p/source/syscall.hpp
rename to lib-shared/source/syscall.hpp
diff --git a/p2p/source/task.cpp b/lib-shared/source/task.cpp
similarity index 100%
rename from p2p/source/task.cpp
rename to lib-shared/source/task.cpp
diff --git a/p2p/source/task.hpp b/lib-shared/source/task.hpp
similarity index 100%
rename from p2p/source/task.hpp
rename to lib-shared/source/task.hpp
diff --git a/p2p/source/time.cpp b/lib-shared/source/time.cpp
similarity index 100%
rename from p2p/source/time.cpp
rename to lib-shared/source/time.cpp
diff --git a/p2p/source/time.hpp b/lib-shared/source/time.hpp
similarity index 100%
rename from p2p/source/time.hpp
rename to lib-shared/source/time.hpp
diff --git a/p2p/source/version.cpp b/lib-shared/source/version.cpp
similarity index 100%
rename from p2p/source/version.cpp
rename to lib-shared/source/version.cpp
diff --git a/p2p/source/version.hpp b/lib-shared/source/version.hpp
similarity index 100%
rename from p2p/source/version.hpp
rename to lib-shared/source/version.hpp
diff --git a/p2p/sqlite b/lib-shared/sqlite
similarity index 100%
rename from p2p/sqlite
rename to lib-shared/sqlite
diff --git a/p2p/sqlite.mk b/lib-shared/sqlite.mk
similarity index 100%
rename from p2p/sqlite.mk
rename to lib-shared/sqlite.mk
diff --git a/p2p/target.mk b/lib-shared/target.mk
similarity index 54%
rename from p2p/target.mk
rename to lib-shared/target.mk
index 9b6089f2e..d61c2b3c7 100644
--- a/p2p/target.mk
+++ b/lib-shared/target.mk
@@ -18,12 +18,18 @@
# }}}
+source += $(wildcard $(pwd)/source/*.cpp)
+cflags += -I$(pwd)/source
+cflags += -I$(pwd)/extra
+
+
+$(call depend,$(pwd)/source/version.cpp.o,@/extra/revision.hpp)
+
+
cflags += -fcoroutines-ts
cflags += -Wno-deprecated-coroutine
cflags += -Wno-deprecated-experimental-coroutine
-cflags += -I$(pwd)/extra
-
cflags += -I$(pwd)/cppcoro/include
@@ -37,12 +43,6 @@ source += $(pwd)/cppcoro/lib/win32.cpp
endif
-source += $(wildcard $(pwd)/source/*.cpp)
-cflags += -I$(pwd)/source
-
-$(call depend,$(pwd)/source/version.cpp.o,@/extra/revision.hpp)
-
-
cflags += -I$(pwd)/expected/include
cflags += -I$(pwd)/url/include
cflags += -I$(pwd)/url/src
@@ -59,38 +59,6 @@ source += $(filter-out \
))
-source += $(wildcard $(pwd)/lwip/src/api/*.c)
-source += $(wildcard $(pwd)/lwip/src/core/*.c)
-source += $(wildcard $(pwd)/lwip/src/core/ipv4/*.c)
-source += $(wildcard $(pwd)/lwip/src/core/ipv6/*.c)
-source += $(pwd)/lwip/src/netif/ethernet.c
-
-ifeq ($(target),win)
-source += $(pwd)/lwip/contrib/ports/win32/sys_arch.c
-cflags/$(pwd)/lwip/contrib/ports/win32/sys_arch.c += -UWIN32_LEAN_AND_MEAN
-cflags += -I$(pwd)/lwip/contrib/ports/win32/include
-else
-source += $(pwd)/lwip/contrib/ports/unix/port/sys_arch.c
-cflags += -I$(pwd)/lwip/contrib/ports/unix/port/include
-endif
-
-cflags += -I$(pwd)/lwip/src/include
-
-cflags += -DLWIP_ERRNO_STDINCLUDE
-cflags += -DLWIP_TCP
-
-ifeq ($(target),lnx)
-cflags += -DTCP_USER_TIMEOUT=18
-endif
-
-
-# Android sockaddr_storage is more indirect
-ifeq ($(target),and)
-cflags/$(pwd)/lwip/ += -Wno-missing-braces
-cflags/$(pwd)/source/lwip.cpp += -Wno-missing-braces
-endif
-
-cflags += -I$(pwd)/BeastHttp/BeastHttp/include
#source += $(pwd)/boost/libs/regex/src/regex_traits_defaults.cpp
source += $(wildcard $(pwd)/boost/libs/filesystem/src/*.cpp)
source += $(wildcard $(pwd)/boost/libs/json/src/*.cpp)
@@ -126,40 +94,6 @@ source += $(pwd)/SHA3IUF/sha3.c
cflags += -I$(pwd)/SHA3IUF
-source += $(filter-out \
- %/libutp_inet_ntop.cpp \
-,$(wildcard $(pwd)/libutp/*.cpp))
-
-cflags += -I$(pwd)/libutp
-cflags/$(pwd)/libutp/ += -Wno-unused-const-variable
-cflags/$(pwd)/libutp/ += -Wno-unused-variable
-
-ifeq ($(target),win)
-source += $(pwd)/libutp/libutp_inet_ntop.cpp
-cflags += -DWIN32
-else
-cflags += -DPOSIX=5
-endif
-
-
-pwd/secp256k1 := $(pwd)/secp256k1
-source += $(pwd/secp256k1)/src/secp256k1.c
-source += $(pwd/secp256k1)/src/precomputed_ecmult.c
-source += $(pwd/secp256k1)/src/precomputed_ecmult_gen.c
-cflags += -I$(pwd/secp256k1)/include
-
-cflags/$(pwd/secp256k1)/ += -I$(pwd/secp256k1)
-cflags/$(pwd/secp256k1)/ += -I$(pwd/secp256k1)/src
-cflags/$(pwd/secp256k1)/ += -Wno-unused-function
-
-cflags += -DSECP256K1_STATIC
-
-cflags += -DENABLE_MODULE_RECOVERY
-cflags += -DENABLE_MODULE_ECDH
-cflags += -DECMULT_WINDOW_SIZE=15
-cflags += -DECMULT_GEN_PREC_BITS=4
-
-
cflags += -I$(pwd)/intx/include
source += $(filter-out %/fmt.cc,$(wildcard $(pwd)/fmt/src/*.cc))
@@ -173,57 +107,18 @@ cflags += -I$(pwd)/eEVM/3rdparty
cflags += -I$(pwd)/eEVM/include
-linked += $(pwd)/challenge-bypass-ristretto-ffi/librust.a
-cflags += -I$(pwd)/challenge-bypass-ristretto-ffi/src
-source += $(pwd)/challenge-bypass-ristretto-ffi/src/wrapper.cpp
-
-
-linked += $(pwd)/boringtun/boringtun/librust.a
-cflags += -I$(pwd)/boringtun/boringtun/src
-features/$(pwd)/boringtun/boringtun += ffi-bindings
-
-
-source += $(pwd)/SPCDNS/src/codec.c
-source += $(pwd)/SPCDNS/src/mappings.c
-source += $(pwd)/SPCDNS/src/output.c
-cflags += -I$(pwd)/SPCDNS/src
-
-
-cflags += -I$(pwd)/cpp-jwt/include
-
-
source += $(pwd)/bech32/ref/c++/bech32.cpp
cflags += -I$(pwd)/bech32/ref/c++
# for (const char& c : hrp) assert(c < 'A' || c > 'Z');
cflags/$(pwd)/bech32/ += -Wno-unused-variable
-
-source += $(pwd)/pugixml/src/pugixml.cpp
-cflags += -I$(pwd)/pugixml/src
-cflags += -DPUGIXML_HAS_LONG_LONG
-
-
-source += $(pwd)/snappy/snappy.cc
-source += $(pwd)/snappy/snappy-sinksource.cc
-cflags += -I$(pwd)/snappy
-
+ifeq ($(crypto),)
+crypto := openssl
+endif
+$(call include,$(crypto)/target.mk)
include $(pwd)/asio.mk
-include $(pwd)/protobuf.mk
-
-$(eval $(call protobuf,,$(pwd)/trezor-common/protob))
-source += $(output)/pb/messages.pb.cc
-header += $(output)/pb/messages.pb.h
-source += $(output)/pb/messages-common.pb.cc
-header += $(output)/pb/messages-common.pb.h
-source += $(output)/pb/messages-ethereum.pb.cc
-header += $(output)/pb/messages-ethereum.pb.h
-source += $(output)/pb/messages-management.pb.cc
-header += $(output)/pb/messages-management.pb.h
-
-$(call include,rtc/target.mk)
-$(call include,krypton/target.mk)
-$(call include,c-ares.mk)
-$(call include,openvpn3.mk)
+$(call include,abseil.mk)
+$(call include,secp256k1.mk)
$(call include,sqlite.mk)
diff --git a/p2p/url b/lib-shared/url
similarity index 100%
rename from p2p/url
rename to lib-shared/url
diff --git a/min-boringssl/boringssl b/min-boringssl/boringssl
new file mode 160000
index 000000000..8ae84b558
--- /dev/null
+++ b/min-boringssl/boringssl
@@ -0,0 +1 @@
+Subproject commit 8ae84b558b3d3af50a323c7e3800998764e77375
diff --git a/min-boringssl/target.mk b/min-boringssl/target.mk
new file mode 100644
index 000000000..7efd06ddc
--- /dev/null
+++ b/min-boringssl/target.mk
@@ -0,0 +1,21 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+cflags += -I$(pwd)/boringssl/src/include
diff --git a/min-icu4c/icu b/min-icu4c/icu
index 39dfee39b..63afc7642 160000
--- a/min-icu4c/icu
+++ b/min-icu4c/icu
@@ -1 +1 @@
-Subproject commit 39dfee39b88a09fcafb33992a5495c4117490644
+Subproject commit 63afc7642582622f4c27925835e9e95828efea76
diff --git a/min-v8/FP16 b/min-v8/FP16
new file mode 160000
index 000000000..581ac1c79
--- /dev/null
+++ b/min-v8/FP16
@@ -0,0 +1 @@
+Subproject commit 581ac1c79dd9d9f6f4e8b2934e7a55c7becf0799
diff --git a/min-v8/base b/min-v8/base
deleted file mode 160000
index 6ca251cee..000000000
--- a/min-v8/base
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit 6ca251cee4cf82f5c33461837005539eeaf684da
diff --git a/min-v8/extra/fp16 b/min-v8/extra/fp16
new file mode 120000
index 000000000..89e586b43
--- /dev/null
+++ b/min-v8/extra/fp16
@@ -0,0 +1 @@
+../FP16/include/fp16
\ No newline at end of file
diff --git a/min-v8/extra/third_party/fp16/src b/min-v8/extra/third_party/fp16/src
new file mode 120000
index 000000000..2a8d35a39
--- /dev/null
+++ b/min-v8/extra/third_party/fp16/src
@@ -0,0 +1 @@
+../../../FP16
\ No newline at end of file
diff --git a/min-v8/target.mk b/min-v8/target.mk
index eef1e4db8..112075341 100644
--- a/min-v8/target.mk
+++ b/min-v8/target.mk
@@ -16,16 +16,19 @@ $(call include,zlb/target.mk)
$(call include,zlb/google.mk)
-v8sub := codegen compiler/backend debug deoptimizer diagnostics execution
+v8sub := codegen compiler/backend debug deoptimizer diagnostics execution maglev regexp
v8all := $(patsubst ./%,$(pwd/v8)/src/%,$(shell cd $(pwd/v8)/src && find . \
$(foreach sub,$(v8sub),-path "./$(sub)" -prune -o) \
+ -path "./builtins/riscv" -prune -o \
-path "./d8" -prune -o \
-path "./heap/base/asm" -prune -o \
-path "./heap/cppgc/asm" -prune -o \
-path "./inspector" -prune -o \
-path "./torque" -prune -o \
-path "./third_party" -prune -o \
+ -path "./tracing" -prune -o \
+ -path "./wasm/fuzzing" -prune -o \
\
! -path "./builtins/generate-bytecodes-builtins-list.cc" \
! -path "./regexp/gen-regexp-special-case.cc" \
@@ -51,6 +54,11 @@ v8all := $(patsubst ./%,$(pwd/v8)/src/%,$(shell cd $(pwd/v8)/src && find . \
v8all += $(pwd/v8)/src/torque/class-debug-reader-generator.cc
v8all += $(foreach sub,$(v8sub),$(wildcard $(pwd)/v8/src/$(sub)/*.cc))
+v8all += $(wildcard $(pwd)/v8/src/regexp/experimental/*.cc)
+v8all += $(pwd)/v8/src/tracing/trace-event.cc
+v8all += $(pwd)/v8/src/tracing/traced-value.cc
+v8all += $(pwd)/v8/src/tracing/tracing-category-observer.cc
+
v8all := $(filter-out %/deoptimizer-cfi-builtins.cc,$(v8all))
v8all := $(filter-out %/deoptimizer-cfi-empty.cc,$(v8all))
v8all := $(filter-out %/system-jit-win.cc,$(v8all))
@@ -115,11 +123,15 @@ vflags += -DENABLE_HANDLE_ZAPPING
vflags += -DENABLE_MINOR_MC
vflags += -DVERIFY_HEAP
-vflags += -DV8_31BIT_SMIS_ON_64BIT_ARCH
+# XXX: this seems to be broken now?
+# look at 51bad4ef1d2b8cebca9ea1dbe3cc30e80dabf2cd
+#vflags += -DV8_31BIT_SMIS_ON_64BIT_ARCH
+
vflags += -DV8_ADVANCED_BIGINT_ALGORITHMS
vflags += -DV8_ATOMIC_MARKING_STATE
vflags += -DV8_ATOMIC_OBJECT_FIELD_WRITES
vflags += -DV8_DEPRECATION_WARNINGS
+vflags += -DV8_ENABLE_CONTINUATION_PRESERVED_EMBEDDER_DATA
vflags += -DV8_ENABLE_LAZY_SOURCE_POSITIONS
vflags += -DV8_ENABLE_REGEXP_INTERPRETER_THREADED_DISPATCH
vflags += -DV8_ENABLE_WEBASSEMBLY
@@ -136,10 +148,15 @@ ifeq ($(bits/$(machine)),64)
#vflags += -DV8_SHORT_BUILTIN_CALLS
endif
-ifeq ($(machine),x86_64)
+vflags += -DV8_ENABLE_SPARKPLUG
vflags += -DV8_ENABLE_MAGLEV
+vflags += -DV8_ENABLE_TURBOFAN
+
+ifeq ($(machine),x86_64)
+vflags += -DV8_ENABLE_WASM_SIMD256_REVEC
else
-v8src := $(filter-out $(pwd/v8)/src/maglev/%,$(v8src))
+v8src := $(filter-out $(pwd/v8)/src/compiler/revectorizer.cc,$(v8src))
+v8src := $(filter-out $(pwd/v8)/src/compiler/turboshaft/wasm-revec-%,$(v8src))
endif
cflags += -DICU_UTIL_DATA_IMPL=ICU_UTIL_DATA_STATIC
@@ -152,6 +169,7 @@ endif
vflags += -I$(pwd/v8)
vflags += -I$(output)/$(pwd/v8)
+vflags += -I$(pwd)/extra
source += $(v8src)
@@ -165,7 +183,7 @@ vflags += -include cstdint
$(output)/$(pwd/v8)/gen-regexp-special-case: $(pwd)/v8/src/regexp/gen-regexp-special-case.cc $(pwd)/fatal.cc $(output)/icu4c/lib/libicuuc.a $(output)/icu4c/lib/libicudata.a
@mkdir -p $(dir $@)
- clang++ -std=c++14 -pthread -o $@ $^ $(vflags) $(icu4c) -ldl -m$(bits/$(machine))
+ clang++ -std=c++17 -pthread -o $@ $^ $(vflags) $(icu4c) -ldl -m$(bits/$(machine)) -static
$(output)/$(pwd/v8)/special-case.cc: $(output)/$(pwd/v8)/gen-regexp-special-case
@mkdir -p $(dir $@)
@@ -178,7 +196,7 @@ source += $(output)/$(pwd/v8)/special-case.cc
$(output)/$(pwd/v8)/generate-bytecodes-builtins-list: $(pwd)/v8/src/builtins/generate-bytecodes-builtins-list.cc $(pwd)/v8/src/interpreter/bytecodes.cc $(pwd)/v8/src/interpreter/bytecode-operands.cc $(pwd)/fatal.cc
@mkdir -p $(dir $@)
- clang++ -std=c++14 -pthread -o $@ $^ $(vflags) -m$(bits/$(machine))
+ clang++ -std=c++17 -pthread -o $@ $^ $(vflags) -m$(bits/$(machine))
$(output)/$(pwd/v8)/builtins-generated/bytecodes-builtins-list.h: $(output)/$(pwd/v8)/generate-bytecodes-builtins-list
@mkdir -p $(dir $@)
@@ -194,15 +212,15 @@ torque := $(patsubst ./%,%,$(sort $(shell cd $(pwd)/v8 && find . -name '*.tq')))
# XXX: this now needs to be per target (due to -m$(bits))
-$(output)/$(pwd/v8)/torque: $(wildcard $(pwd)/v8/src/torque/*.cc) $(pwd)/v8/src/base/functional.cc $(pwd)/fatal.cc
+$(output)/$(pwd/v8)/torque: $(wildcard $(pwd)/v8/src/torque/*.cc) $(pwd)/fatal.cc
@rm -rf $(dir $@)
@mkdir -p $(dir $@)
- clang++ -std=c++14 -pthread -o $@ $^ $(vflags) -m$(bits/$(machine))
+ clang++ -std=c++17 -pthread -o $@ $^ $(vflags) -m$(bits/$(machine))
tqsrc := $(patsubst %.tq,%-tq-csa.cc,$(torque))
-#tqsrc += class-debug-readers.cc
+tqsrc += class-debug-readers.cc
tqsrc += class-verifiers.cc
-#tqsrc += debug-macros.cc
+tqsrc += debug-macros.cc
tqsrc += exported-macros-assembler.cc
tqsrc += $(patsubst %.cc,%.h,$(tqsrc))
tqsrc += $(patsubst %.tq,%-tq.cc,$(torque))
@@ -262,4 +280,6 @@ cflags/$(pwd/v8)/ += -Wno-builtin-assume-aligned-alignment
# XXX: they might have already changed many of these cases
cflags/$(pwd/v8)/ += -Wno-unused-but-set-variable
+cflags += -Wno-invalid-offsetof
+
archive += $(pwd/v8)/
diff --git a/min-v8/trace_event b/min-v8/trace_event
index 35f06510a..521ac34eb 160000
--- a/min-v8/trace_event
+++ b/min-v8/trace_event
@@ -1 +1 @@
-Subproject commit 35f06510a6a088054ba3417b0f9f7ee4a120db55
+Subproject commit 521ac34ebd795939c7e16b37d9d3ddb40e8ed556
diff --git a/min-v8/v8 b/min-v8/v8
index 5974242ae..b3a476aa4 160000
--- a/min-v8/v8
+++ b/min-v8/v8
@@ -1 +1 @@
-Subproject commit 5974242ae2141744091e5c6adcc95c8d9f6cee81
+Subproject commit b3a476aa45ab28fd96e47b299c0c5fa54867a91a
diff --git a/min-webrtc/target.mk b/min-webrtc/target.mk
index 9e04c6aaf..acb9b0073 100644
--- a/min-webrtc/target.mk
+++ b/min-webrtc/target.mk
@@ -153,28 +153,6 @@ webrtc += $(wildcard $(pwd)/webrtc/stats/*.cc)
webrtc += $(wildcard $(pwd)/webrtc/system_wrappers/source/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/base/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/base/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/crc/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/crc/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/debugging/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/debugging/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/numeric/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/numeric/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/profiling/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/profiling/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/types/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/types/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/strings/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/strings/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/synchronization/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/synchronization/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/time/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/time/internal/*.cc)
-webrtc += $(wildcard $(pwd)/abseil-cpp/absl/time/internal/cctz/src/*.cc)
-cflags += -I$(pwd)/abseil-cpp
-
-
pwd/libsrtp := $(pwd)/libsrtp
webrtc += $(wildcard $(pwd/libsrtp)/srtp/*.c)
cflags += -I$(pwd/libsrtp)/include
@@ -284,5 +262,3 @@ cflags/$(pwd/webrtc)/rtc_base/checks.cc += -Wno-unused-result
include $(pwd)/target-$(target).mk
-
-$(call include,ssl/target.mk)
diff --git a/min-wireshark/libgcrypt b/min-wireshark/libgcrypt
index ccfa9f2c1..3f5989014 160000
--- a/min-wireshark/libgcrypt
+++ b/min-wireshark/libgcrypt
@@ -1 +1 @@
-Subproject commit ccfa9f2c1427b40483984198c3df41f8057f69f8
+Subproject commit 3f5989014a1b7c01aced88897d878ce5105d15df
diff --git a/min-wireshark/libgpg-error b/min-wireshark/libgpg-error
index 220a427b4..a5f0e0b2f 160000
--- a/min-wireshark/libgpg-error
+++ b/min-wireshark/libgpg-error
@@ -1 +1 @@
-Subproject commit 220a427b4f997ef6af1b2d4e82ef1dc96e0cd6ff
+Subproject commit a5f0e0b2f7897fc6ef1ab847146e16ef64d1d4a7
diff --git a/min-zlib/target.mk b/min-zlib/target.mk
index 107c1ef3a..950282b10 100644
--- a/min-zlib/target.mk
+++ b/min-zlib/target.mk
@@ -18,4 +18,6 @@ cflags += -I$(pwd)/libz
cflags += -I$(pwd)/extra
cflags += -I$(pwd)
+cflags += -I$(pwd)/googletest/googletest/include
+
export PWD_ZLIB := $(pwd)/libz
diff --git a/modules b/modules
index 1b2859869..32e4a2771 100755
--- a/modules
+++ b/modules
@@ -10,25 +10,24 @@ function tag() {
echo "${head[$1]}"
}
-tag p2p/boost 'boost-[0-9.]*'
+tag lib-shared/boost 'boost-[0-9.]*'
tag min-openssl/openssl 'OpenSSL_[0-9_]*[a-z]'
-tag p2p/sqlite 'version-[0-9.]*'
-
-# to upgrade to a later version of libc++ would require LLVM as submodule
-head[env/libcxx]=origin/release_90
-head[env/libcxxabi]=origin/release_90
+tag lib-shared/sqlite 'version-[0-9.]*'
head[app-shared/flutter]=3.13.9
head[app-shared/engine]=$(cat app-shared/flutter/bin/internal/engine.version)
+head[min-v8/v8]=$(sed -e '/url = "https:\/\/github.com\/v8\/v8\//!d;s/^.*\///;s/\.tar\.gz",$//' srv-worker/workerd/WORKSPACE)
+head[srv-worker/capnproto]=$(sed -e '/url.*"https:\/\/github.com\/capnproto\/capnproto\//!d;s/^.*\///;s/".*//' srv-worker/workerd/WORKSPACE)
+
# cairo and pixman decided to drop autotools, which is really annoying :/
-# intx is stuck due to use of concepts (so need a newer version of libc++)
+# libcxx and libcxxabi are blocked on a new __assertion_handler generator
# libgcrypt is stuck on aarch64 Android due to https://dev.gnupg.org/T7111
# libgpg-error is stuck due to libgcrypt as it breaks the older detection
# url is stuck due to https://forums.developer.apple.com/thread/120977 :/
# (I tried to use a local copy of libcxx on Apple, but crashed on iOS 14)
-head[p2p/url]=7c822cb9873b1422e09be5131f30e9d83d487096
+head[lib-shared/url]=7c822cb9873b1422e09be5131f30e9d83d487096
git submodule foreach -q 'echo $displaypath' | while read -r sub; do (
cd "${sub}"
diff --git a/p2p/intx b/p2p/intx
deleted file mode 160000
index 8296dd711..000000000
--- a/p2p/intx
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit 8296dd711603056cd16412b68da6f9ab26dd59c0
diff --git a/srv-daemon/env b/srv-daemon/env
index 9e1ff3db4..971e97aa3 120000
--- a/srv-daemon/env
+++ b/srv-daemon/env
@@ -1 +1 @@
-p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/srv-daemon/lib b/srv-daemon/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/srv-daemon/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/srv-daemon/makefile b/srv-daemon/makefile
index 63b5d7c11..81cdba2d0 100644
--- a/srv-daemon/makefile
+++ b/srv-daemon/makefile
@@ -53,7 +53,7 @@ source += $(wildcard $(pwd)/source/*.cpp)
cflags += -I$(pwd)/extra
cflags += -I$(pwd)/source
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
cflags += -Iall/vpn-shared/source
ifeq ($(target),lnx)
diff --git a/srv-daemon/p2p b/srv-daemon/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/srv-daemon/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/srv-daemon/source/engine.cpp b/srv-daemon/source/engine.cpp
index a468745e3..80802f02a 100644
--- a/srv-daemon/source/engine.cpp
+++ b/srv-daemon/source/engine.cpp
@@ -60,7 +60,7 @@ int Engine() {
const Fd zygote(memfd_create("zygote", MFD_CLOEXEC));
- const size_t arena(512*megabyte);
+ const size_t arena(768*megabyte);
orc_syscall(ftruncate(zygote, arena));
// NOLINTNEXTLINE(cppcoreguidelines-pro-type-cstyle-cast,performance-no-int-to-ptr)
@@ -306,6 +306,7 @@ int Engine() {
switch (run->exit_reason) {
case KVM_EXIT_INTR:
std::cout << "INTR" << std::endl;
+ dump();
break;
case KVM_EXIT_MMIO: {
@@ -313,16 +314,17 @@ int Engine() {
orc_assert(run->mmio.is_write);
orc_assert(run->mmio.len == sizeof(uintptr_t));
switch (const auto command = *reinterpret_cast(run->mmio.data)) {
- case 0: {
+ case 0: case 1: {
struct kvm_guest_debug debug{};
- debug.control = KVM_GUESTDBG_ENABLE | KVM_GUESTDBG_SINGLESTEP;
+ debug.control = command == 0 ? 0 : KVM_GUESTDBG_ENABLE | KVM_GUESTDBG_SINGLESTEP;
+ debug.control = 0;
orc_syscall(ioctl(cpu, KVM_SET_GUEST_DEBUG, &debug));
} break;
- case 1: {
+ case 2: {
std::cout << "abort()" << std::endl;
return 0;
} break;
- case 2: {
+ case 3: {
std::cout << buffer << std::flush;
} break;
default:
diff --git a/srv-gateway/env b/srv-gateway/env
index 9e1ff3db4..971e97aa3 120000
--- a/srv-gateway/env
+++ b/srv-gateway/env
@@ -1 +1 @@
-p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/srv-gateway/lib b/srv-gateway/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/srv-gateway/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/srv-gateway/makefile b/srv-gateway/makefile
index 1df8b112a..e10a3600a 100644
--- a/srv-gateway/makefile
+++ b/srv-gateway/makefile
@@ -44,7 +44,7 @@ record: $(output)/$(machine)/orchid$(exe)
report: $(output)/$(machine)/orchid$(exe)
perf report --sort=cpu
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
source += $(wildcard source/*.cpp)
diff --git a/srv-gateway/p2p b/srv-gateway/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/srv-gateway/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/srv-kernel/source/main.cpp b/srv-kernel/source/main.cpp
index a53d418a3..f2914b5cc 100644
--- a/srv-kernel/source/main.cpp
+++ b/srv-kernel/source/main.cpp
@@ -29,8 +29,12 @@
#include
#include
+#include
#include
+#include
+#include
+#include
#include
#include
@@ -46,6 +50,8 @@ namespace orc {
__asm__ volatile ("dc cvac, %0" : : "r" (code) : "memory")
#elif defined(__x86_64__) || defined(__i386__)
#define Clear(code)
+#else
+#error
#endif
#if defined(__x86_64__)
@@ -95,7 +101,7 @@ __attribute__((__noreturn__))
extern "C" void abort() {
// NOLINTNEXTLINE(google-build-using-namespace)
using namespace orc;
- *control_ = 1;
+ *control_ = 2;
}
#pragma clang diagnostic pop
@@ -118,6 +124,17 @@ extern "C" size_t strlen(const char *data) {
if (data[size] == '\0')
return size;
}
+
+// this code was stolen directly from the GNU man page
+// if it isn't correct, I'm going to be so upset... ;P
+extern "C" char *strncpy(char *dest, const char *src, size_t n) {
+ size_t i;
+ for (i = 0; i < n && src[i] != '\0'; i++)
+ dest[i] = src[i];
+ for ( ; i < n; i++)
+ dest[i] = '\0';
+ return dest;
+}
// NOLINTEND(readability-inconsistent-declaration-parameter-name)
// }}}
@@ -232,7 +249,7 @@ extern "C" size_t printf(const char *format, ...) {
auto value(vsnprintf(state_.buffer_, kilopage_, format, args));
va_end(args);
Clear(state_.buffer_);
- *control_ = 2;
+ *control_ = 3;
return value;
}
// NOLINTEND(cppcoreguidelines-pro-type-vararg,cert-dcl50-cpp)
@@ -301,12 +318,12 @@ extern "C" long enosys(uintptr_t nr, uintptr_t lr, uintptr_t fp) {
// }}}
// page fault {{{
#if defined(__aarch64__)
-extern "C" uintptr_t efault(uintptr_t sr, uintptr_t lr, uintptr_t fp, uintptr_t x0) {
+extern "C" uintptr_t efault(uintptr_t sr, uintptr_t lr, uintptr_t fp, uintptr_t xN) {
// https://developer.arm.com/documentation/ddi0595/2021-12/AArch64-Registers/ESR-EL1--Exception-Syndrome-Register--EL1-?lang=en#fieldset_0-24_0_10
- printf("efault(0x%lx, 0x%lx, 0x%lx, 0x%lx)\n", sr, lr, fp, x0);
+ printf("efault(0x%lx, 0x%lx, 0x%lx, 0x%lx)\n", sr, lr, fp, xN);
backtrace(lr, reinterpret_cast(fp));
abort();
- return x0;
+ return xN;
}
#endif
// }}}
@@ -358,7 +375,10 @@ template
#error
#endif
- return Scan_(table, base >> pagebits_, code);
+ //*control_ = 0;
+ const auto done(Scan_(table, base >> pagebits_, code));
+ //*control_ = 1;
+ return done;
}
template
@@ -489,26 +509,67 @@ uintptr_t $brk(uintptr_t brk) {
}
// }}}
+bool isU(const void *data) {
+ // XXX: verify null-terminated
+ // (safe as we don't use this)
+ return true;
+}
+
+bool isU(const void *data, size_t size) {
+ return reinterpret_cast(data) >= 0 &&
+ reinterpret_cast(data) + size >= data;
+}
+
+constexpr auto stacklim_(8192ul*1024ul);
+
long $prlimit64(pid_t pid, int resource, const struct rlimit *new_limit, struct rlimit *old_limit) {
orc_assert(pid == 0);
orc_assert(resource == RLIMIT_STACK);
orc_assert(new_limit == nullptr);
+ orc_assert(isU(old_limit, sizeof(*old_limit)));
- old_limit->rlim_cur = 8192ul*1024ul;
+ old_limit->rlim_cur = stacklim_;
old_limit->rlim_max = RLIM64_INFINITY;
return 0;
}
+int $uname(struct utsname *data) {
+ orc_assert(isU(data, sizeof(*data)));
+
+ strncpy(data->sysname, "Linux", sizeof(data->sysname));
+ strncpy(data->nodename, "V8", sizeof(data->nodename));
+ strncpy(data->release, "4.4.0", sizeof(data->release));
+ strncpy(data->version, "", sizeof(data->version));
+ strncpy(data->machine, "x86_64", sizeof(data->machine));
+ strncpy(data->domainname, "example.com", sizeof(data->domainname));
+ return 0;
+}
+
+constexpr pid_t pid_(1);
+pid_t $getpid() { return pid_; }
+pid_t $gettid() { return pid_; }
+
+uid_t $getuid() { return 501; }
+uid_t $geteuid() { return 501; }
+
+gid_t $getgid() { return 501; }
+gid_t $getegid() { return 501; }
+
+/*int*/ long $sched_getaffinity(pid_t pid, size_t size, cpu_set_t *mask) {
+ //printf("sched_getaffinity(%d, %zu)\n", pid, size);
+ orc_assert(pid == 0 || pid == pid_);
+ orc_assert(size == sizeof(*mask));
+ orc_assert(isU(mask, sizeof(*mask)));
+ CPU_ZERO(mask);
+ CPU_SET(0, mask);
+ return size;
+}
+
long $exit_group(int status) {
printf("exit_group(0x%x)\n", status);
abort();
}
-bool isU(const void *data, size_t size) {
- return reinterpret_cast(data) >= 0 &&
- reinterpret_cast(data) + size >= data;
-}
-
#ifdef __x86_64__
long $arch_prctl(int code, unsigned long address) {
switch (code) {
@@ -523,8 +584,49 @@ long $arch_prctl(int code, unsigned long address) {
}
#endif
+/*int*/ long $clock_gettime(clockid_t clk_id, struct timespec *tp) {
+ orc_assert(clk_id == CLOCK_MONOTONIC || clk_id == CLOCK_MONOTONIC_COARSE);
+ orc_assert(isU(tp, sizeof(*tp)));
+
+ // XXX: implement time!!!
+ tp->tv_sec = 1000;
+ tp->tv_nsec = 0;
+ return 0;
+}
+
+#if 0
+#elif defined(__aarch64__)
+ssize_t $readlinkat(int fd, const char *path, char *data, size_t size) {
+ orc_assert(isU(path));
+ orc_assert(isU(data, size));
+ //printf("readlinkat(%d, \"%s\")\n", fd, path);
+ return -ENOENT;
+}
+#elif defined(__x86_64__)
+ssize_t $readlink(const char *path, char *data, size_t size) {
+ orc_assert(isU(path));
+ orc_assert(isU(data, size));
+ //printf("readlink(\"%s\")\n", path);
+ return -ENOENT;
+}
+#else
+#error
+#endif
+
+/*int*/ long $openat(int fd, const char *path, int flags, mode_t mode) {
+ orc_assert(isU(path));
+ //printf("openat(%d, \"%s\", %d, %o)\n", fd, path, flags, mode);
+ return -ENOENT;
+}
+
+size_t $read(int fd, void *data, size_t size) {
+ orc_assert(isU(data, size));
+ printf("read(%d, %p, %zu)\n", fd, data, size);
+ abort();
+}
+
size_t $write(int fd, const void *data, size_t size) {
- printf("write(%d, %p, %zu)\n", fd, data, size);
+ //printf("write(%d, %p, %zu)\n", fd, data, size);
orc_assert(fd == 1 || fd == 2);
orc_assert(isU(data, size));
orc_assert(size <= kilopage_ - 1);
@@ -532,7 +634,17 @@ size_t $write(int fd, const void *data, size_t size) {
// NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-constant-array-index)
state_.buffer_[size] = '\0';
Clear(state_.buffer_);
- *control_ = 2;
+ *control_ = 3;
+ return size;
+}
+
+ssize_t $getrandom(void *data, size_t size, unsigned int flags) {
+ orc_assert(flags == 0);
+ for (size_t i(0); i != size; ++i)
+ // XXX: https://xkcd.com/221/
+ // chosen by fair dice roll.
+ // guaranteed to be random.
+ reinterpret_cast(data)[i] = 4;
return size;
}
@@ -625,16 +737,17 @@ void service() {
push %%r10; push %%r11
cmp %1, %%rax
- jge abort
+ jge .Lenosys
mov %0, %%rcx
- mov (%%rcx, %%rax, 8), %%rax
+ mov (%%rcx, %%rax, 8), %%r11
- cmp $0, %%rax
- je abort
+ cmp $0, %%r11
+ je .Lenosys
mov %%r10, %%rcx
- call *%%rax
+ call *%%r11
+ .Lreturn:
pop %%r11; pop %%r10
pop %%r9; pop %%r8
@@ -645,6 +758,13 @@ void service() {
// XXX: protect interrupts!!
pop %%rsp
sysretq
+
+ .Lenosys:
+ mov %%rax, %%rdi
+ //mrs elr_el1, %%rsi
+ //mov x29, %%rdx
+ call enosys
+ jmp .Lreturn
)" : : "i" (state_.syscalls_), "i" (sizeof(state_.syscalls_) / sizeof(*state_.syscalls_)), "i" (state_.tables_)
#else
#error
@@ -654,27 +774,59 @@ void service() {
// }}}
// executable loader {{{
extern "C" void main() {
+ //*control_ = 1;
+
state_.tables_[0][0] = 0x0;
state_.tables_[0][1] = 0x0;
Clear(state_.tables_[0]);
state_.more_ = reinterpret_cast(&state_ + 1);
+
// XXX: randomize this address
state_.stop_ = 0x555555b2d000;
+ // XXX: guarantee value in range
+ state_.stop_ &= ~MASK(pagebits_);
+
+ #define syscall(name) \
+ state_.syscalls_[__NR_##name] = reinterpret_cast(&$##name)
+
+ syscall(mmap);
+ syscall(madvise);
+ syscall(munmap);
+ syscall(mprotect);
+ syscall(brk);
+
+ syscall(prlimit64);
+ syscall(uname);
+
+ syscall(getpid); syscall(gettid);
+ syscall(getuid); syscall(geteuid);
+ syscall(getgid); syscall(getegid);
+
+ syscall(sched_getaffinity);
- state_.syscalls_[__NR_mmap] = reinterpret_cast(&$mmap);
- state_.syscalls_[__NR_madvise] = reinterpret_cast(&$madvise);
- state_.syscalls_[__NR_munmap] = reinterpret_cast(&$munmap);
- state_.syscalls_[__NR_mprotect] = reinterpret_cast(&$mprotect);
- state_.syscalls_[__NR_brk] = reinterpret_cast(&$brk);
+ syscall(exit_group);
- state_.syscalls_[__NR_prlimit64] = reinterpret_cast(&$prlimit64);
- state_.syscalls_[__NR_exit_group] = reinterpret_cast(&$exit_group);
#if defined(__x86_64__)
- state_.syscalls_[__NR_arch_prctl] = reinterpret_cast(&$arch_prctl);
+ syscall(arch_prctl);
#endif
- state_.syscalls_[__NR_write] = reinterpret_cast(&$write);
+ syscall(clock_gettime);
+
+#if 0
+#elif defined(__aarch64__)
+ syscall(readlinkat);
+#elif defined(__x86_64__)
+ syscall(readlink);
+#else
+#endif
+
+ syscall(openat);
+
+ syscall(read);
+ syscall(write);
+
+ syscall(getrandom);
const auto null(orc_syscall($mmap(0, megapage_, 0, MAP_PRIVATE | MAP_ANONYMOUS | MAP_FIXED, -1, 0)));
orc_assert(null == 0);
@@ -719,8 +871,10 @@ extern "C" void main() {
entry = rest | PofK(copy) | 0x1;
});
+ //*control_ = 0;
memset(reinterpret_cast(start), 0, offset);
memset(reinterpret_cast(start + offset + command.p_filesz), 0, size - offset - command.p_filesz);
+ //*control_ = 1;
}
Scan(start + size, total - size, [&](uintptr_t page, uintptr_t &entry) {
@@ -729,27 +883,27 @@ extern "C" void main() {
});
}
- struct rlimit limit{};
- $prlimit64(0, RLIMIT_STACK, nullptr, &limit);
- const size_t size(limit.rlim_cur);
-
- auto stack(reinterpret_cast(reinterpret_cast(orc_syscall($mmap(0, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0))) + size));
+ auto stack(reinterpret_cast(reinterpret_cast(orc_syscall($mmap(0, stacklim_, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0))) + stacklim_));
// NOLINTBEGIN(clang-analyzer-core.NullDereference)
// https://articles.manugarg.com/aboutelfauxiliaryvectors
// https://lwn.net/Articles/519085/
+ // marker
+
// random
- // XXX: https://xkcd.com/221/
- // chosen by fair dice roll.
- // guaranteed to be random.
- *--stack = 0x4444444444444444;
- *--stack = 0x4444444444444444;
- const auto random(stack);
+ const auto random(stack -= 2);
+ orc_syscall($getrandom(random, sizeof(*stack) * 2, 0));
+
+ // padding
// auxv
*--stack = AT_NULL;
+
+ *--stack = kilopage_;
+ *--stack = AT_PAGESZ;
+
*--stack = reinterpret_cast(random);
*--stack = AT_RANDOM;
@@ -795,10 +949,16 @@ extern "C" void main() {
.balign 0x800
vectors:
.space 0x200
- .space 0x200
+
b %3
.balign 0x80
- .space 0x380
+ .space 0x180
+
+ b %3
+ .balign 0x80
+ .space 0x180
+
+ .space 0x200
)" : : "r" (stack), "r" (entry), "i" (atexit), "i" (service), "r" (state_.tables_) : "x0"
#elif defined(__x86_64__)
// sysdeps/x86_64/start.S
diff --git a/srv-worker/capnproto b/srv-worker/capnproto
index 08d082653..24371b79b 160000
--- a/srv-worker/capnproto
+++ b/srv-worker/capnproto
@@ -1 +1 @@
-Subproject commit 08d0826533c72ae9d9182cb2dd33d5ccd20e4e46
+Subproject commit 24371b79b467686641aa64afa340bdad03b05830
diff --git a/srv-worker/capnproto.mk b/srv-worker/capnproto.mk
new file mode 100644
index 000000000..22e4724c7
--- /dev/null
+++ b/srv-worker/capnproto.mk
@@ -0,0 +1,43 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+$(output)/capnproto/Makefile: $(pwd)/capnproto/c++/configure
+ mkdir -p $(dir $@)
+ cd $(dir $@) && $(CURDIR)/$< --enable-static \
+ CC='clang -m$(bits/$(machine))' CXX='clang++ -m$(bits/$(machine))'
+
+export PATH := $(CURDIR)/$(output)/capnproto:$(PATH)
+
+capnp := $(output)/capnproto/capnp
+
+$(capnp): $(output)/capnproto/Makefile
+ $(MAKE) -C $(dir $<)
+
+$(output)/capnp/%.capnp.h: %.capnp $(capnp)
+ @mkdir -p $(output)/capnp
+ capnp compile \
+ -I$(pwd)/capnproto/c++/src \
+ -I$(pwd)/workerd/src \
+ $< -oc++:$(output)/capnp
+
+cflags += -I$(pwd)/capnproto/c++/src
+cflags += -I$(output)/capnp/capnproto/c++/src
+
+source += $(shell find $(pwd)/capnproto/c++/src/kj -name '*.c++' -not -name '*test.c++')
diff --git a/srv-worker/jemalloc.mk b/srv-worker/jemalloc.mk
new file mode 100644
index 000000000..82f48290c
--- /dev/null
+++ b/srv-worker/jemalloc.mk
@@ -0,0 +1,34 @@
+# Orchid - WebRTC P2P VPN Market (on Ethereum)
+# Copyright (C) 2017-2020 The Orchid Authors
+
+# GNU Affero General Public License, Version 3 {{{ */
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+# }}}
+
+
+w_jemalloc += --disable-cxx
+w_jemalloc += --disable-libdl
+w_jemalloc += --disable-stats
+w_jemalloc += --disable-syscall
+w_jemalloc += --enable-debug
+w_jemalloc += --with-malloc-conf=tcache:false
+
+w_jemalloc += ac_cv_func_sbrk=no
+w_jemalloc += force_tls=0
+
+jemalloc := lib/libjemalloc_pic.a
+$(output)/%/$(pwd)/jemalloc/$(jemalloc): $(output)/%/$(pwd)/jemalloc/Makefile
+ $(MAKE) -C $(dir $<) $(jemalloc)
+linked += $(pwd)/jemalloc/$(jemalloc)
diff --git a/srv-worker/lib b/srv-worker/lib
new file mode 120000
index 000000000..005659d22
--- /dev/null
+++ b/srv-worker/lib
@@ -0,0 +1 @@
+../lib-shared
\ No newline at end of file
diff --git a/srv-worker/libc.cpp b/srv-worker/libc.cpp
index 57056343c..18690ba98 100644
--- a/srv-worker/libc.cpp
+++ b/srv-worker/libc.cpp
@@ -20,353 +20,6 @@
/* }}} */
-#undef _FORTIFY_SOURCE
-
-#include
-#include
-
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include // XXX
-#include
-
-#include
-#include
-#include
-#include
-#include
-
-#include "scope.hpp"
-
-#define orc_trace() do { \
- std::cout << "_trace()@" << __FILE__ << ":" << __LINE__ << std::endl; \
-} while (false)
-
-#define __(x) extern "C" __typeof(x) __##x __attribute__((alias(#x)));
-
-// NOLINTBEGIN(readability-inconsistent-declaration-parameter-name)
-
-// *dir -> error {{{
-DIR *opendir(const char *name) {
- return nullptr; } __(opendir)
-int closedir(DIR *dirp) {
- errno = EINVAL; return -1; } __(closedir)
-struct dirent *readdir(DIR *dirp) {
- return nullptr; } __(readdir)
-// }}}
-// FILE {{{
-int open(const char *pathname, int flags, ...) {
- errno = ENOENT; return -1; } __(open)
-int close(int fd) {
- errno = EBADF; return -1; } __(close)
-ssize_t read(int fd, void *buf, size_t count) {
- errno = EBADF; return -1; } __(read)
-
-#if 0
-ssize_t write(int fd, const void *buf, size_t count) {
- __builtin_debugtrap();
- errno = EBADF; return -1;
-} __(write)
-#endif
-
-off_t lseek(int fd, off_t offset, int whence) {
- errno = EBADF; return -1; } __(lseek)
-off64_t lseek64(int fd, off64_t offset, int whence) {
- errno = EBADF; return -1; } __(lseek64)
-
-FILE *fopen(const char *pathname, const char *mode) {
- errno = ENOENT; return nullptr; }
-FILE *fdopen(int fd, const char *mode) {
- errno = ENOENT; return nullptr; }
-int fclose(FILE *stream) {
- errno = EBADF; return EOF; }
-
-FILE *stdin = reinterpret_cast(1);
-FILE *stdout = reinterpret_cast(2);
-FILE *stderr = reinterpret_cast(3);
-
-int fileno(FILE *stream) {
- if (false);
- else if (stream == stdout)
- return 1;
- else if (stream == stderr)
- return 2;
- else abort();
-} __(fileno)
-
-size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream) {
- const auto total(nmemb * size);
- // for some reason libcxx loves to call fwrite with 0 items during some kind of sync operation
- if (total == 0) return 0;
- // clang (incorrectly) rewrites fprintf() with constant format string to #,1 instead of 1,# :/
- // https://github.com/llvm/llvm-project/blob/main/llvm/lib/Transforms/Utils/SimplifyLibCalls.cpp
- // https://github.com/llvm/llvm-project/blob/main/llvm/test/Transforms/InstCombine/fprintf-1.ll
- // https://github.com/llvm/llvm-project/blob/main/llvm/lib/Transforms/Utils/BuildLibCalls.cpp
- // https://virtuallyfun.com/wordpress/2018/03/01/fread-and-fwrite-demystified-stdio-on-unix-v7/
- // https://www.tuhs.org/cgi-bin/utree.pl?file=V7/usr/src/libc/stdio/rdwr.c
- // https://retrocomputing.stackexchange.com/questions/16633/is-this-the-reason-why-fread-fwrite-has-2-size-t-arguments
- // https://sourceware.org/git/?p=glibc.git;a=blob;f=libio/iofwrite.c;h=640b0a7c2be46e05b7c4750ce6f0330ad6e39d3d;hb=HEAD
- const auto writ(write(fileno(stream), ptr, total));
- return writ >= 0 ? writ / size : 0;
-}
-
-int fputc(int c, FILE *stream) {
- return fwrite(&c, 1, 1, stream) == 1 ? c : EOF;
-}
-
-int fputs(const char *s, FILE *stream) {
- return fwrite(s, 1, strlen(s), stream);
-}
-
-int fflush(FILE *stream) {
- return 0;
-}
-
-char *fgets(char *s, int size, FILE *stream) { abort(); }
-size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream) { abort(); }
-size_t fread_unlocked(void *ptr, size_t size, size_t nmemb, FILE *stream) { abort(); } __(fread_unlocked)
-int fscanf(FILE *stream, const char *format, ...) { abort(); }
-int fseek(FILE *stream, long offset, int whence) { abort(); }
-int fseeko(FILE *stream, off_t offset, int whence) { abort(); }
-long ftell(FILE *stream) { abort(); }
-off_t ftello(FILE *stream) { abort(); } __(ftello)
-int getc(FILE *stream) { abort(); }
-void rewind(FILE *stream) { abort(); }
-int setvbuf(FILE *stream, char *buf, int mode, size_t size) { abort(); }
-FILE *tmpfile(void) { abort(); }
-int ungetc(int c, FILE *stream) { abort(); }
-// }}}
-// get* -> stub {{{
-char *secure_getenv(const char *name) { return nullptr; }
-char *getenv(const char *name) { return secure_getenv(name); }
-
-static const pid_t pid_(1);
-pid_t getpid() { return pid_; } __(getpid)
-
-static const gid_t gid_(500);
-gid_t getgid() { return gid_; } __(getgid)
-gid_t getegid() { return gid_; } __(getegid)
-
-static const uid_t uid_(500);
-uid_t getuid() { return uid_; } __(getuid)
-uid_t geteuid() { return uid_; } __(geteuid)
-// }}}
-// *link -> error {{{
-ssize_t readlink(const char *pathname, char *buf, size_t bufsiz) {
- errno = ENOENT; return -1; }
-int unlink(const char *pathname) {
- errno = ENOENT; return -1; }
-// }}}
-// pthread_* {{{
-int pthread_atfork(void (*) (), void (*) (), void (*) ()) { return 0; }
-int pthread_attr_destroy(pthread_attr_t *) { return 0; }
-int pthread_attr_init(pthread_attr_t *) { return 0; }
-int pthread_attr_setstacksize(pthread_attr_t *, size_t) { return 0; }
-int pthread_cond_broadcast(pthread_cond_t *) { return 0; }
-int pthread_cond_destroy(pthread_cond_t *) { return 0; }
-int pthread_cond_init(pthread_cond_t *, const pthread_condattr_t *) { return 0; }
-int pthread_cond_signal(pthread_cond_t *) { return 0; }
-int pthread_cond_timedwait(pthread_cond_t *, pthread_mutex_t *, const struct timespec *) { abort(); } // XXX
-int pthread_cond_wait(pthread_cond_t *, pthread_mutex_t *) { abort(); }
-int pthread_condattr_destroy(pthread_condattr_t *) { return 0; }
-int pthread_condattr_init(pthread_condattr_t *) { return 0; }
-int pthread_condattr_setclock(pthread_condattr_t *, clockid_t) { return 0; }
-int pthread_create(pthread_t *, const pthread_attr_t *, void *(*)(void *), void *) { abort(); }
-int pthread_equal(pthread_t, pthread_t) { return 1; }
-int pthread_join(pthread_t, void **) { abort(); }
-int pthread_kill(pthread_t, int) { abort(); }
-int pthread_mutex_destroy(pthread_mutex_t *) { return 0; }
-int pthread_mutex_init(pthread_mutex_t *, const pthread_mutexattr_t *) { return 0; }
-int pthread_mutex_lock(pthread_mutex_t *) { return 0; }
-int pthread_mutex_trylock(pthread_mutex_t *) { return 0; } __(pthread_mutex_lock)
-int pthread_mutex_unlock(pthread_mutex_t *) { return 0; } __(pthread_mutex_unlock)
-int pthread_mutexattr_destroy(pthread_mutexattr_t *) { return 0; }
-int pthread_mutexattr_init(pthread_mutexattr_t *) { return 0; }
-int pthread_mutexattr_settype(pthread_mutexattr_t *, int) { return 0; }
-int pthread_rwlock_destroy(pthread_rwlock_t *) { return 0; }
-int pthread_rwlock_init(pthread_rwlock_t *, const pthread_rwlockattr_t *) { return 0; } __(pthread_rwlock_init)
-int pthread_rwlock_rdlock(pthread_rwlock_t *) { return 0; } __(pthread_rwlock_rdlock)
-int pthread_rwlock_tryrdlock(pthread_rwlock_t *) { return 0; }
-int pthread_rwlock_unlock(pthread_rwlock_t *) { return 0; } __(pthread_rwlock_unlock)
-int pthread_rwlock_wrlock(pthread_rwlock_t *) { return 0; } __(pthread_rwlock_wrlock)
-pthread_t pthread_self() { return 0; }
-void pthread_testcancel() {} __(pthread_testcancel)
-int pthread_setname_np(pthread_t, const char *) { return 0; }
-// }}}
-// pthread_once {{{
-int pthread_once (pthread_once_t *control, void (*routine)()) {
- if (*control == PTHREAD_ONCE_INIT) {
- *control = ~PTHREAD_ONCE_INIT;
- (*routine)();
- }
- return 0;
-} __(pthread_once)
-// }}}
-// pthread_*specific {{{
-static unsigned specific_(0);
-static const void *specifics_[64];
-
-int pthread_key_create(pthread_key_t *key, void (*)(void *)) {
- if (specific_ == sizeof(specifics_) / sizeof(specifics_[0])) abort();
- *key = specific_++;
- return 0;
-} __(pthread_key_create)
-
-int pthread_key_delete(pthread_key_t key) {
- return 0;
-}
-
-void *pthread_getspecific(pthread_key_t key) {
- return const_cast(specifics_[key]);
-}
-
-int pthread_setspecific(pthread_key_t key, const void *value) {
- specifics_[key] = value;
- return 0;
-}
-// }}}
-// sched* -> return {{{
-int __sched_cpucount(size_t, const cpu_set_t *) { return 1; }
-int sched_getcpu() { return 0; }
-int sched_setaffinity(pid_t, size_t, const cpu_set_t *) { return 0; }
-int sched_getaffinity(pid_t, size_t, cpu_set_t *) { return 0; }
-// }}}
-// sem_* {{{
-int sem_destroy(sem_t *) { return 0; }
-int sem_init(sem_t *, int, unsigned int) { return 0; }
-// XXX: implement EOVERFLOW
-int sem_post(sem_t *) { return 0; }
-int sem_wait(sem_t *) { abort(); }
-// }}}
-// *sig* -> abort {{{
-int pthread_sigmask(int, const sigset_t *, sigset_t *) { abort(); }
-int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact) { abort(); } __(sigaction)
-int sigemptyset(sigset_t *) { abort(); }
-int sigfillset(sigset_t *) { abort(); }
-sighandler_t signal(int signum, sighandler_t handler) { abort(); }
-// }}}
-// *stat -> error {{{
-int stat(const char *pathname, struct stat *statbuf) {
- errno = ENOENT; return -1; }
-int stat64(const char *pathname, struct stat64 *statbuf) {
- errno = ENOENT; return -1; } __(stat64)
-int fstat(int fd, struct stat *statbuf) {
- errno = EBADF; return -1; }
-int fstat64(int fd, struct stat64 *statbuf) {
- errno = EBADF; return -1; } __(fstat64)
-int lstat(const char *pathname, struct stat *statbuf) {
- errno = ENOENT; return -1; } __(lstat)
-int lstat64(const char *pathname, struct stat64 *statbuf) {
- errno = ENOENT; return -1; } __(lstat64)
-// }}}
-// sysconf {{{
-long sysconf(int name) {
- switch (name) {
- case _SC_NPROCESSORS_CONF:
- return 1;
- case _SC_NPROCESSORS_ONLN:
- return 1;
- case _SC_PAGESIZE:
- return 0x1000;
- case _SC_PHYS_PAGES:
- return 0x1000; // XXX
- case _SC_THREAD_STACK_MIN:
- return 0x10000; // XXX
- default:
- abort();
- errno = EINVAL;
- return -1;
- }
-}
-
-extern "C" __typeof(sysconf) __sysconf __attribute__((alias("sysconf")));
-// }}}
-// *time* {{{
-int clock_gettime(clockid_t clk_id, struct timespec *tp) {
- switch (clk_id) {
- case CLOCK_MONOTONIC:
- case CLOCK_MONOTONIC_COARSE:
- break;
- default: errno = EINVAL; return -1;
- }
-
- if (tp == nullptr) { errno = EFAULT; return -1; }
- // XXX: implement time!!!
- tp->tv_sec = 1000;
- tp->tv_nsec = 0;
- return 0;
-}
-
-int gettimeofday(struct timeval *tv, void *tz) {
- struct timespec tp;
- if (clock_gettime(CLOCK_MONOTONIC, &tp) == -1) return -1;
- if (tz != nullptr) abort();
- tv->tv_sec = tp.tv_sec;
- tv->tv_usec = tp.tv_nsec / 1000;
- return 0;
-}
-
-time_t time(time_t *tloc) {
- struct timespec tp;
- if (clock_gettime(CLOCK_MONOTONIC, &tp) == -1) return -1;
- if (tloc != nullptr) *tloc = tp.tv_sec;
- return tp.tv_sec;
-}
-// }}}
-
-extern "C" const char *_dl_get_origin () { return "/_"; }
-
+// XXX: consider implementing kernel-side
extern "C" void __tls_pre_init_tp() {}
extern "C" void __tls_init_tp() {}
-
-int prctl(int option, ...) { abort(); }
-
-long syscall(long number, ...) {
- switch (number) {
- case SYS_gettid:
- return pid_;
- default: abort();
- }
-}
-
-char *getcwd(char *buf, size_t size) {
- if (size < 2) { errno = ERANGE; return nullptr; }
- buf[0] = '/'; buf[1] = '\0'; return buf;
-} __(getcwd)
-
-
-int uname(struct utsname *buf) {
- snprintf(buf->sysname, sizeof(buf->sysname) - 1, "Linux");
- snprintf(buf->nodename, sizeof(buf->nodename) - 1, "V8");
- snprintf(buf->release, sizeof(buf->release) - 1, "4.4.0");
- snprintf(buf->version, sizeof(buf->version) - 1, "");
- snprintf(buf->machine, sizeof(buf->machine) - 1, "x86_64");
- snprintf(buf->domainname, sizeof(buf->domainname) - 1, "example.com");
- return 0;
-} __(uname)
-
-
-int raise(int sig) { abort(); }
-
-int kill(pid_t pid, int sig) {
- if (pid != pid_) abort();
- return raise(sig);
-}
-
-
-int sched_yield(void) { abort(); } __(sched_yield)
-
-int usleep(useconds_t usec) {
- if (usec != 0) abort();
- return 0;
-}
-
-// NOLINTEND(readability-inconsistent-declaration-parameter-name)
diff --git a/srv-worker/makefile b/srv-worker/makefile
index 31d639dfa..fb56f14fc 100644
--- a/srv-worker/makefile
+++ b/srv-worker/makefile
@@ -21,6 +21,7 @@
args :=
distro := ubuntu jammy 11
+crypto := boringssl
include env/target.mk
binary := $(output)/$(machine)/worker$(exe)
@@ -30,637 +31,56 @@ all: $(binary)
.PHONY: debug
debug: $(binary)
- lldb-14 -o 'b malloc_error_break' -o 'run $(args)' $<
+ lldb -o 'b malloc_error_break' -o 'run $(args)' $<
.PHONY: test
test: $(binary)
- strace -ff -e 'trace=!write' $< 2>&1 #| sed -e '0,/^execve(/d;/^orc_trace(/d;/^+++ /d;s/\(mmap([^,]*\),[^,]*/\1/;s/mmap(0x\([0-9a-f]*\),\(.*\)= 0x\1/mmap(0X,\2= 0X/;s/\(mmap(NULL,.*\)= 0x[0-9a-f]*/\1= 0X/;s///;s/^\(madvise\|mprotect\)(0x[0-9a-z]*, [0-9]*, /\1(/;s/^munmap(0x[0-9a-f]*, [0-9]*) */munmap() /' | sort | uniq -c | sort -nr
+ strace -ff -e 'trace=!write' $< 2>&1 | ./syscalls.sh
source += $(wildcard $(pwd)/source/*.cpp)
source += $(pwd)/libc.cpp
cflags += -I$(pwd)/source
-lflags += -nodefaultlibs
lflags += -static-pie
cflags += -ftls-model=local-exec
-lflags += -lm
lflags := $(filter-out -pthread,$(lflags))
-lflags += -lstdc++
-lflags += -lgcc
-lflags += -lgcc_eh
-
-
-# linked += {{{
-ifeq ($(machine),x86_64)
-linked += libc/cacheinfo.o
-linked += libc/dl-cet.o
-linked += libc/varshift.o
-
-linked += libc/float1282mpn.o
-linked += libc/mpn2float128.o
-linked += libc/strtof128.o
-linked += libc/strtof128_l.o
-linked += libc/strtof128_nan.o
-
-linked += libc/memchr-avx2.o
-linked += libc/memchr-avx2-rtm.o
-linked += libc/memchr-evex.o
-linked += libc/memchr-evex-rtm.o
-linked += libc/memchr-sse2.o
-linked += libc/memcmp-avx2-movbe.o
-linked += libc/memcmp-avx2-movbe-rtm.o
-linked += libc/memcmp-evex-movbe.o
-linked += libc/memcmp-sse2.o
-linked += libc/memcmp-sse4.o
-linked += libc/memcmp-ssse3.o
-linked += libc/memcpy-ssse3.o
-linked += libc/memcpy-ssse3-back.o
-linked += libc/memcpy_chk-nonshared.o
-linked += libc/memmove-avx-unaligned-erms.o
-linked += libc/memmove-avx-unaligned-erms-rtm.o
-linked += libc/memmove-avx512-no-vzeroupper.o
-linked += libc/memmove-avx512-unaligned-erms.o
-linked += libc/memmove-evex-unaligned-erms.o
-linked += libc/memmove-sse2-unaligned-erms.o
-linked += libc/memmove-ssse3.o
-linked += libc/memmove-ssse3-back.o
-linked += libc/memmove_chk-nonshared.o
-linked += libc/memset-avx2-unaligned-erms.o
-linked += libc/memset-avx2-unaligned-erms-rtm.o
-linked += libc/memset-avx512-no-vzeroupper.o
-linked += libc/memset-avx512-unaligned-erms.o
-linked += libc/memset-evex-unaligned-erms.o
-linked += libc/memset-sse2-unaligned-erms.o
-linked += libc/rawmemchr-avx2.o
-linked += libc/rawmemchr-avx2-rtm.o
-linked += libc/rawmemchr-evex.o
-linked += libc/rawmemchr-evex-rtm.o
-linked += libc/rawmemchr-sse2.o
-linked += libc/stpcpy-avx2.o
-linked += libc/stpcpy-avx2-rtm.o
-linked += libc/stpcpy-evex.o
-linked += libc/stpcpy-sse2.o
-linked += libc/stpcpy-sse2-unaligned.o
-linked += libc/stpcpy-ssse3.o
-linked += libc/strcasecmp_l-avx.o
-linked += libc/strcasecmp_l-nonascii.o
-linked += libc/strcasecmp_l-sse2.o
-linked += libc/strcasecmp_l-sse4_2.o
-linked += libc/strcasecmp_l-ssse3.o
-linked += libc/strcat-avx2.o
-linked += libc/strcat-avx2-rtm.o
-linked += libc/strcat-evex.o
-linked += libc/strcat-sse2.o
-linked += libc/strcat-sse2-unaligned.o
-linked += libc/strcat-ssse3.o
-linked += libc/strchr-avx2.o
-linked += libc/strchr-avx2-rtm.o
-linked += libc/strchr-evex.o
-linked += libc/strchr-sse2-no-bsf.o
-linked += libc/strchr-sse2.o
-linked += libc/strchrnul-avx2.o
-linked += libc/strchrnul-avx2-rtm.o
-linked += libc/strchrnul-evex.o
-linked += libc/strchrnul-sse2.o
-linked += libc/strcmp-avx2.o
-linked += libc/strcmp-avx2-rtm.o
-linked += libc/strcmp-evex.o
-linked += libc/strcmp-sse2.o
-linked += libc/strcmp-sse2-unaligned.o
-linked += libc/strcmp-sse4_2.o
-linked += libc/strcmp-ssse3.o
-linked += libc/strcpy-avx2.o
-linked += libc/strcpy-avx2-rtm.o
-linked += libc/strcpy-evex.o
-linked += libc/strcpy-sse2.o
-linked += libc/strcpy-sse2-unaligned.o
-linked += libc/strcpy-ssse3.o
-linked += libc/strcspn-c.o
-linked += libc/strcspn-sse2.o
-linked += libc/strlen-avx2.o
-linked += libc/strlen-avx2-rtm.o
-linked += libc/strlen-evex.o
-linked += libc/strlen-sse2.o
-linked += libc/strncase_l-avx.o
-linked += libc/strncase_l-nonascii.o
-linked += libc/strncase_l-sse2.o
-linked += libc/strncase_l-sse4_2.o
-linked += libc/strncase_l-ssse3.o
-linked += libc/strncat-avx2.o
-linked += libc/strncat-avx2-rtm.o
-linked += libc/strncat-c.o
-linked += libc/strncat-evex.o
-linked += libc/strncat-sse2-unaligned.o
-linked += libc/strncat-ssse3.o
-linked += libc/strncmp-avx2.o
-linked += libc/strncmp-avx2-rtm.o
-linked += libc/strncmp-evex.o
-linked += libc/strncmp-sse2.o
-linked += libc/strncmp-sse4_2.o
-linked += libc/strncmp-ssse3.o
-linked += libc/strncpy-avx2.o
-linked += libc/strncpy-avx2-rtm.o
-linked += libc/strncpy-c.o
-linked += libc/strncpy-evex.o
-linked += libc/strncpy-sse2-unaligned.o
-linked += libc/strncpy-ssse3.o
-linked += libc/strnlen-avx2.o
-linked += libc/strnlen-avx2-rtm.o
-linked += libc/strnlen-evex.o
-linked += libc/strnlen-sse2.o
-linked += libc/strrchr-avx2.o
-linked += libc/strrchr-avx2-rtm.o
-linked += libc/strrchr-evex.o
-linked += libc/strrchr-sse2.o
-linked += libc/strspn-c.o
-linked += libc/strspn-sse2.o
-linked += libc/strstr-sse2-unaligned.o
-linked += libc/wcschr-avx2.o
-linked += libc/wcschr-avx2-rtm.o
-linked += libc/wcschr-evex.o
-linked += libc/wcschr-sse2.o
-linked += libc/wcslen-avx2.o
-linked += libc/wcslen-avx2-rtm.o
-linked += libc/wcslen-evex.o
-linked += libc/wcslen-sse2.o
-linked += libc/wcslen-sse4_1.o
-linked += libc/wcsnlen-avx2.o
-linked += libc/wcsnlen-avx2-rtm.o
-linked += libc/wcsnlen-c.o
-linked += libc/wcsnlen-evex.o
-linked += libc/wcsnlen-sse4_1.o
-linked += libc/wmemchr-avx2.o
-linked += libc/wmemchr-avx2-rtm.o
-linked += libc/wmemchr-evex.o
-linked += libc/wmemchr-evex-rtm.o
-linked += libc/wmemchr-sse2.o
-linked += libc/wmemcmp-avx2-movbe.o
-linked += libc/wmemcmp-avx2-movbe-rtm.o
-linked += libc/wmemcmp-evex-movbe.o
-linked += libc/wmemcmp-c.o
-linked += libc/wmemcmp-sse4.o
-linked += libc/wmemcmp-ssse3.o
-endif
-
-ifeq ($(machine),arm64)
-linked += libc/dl-bti.o
-linked += libc/getauxval.o
-linked += libc/strchrnul.o
-linked += libc/sysdep.o
-
-linked += libc/memchr_generic.o
-linked += libc/memchr_nosimd.o
-linked += libc/memcpy_a64fx.o
-linked += libc/memcpy_advsimd.o
-linked += libc/memcpy_falkor.o
-linked += libc/memcpy_generic.o
-linked += libc/memcpy_thunderx.o
-linked += libc/memcpy_thunderx2.o
-linked += libc/memcpy_chk.o
-linked += libc/memset_a64fx.o
-linked += libc/memset_emag.o
-linked += libc/memset_falkor.o
-linked += libc/memset_generic.o
-linked += libc/memset_kunpeng.o
-linked += libc/strlen_asimd.o
-linked += libc/strlen_mte.o
-endif
-
-ifeq ($(machine),armhf)
-linked += libc/getauxval.o
-linked += libc/libc-do-syscall.o
-linked += libc/sysdep.o
-
-linked += libc/memchr_neon.o
-linked += libc/memchr_noneon.o
-linked += libc/memcpy_neon.o
-linked += libc/memcpy_vfp.o
-endif
-
-linked += libc/dl-reloc-static-pie.o
-linked += libc/libc-start.o
-
-linked += libc/abort.o
-linked += libc/assert.o
-linked += libc/atexit.o
-linked += libc/backtrace.o
-linked += libc/backtracesyms.o
-linked += libc/cancellation.o
-linked += libc/chk_fail.o
-linked += libc/cxa_atexit.o
-linked += libc/errno.o
-linked += libc/errno-loc.o
-linked += libc/exit.o
-linked += libc/_exit.o
-linked += libc/fortify_fail.o
-linked += libc/libc_fatal.o
-linked += libc/msort.o
-linked += libc/qsort.o
-linked += libc/stack_chk_fail.o
-
-linked += libc/SYS_libc.o
-linked += libc/argz-addsep.o
-linked += libc/argz-create.o
-linked += libc/argz-ctsep.o
-linked += libc/brk.o
-linked += libc/check_fds.o
-linked += libc/ctype.o
-linked += libc/ctype-info.o
-linked += libc/dcgettext.o
-linked += libc/dcigettext.o
-linked += libc/elision-conf.o
-linked += libc/enbl-secure.o
-linked += libc/errlist.o
-linked += libc/explodename.o
-linked += libc/filedoalloc.o
-linked += libc/fileops.o
-linked += libc/finddomain.o
-linked += libc/genops.o
-linked += libc/getdents64.o
-linked += libc/getpagesize.o
-linked += libc/getrlimit64.o
-linked += libc/global-locale.o
-linked += libc/hash-string.o
-linked += libc/init-first.o
-linked += libc/init-misc.o
-linked += libc/iofclose.o
-linked += libc/iofgets_u.o
-linked += libc/iofopen.o
-linked += libc/iofwide.o
-linked += libc/iogetdelim.o
-linked += libc/iogetline.o
-linked += libc/isatty.o
-linked += libc/l10nflist.o
-linked += libc/lc-ctype.o
-linked += libc/libc-cleanup.o
-linked += libc/libc-tls.o
-linked += libc/libc_dlerror_result.o
-linked += libc/libc_early_init.o
-linked += libc/loadarchive.o
-linked += libc/loadmsgcat.o
-linked += libc/localealias.o
-linked += libc/localename.o
-linked += libc/lowlevellock.o
-linked += libc/nptl-stack.o
-linked += libc/nptl_deallocate_tsd.o
-linked += libc/nptl_nthreads.o
-linked += libc/plural-exp.o
-linked += libc/plural.o
-linked += libc/prof-freq.o
-linked += libc/profil.o
-linked += libc/pthread_keys.o
-linked += libc/pthread_mutex_conf.o
-linked += libc/pthread_setcancelstate.o
-linked += libc/pthread_sigmask.o
-linked += libc/rtld_static_init.o
-linked += libc/sbrk.o
-linked += libc/sched_getp.o
-linked += libc/sched_gets.o
-linked += libc/sched_primax.o
-linked += libc/sched_primin.o
-linked += libc/sched_sets.o
-linked += libc/scratch_buffer_set_array_size.o
-linked += libc/setitimer.o
-linked += libc/sigjmp.o
-linked += libc/sigprocmask.o
-linked += libc/single_threaded.o
-linked += libc/stdfiles.o
-linked += libc/_strerror.o
-linked += libc/strops.o
-linked += libc/tcgetattr.o
-linked += libc/tlsdesc.o
-linked += libc/tpp.o
-linked += libc/tsearch.o
-linked += libc/vars.o
-linked += libc/vtables.o
-linked += libc/wfiledoalloc.o
-linked += libc/wfileops.o
-linked += libc/wgenops.o
-
-linked += libc/alloc_buffer_alloc_array.o
-linked += libc/alloc_buffer_create_failure.o
-linked += libc/alt_digit.o
-linked += libc/era.o
-linked += libc/gmtime.o
-linked += libc/lc-time-cleanup.o
-linked += libc/localtime.o
-linked += libc/mktime.o
-linked += libc/offtime.o
-linked += libc/strftime.o
-linked += libc/strftime_l.o
-linked += libc/tzfile.o
-linked += libc/tzset.o
-
-linked += libc/div.o
-linked += libc/s_ldexp.o
-linked += libc/s_scalbn.o
-
-linked += libc/memchr.o
-linked += libc/memcmp.o
-linked += libc/memcpy.o
-linked += libc/memmem.o
-linked += libc/memmove.o
-linked += libc/memmove_chk.o
-linked += libc/mempcpy.o
-linked += libc/memset.o
-linked += libc/rawmemchr.o
-linked += libc/stpcpy.o
-linked += libc/strcasecmp.o
-linked += libc/strcasecmp_l.o
-linked += libc/strcat.o
-linked += libc/strchr.o
-linked += libc/strchrnul.o
-linked += libc/strcmp.o
-linked += libc/strcpy.o
-linked += libc/strcspn.o
-linked += libc/strdup.o
-linked += libc/strlen.o
-linked += libc/strncase_l.o
-linked += libc/strncat.o
-linked += libc/strncmp.o
-linked += libc/strncpy.o
-linked += libc/strndup.o
-linked += libc/strnlen.o
-linked += libc/strrchr.o
-linked += libc/strsep.o
-linked += libc/strspn.o
-linked += libc/strstr.o
-linked += libc/strtok_r.o
-linked += libc/wcrtomb.o
-linked += libc/wcschr.o
-linked += libc/wcschrnul.o
-linked += libc/wcslen.o
-linked += libc/wcsmbsload.o
-linked += libc/wcsnlen.o
-linked += libc/wcsnrtombs.o
-linked += libc/wmemchr.o
-linked += libc/wmemcpy.o
-linked += libc/wmemcpy_chk.o
-linked += libc/wmemmove.o
-linked += libc/wmemmove_chk.o
-linked += libc/wmempcpy.o
-linked += libc/wmemset.o
-
-linked += libc/mbrlen.o
-linked += libc/mbrtowc.o
-linked += libc/mbsnrtowcs.o
-linked += libc/mbsrtowcs.o
-linked += libc/mbsrtowcs_l.o
-linked += libc/mbtowc.o
-
-linked += libc/add_n.o
-linked += libc/addmul_1.o
-linked += libc/atoi.o
-linked += libc/cmp.o
-linked += libc/fpioconst.o
-linked += libc/grouping.o
-linked += libc/_itoa.o
-linked += libc/itoa-digits.o
-linked += libc/itoa-udigits.o
-linked += libc/lshift.o
-linked += libc/mb_cur_max.o
-linked += libc/mpn2dbl.o
-linked += libc/mpn2flt.o
-linked += libc/mpn2ldbl.o
-linked += libc/mul.o
-linked += libc/mul_1.o
-linked += libc/mul_n.o
-linked += libc/rshift.o
-linked += libc/strtod.o
-linked += libc/strtod_l.o
-linked += libc/strtod_nan.o
-linked += libc/strtof.o
-linked += libc/strtof_l.o
-linked += libc/strtof_nan.o
-linked += libc/strtol.o
-linked += libc/strtol_l.o
-linked += libc/strtold.o
-linked += libc/strtold_l.o
-linked += libc/strtold_nan.o
-linked += libc/strtoul.o
-linked += libc/strtoul_l.o
-linked += libc/sub_n.o
-linked += libc/submul_1.o
-linked += libc/tens_in_limb.o
-
-linked += libc/madvise.o
-linked += libc/mmap.o
-linked += libc/mmap64.o
-linked += libc/mprotect.o
-linked += libc/mremap.o
-linked += libc/munmap.o
-
-ifeq (,)
-linked += libc/libc_multiple_threads.o
-linked += libc/write.o
-endif
-
-linked += libc/C-address.o
-linked += libc/C-collate.o
-linked += libc/C-ctype.o
-linked += libc/C-identification.o
-linked += libc/C-measurement.o
-linked += libc/C-messages.o
-linked += libc/C-monetary.o
-linked += libc/C-name.o
-linked += libc/C-numeric.o
-linked += libc/C-paper.o
-linked += libc/C-telephone.o
-linked += libc/C-time.o
-linked += libc/C_name.o
-
-linked += libc/catgets.o
-linked += libc/findlocale.o
-linked += libc/freelocale.o
-linked += libc/loadlocale.o
-linked += libc/newlocale.o
-linked += libc/open_catalog.o
-linked += libc/setlocale.o
-linked += libc/uselocale.o
-linked += libc/xlocale.o
-
-linked += libc/dl-addr.o
-linked += libc/dl-addr-obj.o
-linked += libc/dl-cache.o
-linked += libc/dl-call-libc-early-init.o
-linked += libc/dl-close.o
-linked += libc/dl-debug.o
-linked += libc/dl-debug-symbols.o
-linked += libc/dl-deps.o
-linked += libc/dl-error.o
-linked += libc/dl-exception.o
-linked += libc/dl-execstack.o
-linked += libc/dl-find_object.o
-linked += libc/dl-init.o
-linked += libc/dl-iteratephdr.o
-linked += libc/dl-libc.o
-linked += libc/dl-load.o
-linked += libc/dl-lookup.o
-linked += libc/dl-lookup-direct.o
-linked += libc/dl-minimal-malloc.o
-linked += libc/dl-misc.o
-linked += libc/dl-object.o
-linked += libc/dl-open.o
-linked += libc/dl-printf.o
-linked += libc/dl-profile.o
-linked += libc/dl-profstub.o
-linked += libc/dl-reloc.o
-linked += libc/dl-runtime.o
-linked += libc/dl-scope.o
-linked += libc/dl-setup_hash.o
-linked += libc/dl-sort-maps.o
-linked += libc/dl-support.o
-linked += libc/dl-sym.o
-linked += libc/dl-sysdep.o
-linked += libc/dl-thread_gscope_wait.o
-linked += libc/dl-tls.o
-linked += libc/dl-tlsdesc.o
-linked += libc/dl-trampoline.o
-linked += libc/dl-tunables.o
-linked += libc/dl-version.o
-
-linked += libc/dladdr.o
-linked += libc/dladdr1.o
-linked += libc/dlclose.o
-linked += libc/dlerror.o
-linked += libc/dlinfo.o
-linked += libc/dlmopen.o
-linked += libc/dlopen.o
-linked += libc/dlsym.o
-linked += libc/dlvsym.o
-
-linked += libc/bsd-_setjmp.o
-linked += libc/__longjmp.o
-linked += libc/longjmp.o
-linked += libc/setjmp.o
-
-linked += libc/alloca_cutoff.o
-linked += libc/environ.o
-linked += libc/setenv.o
-
-linked += libc/gconv.o
-linked += libc/gconv_builtin.o
-linked += libc/gconv_cache.o
-linked += libc/gconv_charset.o
-linked += libc/gconv_close.o
-linked += libc/gconv_conf.o
-linked += libc/gconv_db.o
-linked += libc/gconv_dl.o
-linked += libc/gconv_open.o
-linked += libc/gconv_simple.o
-linked += libc/gconv_trans.o
-
-linked += libc/asprintf.o
-linked += libc/btowc.o
-linked += libc/dbl2mpn.o
-linked += libc/divrem.o
-linked += libc/fprintf.o
-linked += libc/fxprintf.o
-linked += libc/funlockfile.o
-linked += libc/iofflush.o
-linked += libc/iopadn.o
-linked += libc/iovsprintf.o
-linked += libc/iowpadn.o
-linked += libc/isoc99_sscanf.o
-linked += libc/isoc99_vsscanf.o
-linked += libc/itowa-digits.o
-linked += libc/lc-monetary.o
-linked += libc/lc-numeric.o
-linked += libc/ldbl2mpn.o
-linked += libc/printf.o
-linked += libc/printf-parsemb.o
-linked += libc/printf-parsewc.o
-linked += libc/printf_fp.o
-linked += libc/printf_fphex.o
-linked += libc/readonly-area.o
-linked += libc/reg-modifier.o
-linked += libc/reg-printf.o
-linked += libc/reg-type.o
-linked += libc/scratch_buffer_grow_preserve.o
-linked += libc/snprintf.o
-linked += libc/sprintf.o
-linked += libc/towctrans.o
-linked += libc/vasprintf.o
-linked += libc/vasprintf_chk.o
-linked += libc/vfprintf-internal.o
-linked += libc/vfprintf_chk.o
-linked += libc/vfscanf-internal.o
-linked += libc/vfwprintf-internal.o
-linked += libc/vprintf_chk.o
-linked += libc/vsnprintf.o
-linked += libc/vsnprintf_chk.o
-linked += libc/wcsrtombs.o
-linked += libc/wctrans.o
-
-linked += libc/ctype_l.o
-linked += libc/localeconv.o
-linked += libc/wcfuncs_l.o
-linked += libc/wctob.o
-linked += libc/wmemcmp.o
-
-ifeq (,)
-linked += libc/close_nocancel.o
-linked += libc/pread64_nocancel.o
-linked += libc/open64_nocancel.o
-linked += libc/fcntl_nocancel.o
-linked += libc/write_nocancel.o
-linked += libc/read_nocancel.o
-endif
-# }}}
-
-
cflags/$(pwd)/source/main.cpp += -Wno-deprecated-enum-enum-conversion
+cflags += -I$(pwd)/extra
$(call include,cv8/target.mk)
+$(call include,lib/target.mk)
+# XXX: I might not need this anymore
cflags += -D_LIBCPP_HAS_NO_STDIN=
+# XXX: I might not need this anymore
w_icu4c += ac_cv_var_timezone=no
w_icu4c += ac_cv_var___timezone=no
w_icu4c += ac_cv_var_tzname=no
w_icu4c += ac_cv_var__tzname=no
w_icu4c += ac_cv_func_tzset=no
+include jemalloc.mk
-w_jemalloc += --disable-cxx
-w_jemalloc += --disable-libdl
-w_jemalloc += --disable-stats
-w_jemalloc += --disable-syscall
-w_jemalloc += --enable-debug
-w_jemalloc += --with-malloc-conf=tcache:false
-
-w_jemalloc += ac_cv_func_sbrk=no
-w_jemalloc += force_tls=0
-
-jemalloc := lib/libjemalloc_pic.a
-$(output)/%/$(pwd)/jemalloc/$(jemalloc): $(output)/%/$(pwd)/jemalloc/Makefile
- $(MAKE) -C $(dir $<) $(jemalloc)
-linked += $(pwd)/jemalloc/$(jemalloc)
+include capnproto.mk
-ifeq ($(machine),x86_64)
-lib := $(output)/sysroot/usr/lib/$(host/$(machine))
-else
-lib := $(output)/sysroot/usr/$(host/$(machine))/lib
-endif
-
-$(output)/$(machine)/libc.: $(output)/sysroot
- @rm -rf $(basename $@)
- @mkdir -p $(basename $@)
- cd $(basename $@) && $(ar/$(machine)) -x $(CURDIR)/$(lib)/libc.a
- @touch $@
-
-$(output)/$(machine)/libc/%.o: $(output)/$(machine)/libc.
- @
+cflags += -I$(pwd)/workerd/src
+cflags += -I$(output)/capnp/workerd/src
+#source += $(filter-out %-test.c++,$(wildcard $(pwd)/workerd/src/workerd/api/crypto-impl-*.c++))
+header += $(output)/capnp/$(pwd)/capnproto/c++/src/capnp/compat/byte-stream.capnp.h
+header += $(output)/capnp/$(pwd)/capnproto/c++/src/capnp/compat/http-over-capnp.capnp.h
-$(call include,ssl/target.mk)
+header += $(output)/capnp/$(pwd)/workerd/src/workerd/io/actor-storage.capnp.h
+header += $(output)/capnp/$(pwd)/workerd/src/workerd/io/compatibility-date.capnp.h
+header += $(output)/capnp/$(pwd)/workerd/src/workerd/io/outcome.capnp.h
+header += $(output)/capnp/$(pwd)/workerd/src/workerd/io/script-version.capnp.h
+header += $(output)/capnp/$(pwd)/workerd/src/workerd/io/worker-interface.capnp.h
-cflags += -I$(pwd)/capnproto/c++/src
-cflags += -I$(pwd)/workerd/src
-#source += $(wildcard $(pwd)/workerd/src/workerd/api/crypto-impl-aes.c++)
+header += $(output)/capnp/$(pwd)/workerd/src/workerd/jsg/modules.capnp.h
include env/output.mk
diff --git a/srv-worker/source/main.cpp b/srv-worker/source/main.cpp
index f4c14a06a..c868853c4 100644
--- a/srv-worker/source/main.cpp
+++ b/srv-worker/source/main.cpp
@@ -22,6 +22,8 @@
#include
+#include
+
#include
#include
@@ -29,6 +31,7 @@
#include "src/snapshot/snapshot.h"
#include "scope.hpp"
+#include "syscall.hpp"
void Test(const v8::FunctionCallbackInfo &args) {
const auto isolate(args.GetIsolate());
@@ -47,11 +50,7 @@ int main(int argc, char *argv[], char **envp) {
v8::V8::InitializeExternalStartupData(argv[0]);
v8::V8::SetEntropySource([](unsigned char *data, size_t size) {
- // XXX: this is not security critical for our daemon, but might have effects on user code
- // there isn't a good source of entropy right now in the worker process; I should add one
- // NOLINTNEXTLINE(cert-msc32-c,cert-msc51-cpp)
- static const std::independent_bits_engine engine;
- std::generate(data, data + size, engine);
+ orc_assert(orc_syscall(getrandom(data, size, 0)) == size);
return true;
});
diff --git a/srv-worker/source/scope.hpp b/srv-worker/source/scope.hpp
deleted file mode 120000
index 86f83e0db..000000000
--- a/srv-worker/source/scope.hpp
+++ /dev/null
@@ -1 +0,0 @@
-../../p2p/source/scope.hpp
\ No newline at end of file
diff --git a/srv-worker/ssl b/srv-worker/ssl
deleted file mode 120000
index febdfe4ce..000000000
--- a/srv-worker/ssl
+++ /dev/null
@@ -1 +0,0 @@
-../min-openssl
\ No newline at end of file
diff --git a/srv-worker/syscalls.sh b/srv-worker/syscalls.sh
new file mode 100755
index 000000000..a95072f0d
--- /dev/null
+++ b/srv-worker/syscalls.sh
@@ -0,0 +1,2 @@
+#!/bin/bash
+sed -e '0,/^execve(/d;/^orc_trace(/d;/^+++ /d;s/\(mmap([^,]*\),[^,]*/\1/;s/mmap(0x\([0-9a-f]*\),\(.*\)= 0x\1/mmap(0X,\2= 0X/;s/\(mmap(NULL,.*\)= 0x[0-9a-f]*/\1= 0X/;s///;s/^\(madvise\|mprotect\)(0x[0-9a-z]*, [0-9]*, /\1(/;s/^munmap(0x[0-9a-f]*, [0-9]*) */munmap() /' | sort | uniq -c | sort -nr
diff --git a/tst-ethereum/lib b/tst-ethereum/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/tst-ethereum/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/tst-ethereum/makefile b/tst-ethereum/makefile
index f248e7607..10ff9dd66 100644
--- a/tst-ethereum/makefile
+++ b/tst-ethereum/makefile
@@ -32,7 +32,7 @@ test: $(output)/$(machine)/orchid$(exe)
source += $(wildcard source/*.cpp)
cflags += -Isource
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
include env/output.mk
$(output)/%/orchid$(exe): $(patsubst %,$(output)/$$*/%,$(object) $(linked))
diff --git a/tst-ethereum/p2p b/tst-ethereum/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/tst-ethereum/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/tst-explore/env b/tst-explore/env
index 9e1ff3db4..971e97aa3 120000
--- a/tst-explore/env
+++ b/tst-explore/env
@@ -1 +1 @@
-p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/tst-explore/lib b/tst-explore/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/tst-explore/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/tst-explore/makefile b/tst-explore/makefile
index 8b2ae4c1d..837b7bd0c 100644
--- a/tst-explore/makefile
+++ b/tst-explore/makefile
@@ -37,7 +37,7 @@ debug: $(output)/$(machine)/orchid$(exe)
lldb -o 'run $(args)' $<
$(call include,cro/target.mk)
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
source += $(wildcard $(pwd)/source/*.cpp)
diff --git a/tst-explore/p2p b/tst-explore/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/tst-explore/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/tst-finance/env b/tst-finance/env
index 9e1ff3db4..971e97aa3 120000
--- a/tst-finance/env
+++ b/tst-finance/env
@@ -1 +1 @@
-p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/tst-finance/lib b/tst-finance/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/tst-finance/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/tst-finance/makefile b/tst-finance/makefile
index 5cfcba3f9..4d6128293 100644
--- a/tst-finance/makefile
+++ b/tst-finance/makefile
@@ -33,15 +33,15 @@ test: $(output)/$(machine)/orchid$(exe)
debug: $(output)/$(machine)/orchid$(exe)
lldb -o 'run $(args)' $<
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
$(call include,zlb/target.mk)
source += $(wildcard source/*.cpp)
-cflags += -I$(pwd)/p2p/boost/libs/iostreams/include
+cflags += -I$(pwd)/lib/boost/libs/iostreams/include
-source += $(pwd)/p2p/boost/libs/iostreams/src/gzip.cpp
-source += $(pwd)/p2p/boost/libs/iostreams/src/zlib.cpp
+source += $(pwd)/lib/boost/libs/iostreams/src/gzip.cpp
+source += $(pwd)/lib/boost/libs/iostreams/src/zlib.cpp
include env/output.mk
diff --git a/tst-finance/p2p b/tst-finance/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/tst-finance/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/tst-metadata/env b/tst-metadata/env
index 9e1ff3db4..971e97aa3 120000
--- a/tst-metadata/env
+++ b/tst-metadata/env
@@ -1 +1 @@
-p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/tst-metadata/lib b/tst-metadata/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/tst-metadata/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/tst-metadata/makefile b/tst-metadata/makefile
index 6ce152c29..2de41eb6f 100644
--- a/tst-metadata/makefile
+++ b/tst-metadata/makefile
@@ -33,7 +33,7 @@ test: $(output)/$(machine)/orchid$(exe)
debug: $(output)/$(machine)/orchid$(exe)
lldb -o 'run $(args)' $<
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
source += $(wildcard source/*.cpp)
diff --git a/tst-metadata/p2p b/tst-metadata/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/tst-metadata/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/tst-network/env b/tst-network/env
index db4309187..971e97aa3 120000
--- a/tst-network/env
+++ b/tst-network/env
@@ -1 +1 @@
-vpn/p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/tst-openvpn3/env b/tst-openvpn3/env
index db4309187..971e97aa3 120000
--- a/tst-openvpn3/env
+++ b/tst-openvpn3/env
@@ -1 +1 @@
-vpn/p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/tst-openvpn3/makefile b/tst-openvpn3/makefile
index cf92c346e..c26014629 100644
--- a/tst-openvpn3/makefile
+++ b/tst-openvpn3/makefile
@@ -35,8 +35,8 @@ test: $(output)/$(machine)/orchid$(exe)
debug: $(output)/$(machine)/orchid$(exe)
sudo lldb -o 'run $(args)' $<
-source += $(wildcard vpn/p2p/lz4/lib/*.c)
-cflags += -Ivpn/p2p/lz4/lib
+source += $(wildcard vpn/lib/lz4/lib/*.c)
+cflags += -Ivpn/lib/lz4/lib
cflags += -DUSE_ASIO
cflags += -DUSE_ASIO_THREADLOCAL
@@ -44,20 +44,20 @@ cflags += -DHAVE_LZ4
cflags += -DUSE_OPENSSL
cflags += -D'OPENVPN_PACKET_LOG="packet.log"'
-cflags += -Ivpn/p2p/openvpn3
-cflags += -Ivpn/p2p/openvpn3/client
+cflags += -Ivpn/lib/openvpn3
+cflags += -Ivpn/lib/openvpn3/client
ifeq ($(target),ios)
-cflags/vpn/p2p/openvpn3 += -ObjC++
+cflags/vpn/lib/openvpn3 += -ObjC++
endif
-cflags += -Ivpn/p2p/source
+cflags += -Ivpn/lib/source
-$(call include,vpn/p2p/asio.mk)
-$(call include,vpn/p2p/rtc/openssl.mk)
+$(call include,vpn/lib/asio.mk)
+$(call include,vpn/lib/webrtc/openssl.mk)
-source += vpn/p2p/openvpn3/test/ovpncli/cli.cpp
-source += vpn/p2p/source/log.cpp
+source += vpn/lib/openvpn3/test/ovpncli/cli.cpp
+source += vpn/lib/source/log.cpp
ifeq ($(target),mac)
lflags += -framework CoreServices
diff --git a/tst-share/env b/tst-share/env
index 9e1ff3db4..971e97aa3 120000
--- a/tst-share/env
+++ b/tst-share/env
@@ -1 +1 @@
-p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/tst-share/lib b/tst-share/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/tst-share/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/tst-share/makefile b/tst-share/makefile
index 14bede858..c5cc6dd21 100644
--- a/tst-share/makefile
+++ b/tst-share/makefile
@@ -36,7 +36,7 @@ test: $(output)/$(machine)/orchid$(exe)
debug: $(output)/$(machine)/orchid$(exe)
lldb -o 'run $(args)' $<
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
source += $(wildcard $(pwd)/source/*.cpp)
diff --git a/tst-share/p2p b/tst-share/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/tst-share/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/tst-ticket/env b/tst-ticket/env
index 9e1ff3db4..971e97aa3 120000
--- a/tst-ticket/env
+++ b/tst-ticket/env
@@ -1 +1 @@
-p2p/rtc/env
\ No newline at end of file
+../env
\ No newline at end of file
diff --git a/tst-ticket/lib b/tst-ticket/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/tst-ticket/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/tst-ticket/makefile b/tst-ticket/makefile
index fe195aac0..dd22e2e9a 100644
--- a/tst-ticket/makefile
+++ b/tst-ticket/makefile
@@ -34,7 +34,7 @@ test: $(output)/$(machine)/ticket$(exe)
debug: $(output)/$(machine)/ticket$(exe)
lldb -o 'run $(args)' $<
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
source += $(wildcard source/*.cpp)
diff --git a/tst-ticket/p2p b/tst-ticket/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/tst-ticket/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/vpn-shared/lib b/vpn-shared/lib
new file mode 120000
index 000000000..e563ee719
--- /dev/null
+++ b/vpn-shared/lib
@@ -0,0 +1 @@
+../lib-protocol
\ No newline at end of file
diff --git a/vpn-shared/p2p b/vpn-shared/p2p
deleted file mode 120000
index 86974347a..000000000
--- a/vpn-shared/p2p
+++ /dev/null
@@ -1 +0,0 @@
-../p2p
\ No newline at end of file
diff --git a/vpn-shared/target.mk b/vpn-shared/target.mk
index 253d2e49a..c15564c5c 100644
--- a/vpn-shared/target.mk
+++ b/vpn-shared/target.mk
@@ -42,4 +42,4 @@ endif
$(call include,libevent.mk)
$(call include,wsk/target.mk)
-$(call include,p2p/target.mk)
+$(call include,lib/target.mk)
diff --git a/vpn-shared/tor.mk b/vpn-shared/tor.mk
index 22e6860ca..fd434b2a7 100644
--- a/vpn-shared/tor.mk
+++ b/vpn-shared/tor.mk
@@ -33,7 +33,8 @@ deps += $(pwd)/libevent/.libs/libevent_core.a
w_tor += tor_cv_library_zlib_dir="(system)"
p_tor += -I@/openssl/include
-p_tor += -I$(CURDIR)/$(pwd)/p2p/rtc/openssl/include
+# XXX: I don't think openssl is in this folder anymore
+p_tor += -I$(CURDIR)/$(pwd)/lib/webrtc/openssl/include
deps += openssl/include/openssl/opensslconf.h
l_tor += -L@/openssl
deps += openssl/libssl.a