diff options
Diffstat (limited to 'testing')
-rw-r--r-- | testing/android-tools/APKBUILD | 78 | ||||
-rw-r--r-- | testing/android-tools/android-tools.patch | 826 | ||||
-rw-r--r-- | testing/android-tools/fix-build.patch | 69 | ||||
-rw-r--r-- | testing/android-tools/fix-getcwd.patch | 36 | ||||
-rw-r--r-- | testing/android-tools/generate-build.rb | 172 | ||||
-rw-r--r-- | testing/android-tools/musl-fixes.patch | 164 |
6 files changed, 1026 insertions, 319 deletions
diff --git a/testing/android-tools/APKBUILD b/testing/android-tools/APKBUILD index 39fa992b0a..ae3a3fc231 100644 --- a/testing/android-tools/APKBUILD +++ b/testing/android-tools/APKBUILD @@ -1,46 +1,40 @@ # Contributor: Sören Tempel <soeren+alpine@soeren-tempel.net> # Maintainer: Sören Tempel <soeren+alpine@soeren-tempel.net> pkgname=android-tools -pkgver=6.0.1_p46 +pkgver=7.0.0_p24 _realver=${pkgver/_p/_r} -pkgrel=2 +pkgrel=0 pkgdesc="Android platform tools" url="http://tools.android.com/" arch="all" license="Apache BSD" depends="" depends_dev="" -makedepends="zlib-dev libressl-dev pcre-dev linux-headers bsd-compat-headers - ruby" +makedepends="zlib-dev libressl-dev pcre-dev linux-headers bsd-compat-headers" install="" subpackages="" source="http://dev.alpinelinux.org/archive/$pkgname/$pkgname-core-$_realver.tar.gz http://dev.alpinelinux.org/archive/$pkgname/$pkgname-extras-$_realver.tar.gz http://dev.alpinelinux.org/archive/$pkgname/$pkgname-libselinux-$_realver.tar.gz http://dev.alpinelinux.org/archive/$pkgname/$pkgname-f2fs-tools-$_realver.tar.gz + http://dev.alpinelinux.org/archive/$pkgname/$pkgname-safe-iop-$_realver.tar.gz + http://dev.alpinelinux.org/archive/$pkgname/$pkgname-gtest-$_realver.tar.gz - fix-build.patch - fix-getcwd.patch - generate-build.rb + android-tools.patch + musl-fixes.patch " _giturl="https://android.googlesource.com/platform" _gittag="android-$_realver" builddir="$srcdir" -prepare() { - default_prepare || return 1 - - cd "$builddir" - echo "set -x -e" > build.sh - ruby generate-build.rb >> build.sh -} +patch_args="-p0" snapshot() { mkdir -p "$srcdir" && cd "$srcdir" local r= - for r in system/core system/extras external/libselinux external/f2fs-tools; do + for r in system/core system/extras external/libselinux external/f2fs-tools external/gtest external/safe-iop; do local n="${r##*/}.git" local f=$pkgname-"${r##*/}" @@ -56,35 +50,35 @@ snapshot() { } build() { - cd "$builddir" - PKGVER=$pkgver sh build.sh || return 1 + make -C "$builddir" || return 1 } package() { - cd "$builddir" - mkdir -p "$pkgdir"/usr/bin/ - install -Dm755 mkbootimg fastboot adb \ - "$pkgdir"/usr/bin/ || return 1 + make DESTDIR="$pkgdir" PREFIX=/usr \ + -C "$builddir" install || return 1 } -md5sums="db66109fd5ca02ad4ad6c879441ee96c android-tools-core-6.0.1_r46.tar.gz -1d5f3bdf8a54c94e27f9f663ff5ec6c9 android-tools-extras-6.0.1_r46.tar.gz -0ae3837c990c4262f3ada4917acc8153 android-tools-libselinux-6.0.1_r46.tar.gz -b99b09cfef42ac2faad237d51338abad android-tools-f2fs-tools-6.0.1_r46.tar.gz -7272c0aea987e1d4450ed316cb19937a fix-build.patch -b3d1da647a52bf0dd6ca562033648b41 fix-getcwd.patch -3c77207b30748bcf2cbb6dab257bf6ff generate-build.rb" -sha256sums="1e0186dc1160f2db44aee4afb68909760dbf421d9e82de04a850547d70a5fd05 android-tools-core-6.0.1_r46.tar.gz -de52852ee2a172cf193bf43840e2d4418d6dfbdcae68cbff3c77ba0c09f325cb android-tools-extras-6.0.1_r46.tar.gz -5c60e5bfa33e0977ddb6e5f1e0c4df19d88447640d308aaf9665da13b1d370ee android-tools-libselinux-6.0.1_r46.tar.gz -0883c9017c8e498456563c2088e7436eb725a7720d01ac565f27fd2c82263ac8 android-tools-f2fs-tools-6.0.1_r46.tar.gz -bb91e2a8855a5b47d64fbe2a13dcfb5c3bfca5b9e79e06a790cdabe48d55bc2c fix-build.patch -d9e2ba5337c2dbea2d9747c232f56953562494e44faeee88dd0abddb3c810796 fix-getcwd.patch -802f565f7204b720ff86f6acb02aa1ba03b9438b84a38911ba76edeb0824dd3d generate-build.rb" -sha512sums="091c663ff5ba36fed872f30c4d32e4961657ce3bf3c039dd641cc4e003194c5b40aa2dd373f909e58df4529465d5c80784423e8a71229104af75c84c835ead90 android-tools-core-6.0.1_r46.tar.gz -bb3953bfaed031a46dc707896df303a44ea7c764adc48757344c38b805a820c95aa6a702a5e8247c73872466600706e66bf2d3487e6c988cc009197f893426d5 android-tools-extras-6.0.1_r46.tar.gz -765491488780e1da7510fa3146b6ae7443e98ee5b64490aea1fe95d05eb3f96f31c389cbcc33178ffac602f12bda0948f8d7e8dd23bb27628061fd0ba00a106c android-tools-libselinux-6.0.1_r46.tar.gz -b5433ac4b9e3f6b180ebc0b8b5c623b0e1008111e40a179ab4383bd7730ecd09a74d524ee8a5ff8bc1dd0ab8c8cef824c8e8212cf9ad461cff1399de0e96b113 android-tools-f2fs-tools-6.0.1_r46.tar.gz -38e5ce4bfc0305585b1071b52c5d2e47927adc24318abdc466c9eed53ad6ed4fa83b6c1342db51d3a62b76996d2649632012d73c340eaf8b131ac6023248c59a fix-build.patch -d6ab3595d1f77f4baea03d828cc03291cb08e7787ebd653faac4776a2d27ff899f0746516f52c8b533dd104f9e9a1fcede59936de3146f7b8e8955101dacd889 fix-getcwd.patch -421596678ab767d4bf59c54878e82a4faa0e3b5a070803ea37b5ee3c8cd41972d2d8ae46d081ee54a0d5b24874c893f32ad2aae7426090632f8c6099a241030b generate-build.rb" +md5sums="08f229c6a7ee88c9757f7dd204454fb0 android-tools-core-7.0.0_r24.tar.gz +1ed5c25518727a3ae614163fa63b813b android-tools-extras-7.0.0_r24.tar.gz +8d0d5abf79d0e56cc73cffd24f994224 android-tools-libselinux-7.0.0_r24.tar.gz +d4923c0dc9508fa1d6299d633479e306 android-tools-f2fs-tools-7.0.0_r24.tar.gz +5927ee8bddba0a8dcd4ffd3d8b56251e android-tools-safe-iop-7.0.0_r24.tar.gz +b41dd596e7ec64b5d278952dc5415cd9 android-tools-gtest-7.0.0_r24.tar.gz +883cfac28233868a458aab9cfc5da9a1 android-tools.patch +4f1a962a06ce980cc1623e0cd3417a45 musl-fixes.patch" +sha256sums="b6eac2868570c458418c9d9317a00d5ca2552eb33faa693a8014b928c71c1718 android-tools-core-7.0.0_r24.tar.gz +7085bba77af11b7758a4146bc7b13aa2c3ba6ca0e15ccf9173bc86fc32bf5342 android-tools-extras-7.0.0_r24.tar.gz +cd6ec4a1ba06e76dbb2e9eeaa06d23d39e48a21186a9bcc7522694ca1b603b3d android-tools-libselinux-7.0.0_r24.tar.gz +53ae7ea6f7c28847ea249624681fc055b0e95b27f09a55946e22a8352aa91887 android-tools-f2fs-tools-7.0.0_r24.tar.gz +7e961123b32bd0e6fd2d594508746bcaefb6e56990f3afc2c4891f25fcbd7a4d android-tools-safe-iop-7.0.0_r24.tar.gz +8d8e482c14b39df2e5f9db9d0dec6696adeaaf8380de4a7afd76ee83ac702b7a android-tools-gtest-7.0.0_r24.tar.gz +08686f177f6c1bd6901b43816aa83e5f1f3c512f583470b1a520b62d54c3d3e6 android-tools.patch +e4423745d2ac88e24b42250b97345753c954218ec3fc98a1cb3f8b27016eab1f musl-fixes.patch" +sha512sums="f2e054fb236518ce101ba3a17e578985a8e4884c127c113a3e702386abbb5077c647565c21575e1d2103c1f0316c7ddcfd8602b7eadf6955d01054842430ff18 android-tools-core-7.0.0_r24.tar.gz +2dd2b571f17d44b2edb354eee9d913e8a004604fc56cf21bb14b7d081891912443bf7a7a543edad834082f93263b200bc0539200a6cb0a4109f502742529d53f android-tools-extras-7.0.0_r24.tar.gz +3e985e01b4f1d413c4ffb7dea4fa6edc8350872df037eab1e3d109f6f19dcf94a7f77c9bc17d5f2838ebf6f773fb357cf9fb963caccb02b2613793d0e49f6a17 android-tools-libselinux-7.0.0_r24.tar.gz +fbe08ddafa47d647884bb64202d4fceeabd88bcdba825dd9eb1257744b29a85317fe3cc34c991d9c8ba7838f9ab19d4b94fe2acaa3c6564f9d8689be0461b1b9 android-tools-f2fs-tools-7.0.0_r24.tar.gz +baee83d6e0010f3884e9bd56c270294402be9eed2109871b9f2ebc833e35e506605c5d41dfea377e5e59b17b0dbbf4acee2759146d2465b5d2315eb212fa7299 android-tools-safe-iop-7.0.0_r24.tar.gz +303d1b604bd8f8eff8d4d5d9518a43c2d4a96d5d4ca9c89d97120f987897261faa0fee4f22745d066b4a89cdbaeef15cca4cd08fab74340b94c22a8c4d312f4c android-tools-gtest-7.0.0_r24.tar.gz +211fb8d6c37522b26306b75a3d1d2ee05f7c914f32b91a55cfea7375f5f5a99dae484ab11f798caea96de91bb9e345fb67efab19b12c779539fb15b2a687569b android-tools.patch +75e09d7391dba7858cf50d98893c84986b5117e6b920109b0adb4a2e1215b8b85b427fb4e855402f21541cbf01a21430ed2d30296d041ba56c01d0c735334dca musl-fixes.patch" diff --git a/testing/android-tools/android-tools.patch b/testing/android-tools/android-tools.patch new file mode 100644 index 0000000000..9052703861 --- /dev/null +++ b/testing/android-tools/android-tools.patch @@ -0,0 +1,826 @@ +This patch has been taken from the Void Linux distribution. + +https://github.com/voidlinux/void-packages/tree/master/srcpkgs/android-tools/patches/android-tools.patch + +diff --git a/Makefile b/Makefile +new file mode 100644 +index 000000000000..4644fc0b62ad +--- /dev/null ++++ Makefile +@@ -0,0 +1,47 @@ ++all: ++ $(MAKE) -C core/libcutils all ++ $(MAKE) -C libselinux all ++ $(MAKE) -C core/libziparchive all ++ $(MAKE) -C extras/ext4_utils all ++ $(MAKE) -C core/libsparse all ++ $(MAKE) -C core/libutils all ++ $(MAKE) -C core/liblog all ++ $(MAKE) -C core/base all ++ $(MAKE) -C gtest all ++ $(MAKE) -C extras/f2fs_utils all ++ $(MAKE) -C core/adb all ++ $(MAKE) -C core/fastboot all ++ ++install: all ++ $(MAKE) -C core/adb install ++ $(MAKE) -C core/fastboot install ++ ++clean: ++ $(MAKE) -C core/libcutils clean ++ $(MAKE) -C libselinux clean ++ $(MAKE) -C core/libziparchive clean ++ $(MAKE) -C extras/ext4_utils clean ++ $(MAKE) -C core/libsparse clean ++ $(MAKE) -C core/libutils clean ++ $(MAKE) -C core/liblog clean ++ $(MAKE) -C core/adb libdiagnose_usb ++ $(MAKE) -C core/base clean ++ $(MAKE) -C gtest clean ++ $(MAKE) -C extras/f2fs_utils clean ++ $(MAKE) -C core/adb clean ++ $(MAKE) -C core/fastboot clean ++ ++mrproper: ++ $(MAKE) -C core/libcutils mrproper ++ $(MAKE) -C libselinux mrproper ++ $(MAKE) -C core/libziparchive mrproper ++ $(MAKE) -C extras/ext4_utils mrproper ++ $(MAKE) -C core/libsparse mrproper ++ $(MAKE) -C core/libutils mrproper ++ $(MAKE) -C core/liblog mrproper ++ $(MAKE) -C core/adb libdiagnose_usb ++ $(MAKE) -C core/base mrproper ++ $(MAKE) -C gtest mrproper ++ $(MAKE) -C extras/f2fs_utils mrproper ++ $(MAKE) -C core/adb mrproper ++ $(MAKE) -C core/fastboot mrproper +diff --git core/adb/Makefile core/adb/Makefile +new file mode 100644 +index 0000000..8ef539b +--- /dev/null ++++ core/adb/Makefile +@@ -0,0 +1,97 @@ ++adb_version := $(shell git -C . rev-parse --short=12 HEAD 2>/dev/null)-android ++ ++SRCS+= \ ++ adb_client.cpp \ ++ client/main.cpp \ ++ console.cpp \ ++ commandline.cpp \ ++ file_sync_client.cpp \ ++ line_printer.cpp \ ++ services.cpp \ ++ shell_service_protocol.cpp \ ++ ++LIBADB_SRCS= \ ++ adb.cpp \ ++ adb_auth.cpp \ ++ adb_io.cpp \ ++ adb_listeners.cpp \ ++ adb_trace.cpp \ ++ adb_utils.cpp \ ++ fdevent.cpp \ ++ sockets.cpp \ ++ transport.cpp \ ++ transport_local.cpp \ ++ transport_usb.cpp \ ++ adb_auth_host.cpp \ ++ get_my_path_linux.cpp \ ++ sysdeps_unix.cpp \ ++ usb_linux.cpp \ ++ ++LIBDIAGNOSE_USB_SRCS= \ ++ diagnose_usb.cpp ++ ++ ++override CXXFLAGS+= \ ++ -I. \ ++ -I../include \ ++ -I../base/include \ ++ -D_Nonnull="" \ ++ -D_Nullable="" \ ++ -D_GNU_SOURCE \ ++ -Wall \ ++ -Wextra \ ++ -Wno-unused-parameter \ ++ -Wno-missing-field-initializers \ ++ -Wvla \ ++ -DADB_REVISION='"$(adb_version)"' \ ++ -std=gnu++14 \ ++ -DADB_HOST=1 \ ++ -fpermissive \ ++ -fvisibility=hidden ++ ++ ++LIBS= \ ++ ./libadb.a \ ++ ./libdiagnose_usb.a \ ++ ../base/libbase.a \ ++ ../libcutils/libcutils.a \ ++ ../liblog/liblog.a ++ ++override LDFLAGS+= -lssl -lcrypto -lpthread ++ ++OBJS= $(SRCS:.cpp=.o) ++LIBADB_OBJS= $(LIBADB_SRCS:.cpp=.o) ++LIBDIAGNOSE_USB_OBJS= $(LIBDIAGNOSE_USB_SRCS:.cpp=.o) ++ ++BIN= adb ++ ++all: $(BIN) ++ ++adb: $(OBJS) libadb libdiagnose_usb ++ $(CXX) -o $@ $(OBJS) $(LIBS) $(LDFLAGS) ++ ++ ++libadb: libadb.a ++ ++libadb.a: $(LIBADB_OBJS) ++ $(AR) rcs $@ $(LIBADB_OBJS) ++ ++libdiagnose_usb: libdiagnose_usb.a ++ ++libdiagnose_usb.a: $(LIBDIAGNOSE_USB_OBJS) ++ $(AR) rcs $@ $(LIBDIAGNOSE_USB_OBJS) ++ ++%.o: %.cpp ++ $(CXX) -c $< $(CXXFLAGS) -o $@ ++ ++install: adb ++ install -Dm755 adb $(DESTDIR)$(PREFIX)/bin/adb ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) $(LIBADB_OBJS) $(LIBDIAGNOSE_USB_OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) *.a ++ +diff --git core/base/Makefile core/base/Makefile +new file mode 100644 +index 0000000..d3e7436 +--- /dev/null ++++ core/base/Makefile +@@ -0,0 +1,37 @@ ++SRCS+= \ ++ file.cpp \ ++ logging.cpp \ ++ parsenetaddress.cpp \ ++ stringprintf.cpp \ ++ strings.cpp \ ++ test_utils.cpp \ ++ errors_unix.cpp ++ ++override CXXFLAGS+= \ ++ -I./include \ ++ -I../include \ ++ -D__GLIBC__ \ ++ -Wall \ ++ -Wextra \ ++ -Werror \ ++ -std=gnu++14 ++ ++OBJS= $(SRCS:.cpp=.o) ++ ++BIN= libbase.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.cpp ++ $(CXX) -c $< $(CXXFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git core/base/errors_unix.cpp core/base/errors_unix.cpp +index 296995e..3b983d3 100644 +--- core/base/errors_unix.cpp ++++ core/base/errors_unix.cpp +@@ -17,6 +17,7 @@ + #include "android-base/errors.h" + + #include <errno.h> ++#include <cstring> + + namespace android { + namespace base { +diff --git core/base/logging.cpp core/base/logging.cpp +index 1741871..0aaae2e 100644 +--- core/base/logging.cpp ++++ core/base/logging.cpp +@@ -33,6 +33,7 @@ + #include <limits> + #include <sstream> + #include <string> ++#include <cstring> + #include <utility> + #include <vector> + +diff --git core/fastboot/Makefile core/fastboot/Makefile +new file mode 100644 +index 0000000..6d81f7c +--- /dev/null ++++ core/fastboot/Makefile +@@ -0,0 +1,70 @@ ++fastboot_version := $(shell git -C . rev-parse --short=12 HEAD 2>/dev/null)-android ++ ++SRCS+= \ ++ bootimg_utils.cpp \ ++ engine.cpp \ ++ fastboot.cpp \ ++ fs.cpp\ ++ protocol.cpp \ ++ socket.cpp \ ++ tcp.cpp \ ++ udp.cpp \ ++ util.cpp \ ++ usb_linux.cpp \ ++ util_linux.cpp ++ ++ ++override CXXFLAGS+= \ ++ -I../mkbootimg/ \ ++ -I../base/include \ ++ -I../libsparse/include \ ++ -I../include \ ++ -I../adb \ ++ -I../../gtest/include \ ++ -I../../extras/ext4_utils \ ++ -I../../extras/f2fs_utils \ ++ -Wall \ ++ -Wextra \ ++ -Werror \ ++ -Wunreachable-code \ ++ -DFASTBOOT_REVISION='"$(fastboot_version)"' \ ++ -std=gnu++14 ++ ++LIBS= \ ++ ../libziparchive/libziparchive.a \ ++ ../../extras/ext4_utils/libext4_utils.a \ ++ ../libsparse/libsparse.a \ ++ ../libutils/libutils.a \ ++ ../liblog/liblog.a \ ++ ../adb/libdiagnose_usb.a \ ++ ../base/libbase.a \ ++ ../libcutils/libcutils.a \ ++ ../../gtest/libgtest.a \ ++ ../../extras/f2fs_utils/libf2fs.a \ ++ ../libcutils/libcutils.a \ ++ ../../libselinux/libselinux.a ++ ++override LDFLAGS+= -lz -lpcre -lpthread ++ ++OBJS= $(SRCS:.cpp=.o) ++ ++BIN= fastboot ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(CXX) -o $@ $(OBJS) $(LIBS) $(LDFLAGS) ++ ++%.o: %.cpp ++ $(CXX) -c $< $(CXXFLAGS) -o $@ ++ ++install: fastboot ++ install -Dm755 fastboot $(DESTDIR)$(PREFIX)/bin/fastboot ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git core/include/cutils/atomic.h core/include/cutils/atomic.h +index ded972a..2ff6fce 100644 +--- core/include/cutils/atomic.h ++++ core/include/cutils/atomic.h +@@ -19,7 +19,12 @@ + + #include <stdint.h> + #include <sys/types.h> ++#ifdef __cplusplus ++#include <atomic> ++using namespace std; ++#else + #include <stdatomic.h> ++#endif + + #ifndef ANDROID_ATOMIC_INLINE + #define ANDROID_ATOMIC_INLINE static inline +@@ -114,6 +119,7 @@ int32_t android_atomic_or(int32_t value, volatile int32_t* addr) + return atomic_fetch_or_explicit(a, value, memory_order_release); + } + ++#ifndef __cplusplus + /* + * Perform an atomic load with "acquire" or "release" ordering. + * +@@ -208,6 +214,7 @@ int android_atomic_release_cas(int32_t oldvalue, int32_t newvalue, + memory_order_release, + memory_order_relaxed)); + } ++#endif + + /* + * Fence primitives. +diff --git core/include/log/log.h core/include/log/log.h +index e606a84..963347a 100644 +--- core/include/log/log.h ++++ core/include/log/log.h +@@ -38,6 +38,7 @@ + #include <log/uio.h> + + #ifdef __cplusplus ++#include <cstring> + extern "C" { + #endif + +diff --git core/libcutils/Makefile core/libcutils/Makefile +new file mode 100644 +index 0000000..ec9c573 +--- /dev/null ++++ core/libcutils/Makefile +@@ -0,0 +1,59 @@ ++CSRCS+= \ ++ config_utils.c \ ++ fs_config.c \ ++ canned_fs_config.c \ ++ hashmap.c \ ++ iosched_policy.c \ ++ load_file.c \ ++ native_handle.c \ ++ open_memstream.c \ ++ process_name.c \ ++ record_stream.c \ ++ sched_policy.c \ ++ strlcpy.c \ ++ threads.c \ ++ fs.c \ ++ multiuser.c \ ++ socket_inaddr_any_server_unix.c \ ++ socket_local_client_unix.c \ ++ socket_local_server_unix.c \ ++ socket_loopback_client_unix.c \ ++ socket_loopback_server_unix.c \ ++ socket_network_client_unix.c \ ++ str_parms.c \ ++ ashmem-host.c \ ++ trace-host.c \ ++ dlmalloc_stubs.c ++ ++CXXSRCS+= \ ++ sockets_unix.cpp \ ++ sockets.cpp \ ++ strdup16to8.c \ ++ strdup8to16.c ++ ++override CFLAGS+= -I../include ++ ++override CXXFLAGS+= -I../include ++ ++COBJS= $(CSRCS:.c=.o) ++CXXOBJS= $(CXXSRCS:.cpp=.o) ++BIN= libcutils.a ++ ++all: $(BIN) ++ ++$(BIN): $(COBJS) $(CXXOBJS) ++ $(AR) rcs $@ $(COBJS) $(CXXOBJS) ++ ++%.o: %.c ++ $(CC) -c $< $(CFLAGS) -o $@ ++ ++%.o: %.cpp ++ $(CXX) -c $< $(CXXFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(COBJS) $(CXXOBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git core/libcutils/fs.c core/libcutils/fs.c +index 3f14de7..175df6a 100644 +--- core/libcutils/fs.c ++++ core/libcutils/fs.c +@@ -79,7 +79,7 @@ static int fs_prepare_path_impl(const char* path, mode_t mode, uid_t uid, gid_t + create: + create_result = prepare_as_dir + ? TEMP_FAILURE_RETRY(mkdir(path, mode)) +- : TEMP_FAILURE_RETRY(open(path, O_CREAT | O_CLOEXEC | O_NOFOLLOW | O_RDONLY)); ++ : TEMP_FAILURE_RETRY(open(path, O_CREAT | O_CLOEXEC | O_NOFOLLOW | O_RDONLY, mode)); + if (create_result == -1) { + if (errno != EEXIST) { + ALOGE("Failed to %s(%s): %s", +diff --git core/liblog/Makefile core/liblog/Makefile +new file mode 100644 +index 0000000..75a0af3 +--- /dev/null ++++ core/liblog/Makefile +@@ -0,0 +1,39 @@ ++SRCS+= \ ++ log_event_list.c \ ++ log_event_write.c \ ++ logger_write.c \ ++ config_write.c \ ++ logger_name.c \ ++ logger_lock.c \ ++ fake_log_device.c \ ++ fake_writer.c \ ++ event_tag_map.c ++ ++ ++override CFLAGS+= \ ++ -I../include \ ++ -DLIBLOG_LOG_TAG=1005 \ ++ -DSNET_EVENT_LOG_TAG=1397638484 \ ++ -DFAKE_LOG_DEVICE=1 \ ++ -Werror \ ++ -fvisibility=hidden ++ ++OBJS= $(SRCS:.c=.o) ++ ++BIN= liblog.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.c ++ $(CC) -c $< $(CFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git core/libpackagelistparser/Makefile core/libpackagelistparser/Makefile +new file mode 100644 +index 0000000..38a0158 +--- /dev/null ++++ core/libpackagelistparser/Makefile +@@ -0,0 +1,20 @@ ++SRCS+= \ ++ packagelistparser.c ++ ++override CFLAGS+= -I../include ++override CFLAGS+= -I./include ++ ++OBJS= $(SRCS:.c=.o) ++ ++BIN= libpackagelistparser.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.c ++ $(CC) -c $< $(CFLAGS) -o $@ ++ ++clean: ++ rm -rf *.o +diff --git core/libsparse/Makefile core/libsparse/Makefile +new file mode 100644 +index 0000000..418c028 +--- /dev/null ++++ core/libsparse/Makefile +@@ -0,0 +1,31 @@ ++SRCS+= \ ++ backed_block.c \ ++ output_file.c \ ++ sparse.c \ ++ sparse_crc32.c \ ++ sparse_err.c \ ++ sparse_read.c ++ ++override CFLAGS+= \ ++ -I./include \ ++ -Werror ++ ++OBJS= $(SRCS:.c=.o) ++ ++BIN= libsparse.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.c ++ $(CC) -c $< $(CFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git core/libutils/Makefile core/libutils/Makefile +new file mode 100644 +index 0000000..82a22b9 +--- /dev/null ++++ core/libutils/Makefile +@@ -0,0 +1,50 @@ ++SRCS+= \ ++ CallStack.cpp \ ++ FileMap.cpp \ ++ JenkinsHash.cpp \ ++ LinearTransform.cpp \ ++ Log.cpp \ ++ NativeHandle.cpp \ ++ Printer.cpp \ ++ PropertyMap.cpp \ ++ RefBase.cpp \ ++ SharedBuffer.cpp \ ++ Static.cpp \ ++ StopWatch.cpp \ ++ String8.cpp \ ++ String16.cpp \ ++ SystemClock.cpp \ ++ Threads.cpp \ ++ Timers.cpp \ ++ Tokenizer.cpp \ ++ Unicode.cpp \ ++ VectorImpl.cpp \ ++ misc.cpp \ ++ Looper.cpp \ ++ ProcessCallStack.cpp ++ ++override CXXFLAGS+= \ ++ -I../include \ ++ -I../../safe-iop/include \ ++ -DLIBUTILS_NATIVE=1 \ ++ -std=gnu++14 ++ ++OBJS= $(SRCS:.cpp=.o) ++ ++BIN= libutils.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.cpp ++ $(CXX) -c $< $(CXXFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git core/libziparchive/Makefile core/libziparchive/Makefile +new file mode 100644 +index 0000000..4eef274 +--- /dev/null ++++ core/libziparchive/Makefile +@@ -0,0 +1,34 @@ ++SRCS+= \ ++ zip_archive.cc \ ++ zip_archive_stream_entry.cc \ ++ zip_writer.cc \ ++ ++override CXXFLAGS+= \ ++ -I./include \ ++ -I../include \ ++ -I../base/include \ ++ -DZLIB_CONST \ ++ -Werror \ ++ -fno-strict-aliasing \ ++ -std=gnu++14 \ ++ -Wall ++ ++OBJS= $(SRCS:.cc=.o) ++ ++BIN= libziparchive.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.c ++ $(CXX) -c $< $(CXXFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git core/libziparchive/zip_writer.cc core/libziparchive/zip_writer.cc +index 1ebed30..5c622d0 100644 +--- core/libziparchive/zip_writer.cc ++++ core/libziparchive/zip_writer.cc +@@ -24,6 +24,7 @@ + + #include <cassert> + #include <cstdio> ++#include <cstring> + #include <memory> + #include <vector> + #include <zlib.h> +diff --git extras/ext4_utils/Makefile extras/ext4_utils/Makefile +new file mode 100644 +index 0000000..000aaca +--- /dev/null ++++ extras/ext4_utils/Makefile +@@ -0,0 +1,38 @@ ++SRCS+= \ ++ make_ext4fs.c \ ++ ext4fixup.c \ ++ ext4_utils.c \ ++ allocate.c \ ++ contents.c \ ++ extent.c \ ++ indirect.c \ ++ sha1.c \ ++ wipe.c \ ++ crc16.c \ ++ ext4_sb.c ++ ++override CFLAGS+= \ ++ -I../../core/libsparse/include \ ++ -I../../core/include \ ++ -I../../libselinux/include \ ++ -fno-strict-aliasing ++ ++OBJS= $(SRCS:.c=.o) ++ ++BIN= libext4_utils.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.c ++ $(CC) -c $< $(CFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git extras/f2fs_utils/Makefile extras/f2fs_utils/Makefile +new file mode 100644 +index 0000000..d81ac9a +--- /dev/null ++++ extras/f2fs_utils/Makefile +@@ -0,0 +1,34 @@ ++SRCS+= \ ++ f2fs_utils.c \ ++ f2fs_ioutils.c \ ++ f2fs_dlutils.c ++ ++ ++override CFLAGS+= \ ++ -I../../f2fs-tools/include \ ++ -I../../f2fs-tools/mkfs \ ++ -I../../core/libsparse/include \ ++ -I../../libselinux/include \ ++ -Wno-unused-parameter ++ ++OBJS= $(SRCS:.c=.o) ++ ++BIN= libf2fs.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.c ++ $(CC) -c $< $(CFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) ++ ++ +diff --git extras/f2fs_utils/f2fs_utils.c extras/f2fs_utils/f2fs_utils.c +index 6254c08..05ec599 100644 +--- extras/f2fs_utils/f2fs_utils.c ++++ extras/f2fs_utils/f2fs_utils.c +@@ -53,7 +53,7 @@ static void reset_f2fs_info() { + config.fd = -1; + if (f2fs_sparse_file) { + sparse_file_destroy(f2fs_sparse_file); +- f2fs_sparse_file = NULL; ++ f2fs_sparse_file = 0; + } + } + +@@ -73,6 +73,6 @@ int make_f2fs_sparse_fd(int fd, long long len, + sparse_file_write(f2fs_sparse_file, fd, /*gzip*/0, /*sparse*/1, /*crc*/0); + sparse_file_destroy(f2fs_sparse_file); + flush_sparse_buffs(); +- f2fs_sparse_file = NULL; ++ f2fs_sparse_file = 0; + return 0; + } +diff --git libselinux/Makefile libselinux/Makefile +new file mode 100644 +index 0000000..52ef5cc +--- /dev/null ++++ libselinux/Makefile +@@ -0,0 +1,31 @@ ++SRCS+= \ ++ src/callbacks.c \ ++ src/check_context.c \ ++ src/freecon.c \ ++ src/init.c \ ++ src/label.c \ ++ src/label_file.c \ ++ src/label_android_property.c \ ++ src/label_support.c ++ ++override CFLAGS+= -I./include ++ ++OBJS= $(SRCS:.c=.o) ++ ++BIN= libselinux.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.c ++ $(CC) -c $< $(CFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) +diff --git gtest/Makefile gtest/Makefile +new file mode 100644 +index 0000000..49a50aa +--- /dev/null ++++ gtest/Makefile +@@ -0,0 +1,36 @@ ++SRCS+= \ ++ src/gtest-all.cc \ ++ src/gtest-filepath.cc \ ++ src/gtest-printers.cc \ ++ src/gtest-typed-test.cc \ ++ src/gtest_main.cc \ ++ src/gtest-death-test.cc \ ++ src/gtest-port.cc \ ++ src/gtest-test-part.cc \ ++ src/gtest.cc ++ ++ ++override CXXFLAGS+= \ ++ -I./include \ ++ -I. ++ ++OBJS= $(SRCS:.cc=.o) ++ ++BIN= libgtest.a ++ ++all: $(BIN) ++ ++$(BIN): $(OBJS) ++ $(AR) rcs $@ $(OBJS) ++ ++%.o: %.cc ++ $(CXX) -c $< $(CXXFLAGS) -o $@ ++ ++.PHONY: clean mrproper ++ ++clean: ++ rm -rf $(OBJS) ++ ++mrproper: clean ++ rm -rf $(BIN) ++ diff --git a/testing/android-tools/fix-build.patch b/testing/android-tools/fix-build.patch deleted file mode 100644 index d86ad54e5e..0000000000 --- a/testing/android-tools/fix-build.patch +++ /dev/null @@ -1,69 +0,0 @@ ---- a/core/base/file.cpp -+++ b/core/base/file.cpp -@@ -20,6 +20,7 @@ - #include <fcntl.h> - #include <sys/stat.h> - #include <sys/types.h> -+#include <string.h> - - #include <string> - ---- a/core/liblog/log_read.c -+++ b/core/liblog/log_read.c -@@ -26,6 +26,7 @@ - #include <string.h> - #include <sys/cdefs.h> - #include <unistd.h> -+#include <sys/user.h> - - #include <cutils/list.h> - #include <cutils/sockets.h> - ---- a/libselinux/src/label_internal.h -+++ b/libselinux/src/label_internal.h -@@ -10,6 +10,7 @@ - - #include <stdlib.h> - #include <stdarg.h> -+#include <stdbool.h> - #include <selinux/selinux.h> - #include <selinux/label.h> - #include "dso.h" -diff -upr core.orig/include/utils/Compat.h core/include/utils/Compat.h ---- a/core/include/utils/Compat.h 2016-07-10 15:30:25.935363345 +0200 -+++ b/core/include/utils/Compat.h 2016-07-10 15:31:01.785149166 +0200 -@@ -35,10 +35,11 @@ static inline ssize_t pread64(int fd, vo - - #endif /* __APPLE__ */ - -+#define DEFFILEMODE 0666 -+ - #if defined(_WIN32) - #define O_CLOEXEC O_NOINHERIT - #define O_NOFOLLOW 0 --#define DEFFILEMODE 0666 - #endif /* _WIN32 */ - - #if defined(_WIN32) -diff -upr core/adb/adb_auth_host.cpp core.orig/adb/adb_auth_host.cpp ---- a/core/adb/adb_auth_host.cpp 2016-04-22 04:11:37.000000000 +0200 -+++ b/core/adb/adb_auth_host.cpp 2016-07-10 20:28:54.553727489 +0200 -@@ -46,6 +46,7 @@ - #include <base/strings.h> - #include <cutils/list.h> - -+#include <openssl/bn.h> - #include <openssl/evp.h> - #include <openssl/objects.h> - #include <openssl/pem.h> -diff -upr core.orig/include/ziparchive/zip_archive.h core/include/ziparchive/zip_archive.h ---- a/core/include/ziparchive/zip_archive.h 2016-07-10 20:41:30.509065561 +0200 -+++ b/core/include/ziparchive/zip_archive.h 2016-07-10 20:41:47.117424874 +0200 -@@ -23,6 +23,7 @@ - #include <stdint.h> - #include <string.h> - #include <sys/types.h> -+#include <sys/cdefs.h> - #include <utils/Compat.h> - - __BEGIN_DECLS diff --git a/testing/android-tools/fix-getcwd.patch b/testing/android-tools/fix-getcwd.patch deleted file mode 100644 index d96ab42523..0000000000 --- a/testing/android-tools/fix-getcwd.patch +++ /dev/null @@ -1,36 +0,0 @@ -diff -upr core.orig/adb/adb_utils.cpp core/adb/adb_utils.cpp ---- a/core.orig/adb/adb_utils.cpp 2016-07-10 15:17:54.889682995 +0200 -+++ b/core/adb/adb_utils.cpp 2016-07-10 15:18:04.338747965 +0200 -@@ -30,7 +30,7 @@ - #include "adb_trace.h" - #include "sysdeps.h" - --bool getcwd(std::string* s) { -+bool agetcwd(std::string* s) { - char* cwd = getcwd(nullptr, 0); - if (cwd != nullptr) *s = cwd; - free(cwd); -diff -upr core.orig/adb/commandline.cpp core/adb/commandline.cpp ---- a/core.orig/adb/commandline.cpp 2016-07-10 15:17:54.889682995 +0200 -+++ b/core/adb/commandline.cpp 2016-07-10 15:18:11.671355701 +0200 -@@ -863,7 +863,7 @@ static std::string find_product_out_path - // make it absolute. - if (adb_dirstart(hint) != nullptr) { - std::string cwd; -- if (!getcwd(&cwd)) { -+ if (!agetcwd(&cwd)) { - fprintf(stderr, "adb: getcwd failed: %s\n", strerror(errno)); - return ""; - } -diff -upr core.orig/adb/adb_utils.h core/adb/adb_utils.h ---- a/core.orig/adb/adb_utils.h 2016-07-10 15:21:09.327109127 +0200 -+++ b/core/adb/adb_utils.h 2016-07-10 15:21:18.272890564 +0200 -@@ -19,7 +19,7 @@ - - #include <string> - --bool getcwd(std::string* cwd); -+bool agetcwd(std::string* cwd); - bool directory_exists(const std::string& path); - - std::string escape_arg(const std::string& s); diff --git a/testing/android-tools/generate-build.rb b/testing/android-tools/generate-build.rb deleted file mode 100644 index 448b23da03..0000000000 --- a/testing/android-tools/generate-build.rb +++ /dev/null @@ -1,172 +0,0 @@ -#!/usr/bin/ruby -# Copied from the archlinux android-tools PKGBUILD. - -# Android build system is complicated and does not allow to build -# separate parts easily. -# This script tries to mimic Android build rules. - -def expand(dir, files) - files.map{|f| File.join(dir,f)} -end - -# Compiles sources to *.o files. -# Returns array of output *.o filenames -def compile(sources, cflags) - outputs = [] - for s in sources - ext = File.extname(s) - - case ext - when '.c' - cc = 'gcc' - lang_flags = '-std=gnu11 $CFLAGS $CPPFLAGS' - when '.cpp', '.cc' - cc = 'g++' - lang_flags = '-std=gnu++11 $CXXFLAGS $CPPFLAGS' - else - raise "Unknown extension #{ext}" - end - - output = s + '.o' - outputs << output - puts "#{cc} -o #{output} #{lang_flags} #{cflags} -c #{s}\n" - end - - return outputs -end - -# Links object files -def link(output, objects, ldflags) - puts "g++ -o #{output} #{objects.join(' ')} #{ldflags} $LDFLAGS" -end - -minicryptfiles = %w( - dsa_sig.c - p256_ec.c - rsa.c - sha.c - p256.c - p256_ecdsa.c - sha256.c -) -libminicrypt = compile(expand('core/libmincrypt', minicryptfiles), '-Icore/include') -libmkbootimg = compile(['core/mkbootimg/mkbootimg.c'], '-Icore/include') -link('mkbootimg', libminicrypt + libmkbootimg, nil) - - -adbdfiles = %w( - adb.cpp - adb_auth.cpp - adb_io.cpp - adb_listeners.cpp - adb_utils.cpp - sockets.cpp - transport.cpp - transport_local.cpp - transport_usb.cpp - - fdevent.cpp - get_my_path_linux.cpp - usb_linux.cpp - - adb_auth_host.cpp -) -libadbd = compile(expand('core/adb', adbdfiles), '-DADB_HOST=1 -fpermissive -Icore/include -Icore/base/include') - -adbfiles = %w( - adb_main.cpp - console.cpp - commandline.cpp - adb_client.cpp - services.cpp - file_sync_client.cpp -) -libadb = compile(expand('core/adb', adbfiles), '-DADB_REVISION=\"$PKGVER\" -D_GNU_SOURCE -DADB_HOST=1 -DWORKAROUND_BUG6558362 -fpermissive -Icore/include -Icore/base/include') - -basefiles = %w( - file.cpp - stringprintf.cpp - strings.cpp -) -libbase = compile(expand('core/base', basefiles), '-DADB_HOST=1 -Icore/base/include -Icore/include') - -logfiles = %w( - logd_write.c - log_event_write.c - fake_log_device.c -) -liblog = compile(expand('core/liblog', logfiles), '-DLIBLOG_LOG_TAG=1005 -DFAKE_LOG_DEVICE=1 -D_GNU_SOURCE -Icore/log/include -Icore/include') - -cutilsfiles = %w( - load_file.c - socket_inaddr_any_server.c - socket_local_client.c - socket_local_server.c - socket_loopback_client.c - socket_loopback_server.c - socket_network_client.c -) -libcutils = compile(expand('core/libcutils', cutilsfiles), '-D_GNU_SOURCE -Icore/include') - -link('adb', libbase + liblog + libcutils + libadbd + libadb, '-lrt -ldl -lpthread -lssl -lcrypto') - - -fastbootfiles = %w( - protocol.c - engine.c - bootimg_utils.cpp - fastboot.cpp - util.c - fs.c - usb_linux.c - util_linux.c -) -libfastboot = compile(expand('core/fastboot', fastbootfiles), '-DFASTBOOT_REVISION=\"$PKGVER\" -D_GNU_SOURCE -Icore/include -Icore/libsparse/include -Icore/mkbootimg -Iextras/ext4_utils -Iextras/f2fs_utils') - -sparsefiles = %w( - backed_block.c - output_file.c - sparse.c - sparse_crc32.c - sparse_err.c - sparse_read.c -) -libsparse = compile(expand('core/libsparse', sparsefiles), '-Icore/libsparse/include') - -zipfiles = %w( - zip_archive.cc -) -libzip = compile(expand('core/libziparchive', zipfiles), '-Icore/base/include -Icore/include') - -utilfiles = %w( - FileMap.cpp -) -libutil = compile(expand('core/libutils', utilfiles), '-Icore/include') - -ext4files = %w( - make_ext4fs.c - ext4fixup.c - ext4_utils.c - allocate.c - contents.c - extent.c - indirect.c - sha1.c - wipe.c - crc16.c - ext4_sb.c -) -libext4 = compile(expand('extras/ext4_utils', ext4files), '-Icore/libsparse/include -Icore/include -Ilibselinux/include') - -selinuxfiles = %w( - src/callbacks.c - src/check_context.c - src/freecon.c - src/init.c - src/label.c - src/label_file.c - src/label_android_property.c -) -libselinux = compile(expand('libselinux', selinuxfiles), '-DAUDITD_LOG_TAG=1003 -D_GNU_SOURCE -DHOST -Ilibselinux/include') - -link('fastboot', libsparse + libzip + liblog + libutil + libbase + libext4 + libselinux + libfastboot, '-lz -lpcre') diff --git a/testing/android-tools/musl-fixes.patch b/testing/android-tools/musl-fixes.patch new file mode 100644 index 0000000000..4c093ce918 --- /dev/null +++ b/testing/android-tools/musl-fixes.patch @@ -0,0 +1,164 @@ +This patch has been taken from the Void Linux distribution. + +https://github.com/voidlinux/void-packages/tree/master/srcpkgs/android-tools/patches/android-tools-musl.patch + +diff --git core/include/ziparchive/zip_archive.h core/include/ziparchive/zip_archive.h +index 7dc60ae..8886a35 100644 +--- core/include/ziparchive/zip_archive.h ++++ core/include/ziparchive/zip_archive.h +@@ -22,11 +22,12 @@ + + #include <stdint.h> + #include <string.h> +-#include <sys/cdefs.h> + #include <sys/types.h> + #include <utils/Compat.h> + +-__BEGIN_DECLS ++#ifdef __cplusplus ++extern "C" { ++#endif + + /* Zip compression methods we support */ + enum { +@@ -215,6 +216,8 @@ int GetFileDescriptor(const ZipArchiveHandle handle); + + const char* ErrorCodeString(int32_t error_code); + +-__END_DECLS ++#ifdef __cplusplus ++} ++#endif + + #endif // LIBZIPARCHIVE_ZIPARCHIVE_H_ +diff --git core/liblog/log_portability.h core/liblog/log_portability.h +index 3ad2060..2b859c4 100644 +--- core/liblog/log_portability.h ++++ core/liblog/log_portability.h +@@ -17,7 +17,6 @@ + #ifndef _LIBLOG_PORTABILITY_H__ + #define _LIBLOG_PORTABILITY_H__ + +-#include <sys/cdefs.h> + #include <unistd.h> + + /* Helpful private sys/cdefs.h like definitions */ + +diff --git core/include/private/android_filesystem_config.h core/include/private/android_filesystem_config.h +index c220a0c..d38f971 100644 +--- core/include/private/android_filesystem_config.h ++++ core/include/private/android_filesystem_config.h +@@ -22,7 +22,6 @@ + #ifndef _ANDROID_FILESYSTEM_CONFIG_H_ + #define _ANDROID_FILESYSTEM_CONFIG_H_ + +-#include <sys/cdefs.h> + #include <sys/types.h> + #include <stdint.h> + +@@ -230,7 +229,10 @@ struct fs_path_config { + + /* Rules for directories and files has moved to system/code/libcutils/fs_config.c */ + +-__BEGIN_DECLS ++#ifdef __cplusplus ++extern "C" { ++#endif ++ + + /* + * Used in: +@@ -247,7 +249,9 @@ void fs_config(const char *path, int dir, const char *target_out_path, + + ssize_t fs_config_generate(char *buffer, size_t length, const struct fs_path_config *pc); + +-__END_DECLS ++#ifdef __cplusplus ++} ++#endif + + #endif + #endif +diff --git core/base/file.cpp core/base/file.cpp +index da1adba..7ba6d23 100644 +--- core/base/file.cpp ++++ core/base/file.cpp +@@ -111,7 +111,7 @@ bool WriteStringToFile(const std::string& content, const std::string& path, + + bool WriteStringToFile(const std::string& content, const std::string& path) { + int flags = O_WRONLY | O_CREAT | O_TRUNC | O_CLOEXEC | O_NOFOLLOW | O_BINARY; +- int fd = TEMP_FAILURE_RETRY(open(path.c_str(), flags, DEFFILEMODE)); ++ int fd = TEMP_FAILURE_RETRY(open(path.c_str(), flags, (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH))); + if (fd == -1) { + return false; + } +diff --git core/adb/sysdeps.h core/adb/sysdeps.h +index 75dcc86..2dba172 100644 +--- core/adb/sysdeps.h ++++ core/adb/sysdeps.h +@@ -757,18 +757,7 @@ static __inline__ int adb_thread_setname(const std::string& name) { + #ifdef __APPLE__ + return pthread_setname_np(name.c_str()); + #else +- const char *s = name.c_str(); +- +- // pthread_setname_np fails rather than truncating long strings. +- const int max_task_comm_len = 16; // including the null terminator +- if (name.length() > (max_task_comm_len - 1)) { +- char buf[max_task_comm_len]; +- strncpy(buf, name.c_str(), sizeof(buf) - 1); +- buf[sizeof(buf) - 1] = '\0'; +- s = buf; +- } +- +- return pthread_setname_np(pthread_self(), s) ; ++ return 0; + #endif + } + +diff --git core/adb/diagnose_usb.cpp core/adb/diagnose_usb.cpp +index 0f067b0..1138f8d 100644 +--- core/adb/diagnose_usb.cpp ++++ core/adb/diagnose_usb.cpp +@@ -32,28 +32,7 @@ static const char kPermissionsHelpUrl[] = "http://developer.android.com/tools/de + // Returns a message describing any potential problems we find with udev, or nullptr if we can't + // find plugdev information (i.e. udev is not installed). + static const char* GetUdevProblem() { +-#if defined(__linux__) +- errno = 0; +- group* plugdev_group = getgrnam("plugdev"); +- +- if (plugdev_group == nullptr) { +- if (errno != 0) { +- perror("failed to read plugdev group info"); +- } +- // We can't give any generally useful advice here, just let the caller print the help URL. +- return nullptr; +- } +- +- // getgroups(2) indicates that the group_member() may not check the egid so we check it +- // additionally just to be sure. +- if (group_member(plugdev_group->gr_gid) || getegid() == plugdev_group->gr_gid) { +- // The user is in plugdev so the problem is likely with the udev rules. +- return "verify udev rules"; +- } +- return "udev requires plugdev group membership"; +-#else + return nullptr; +-#endif + } + + // Short help text must be a single line, and will look something like: +diff --git core/fastboot/socket.cpp core/fastboot/socket.cpp +index 14ecd93..aff905c 100644 +--- core/fastboot/socket.cpp ++++ core/fastboot/socket.cpp +@@ -31,6 +31,8 @@ + #include <android-base/errors.h> + #include <android-base/stringprintf.h> + ++#include <sys/select.h> ++ + Socket::Socket(cutils_socket_t sock) : sock_(sock) {} + + Socket::~Socket() { |