proot: Build next branch instead of master
authorFredrik Fornwall <fredrik@fornwall.net>
Tue, 22 Mar 2016 01:08:37 +0000 (21:08 -0400)
committerFredrik Fornwall <fredrik@fornwall.net>
Tue, 22 Mar 2016 01:08:37 +0000 (21:08 -0400)
This fixes aarch64 to work.

disabled-packages/proot/build.sh
disabled-packages/proot/src-arch.h.patch [deleted file]
disabled-packages/proot/src-cli-cli.c.patch
disabled-packages/proot/src-loader-assemble-arm64.h.patch [deleted file]
disabled-packages/proot/src-loader-loader.c.patch [deleted file]
disabled-packages/proot/src-syscall-rlimit.c.patch [new file with mode: 0644]

index e75b942..f2f0587 100644 (file)
@@ -1,8 +1,8 @@
 TERMUX_PKG_HOMEPAGE=http://proot.me/
 TERMUX_PKG_DESCRIPTION="Emulate chroot, bind mount and binfmt_misc for non-root users"
-TERMUX_PKG_VERSION=5.1.0
-TERMUX_PKG_SRCURL=https://github.com/proot-me/PRoot/archive/v${TERMUX_PKG_VERSION}.tar.gz
-TERMUX_PKG_FOLDERNAME=PRoot-${TERMUX_PKG_VERSION}
+TERMUX_PKG_VERSION=5.1.99
+TERMUX_PKG_SRCURL=https://github.com/proot-me/PRoot/archive/next.zip
+TERMUX_PKG_FOLDERNAME=PRoot-next
 TERMUX_PKG_DEPENDS="libtalloc"
 
 export LD=$CC
diff --git a/disabled-packages/proot/src-arch.h.patch b/disabled-packages/proot/src-arch.h.patch
deleted file mode 100644 (file)
index 8447f6b..0000000
+++ /dev/null
@@ -1,15 +0,0 @@
-From https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=788113
-
-diff -u -r ../PRoot-5.1.0/src/arch.h ./src/arch.h
---- ../PRoot-5.1.0/src/arch.h  2014-12-15 09:18:11.000000000 -0500
-+++ ./src/arch.h       2016-01-08 19:53:23.789378336 -0500
-@@ -125,6 +125,9 @@
-     #define OFFSETOF_STAT_UID_32 0
-     #define OFFSETOF_STAT_GID_32 0
-+    #define EXEC_PIC_ADDRESS   0x500000000000
-+    #define INTERP_PIC_ADDRESS 0x6f0000000000
-+
- #elif defined(ARCH_X86)
-     #define SYSNUMS_HEADER1 "syscall/sysnums-i386.h"
index a6f34c1..3e15b69 100644 (file)
@@ -1,10 +1,11 @@
 diff -u -r ../PRoot-5.1.0/src/cli/cli.c ./src/cli/cli.c
 --- ../PRoot-5.1.0/src/cli/cli.c       2014-12-15 09:18:11.000000000 -0500
 +++ ./src/cli/cli.c    2016-01-08 15:16:33.393030857 -0500
-@@ -30,7 +30,9 @@
+@@ -30,7 +30,10 @@
  #include <sys/types.h>     /* getpid(2),  */
  #include <unistd.h>        /* getpid(2),  */
  #include <errno.h>         /* errno(3), */
++#include <libgen.h>        /* basename(3), */
 +#ifndef __ANDROID__
  #include <execinfo.h>      /* backtrace_symbols(3), */
 +#endif
diff --git a/disabled-packages/proot/src-loader-assemble-arm64.h.patch b/disabled-packages/proot/src-loader-assemble-arm64.h.patch
deleted file mode 100644 (file)
index 9c8d2c0..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-See https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=788113
-
-diff -N -u -r ../PRoot-5.1.0/src/loader/assemble-arm64.h ./src/loader/assemble-arm64.h
---- ../PRoot-5.1.0/src/loader/assembly-arm64.h 1969-12-31 19:00:00.000000000 -0500
-+++ ./src/loader/assembly-arm64.h      2016-01-08 20:12:46.494779723 -0500
-@@ -0,0 +1,93 @@
-+/* -*- c-set-style: "K&R"; c-basic-offset: 8 -*-
-+ *
-+ * This file is part of PRoot.
-+ *
-+ * Copyright (C) 2014 STMicroelectronics
-+ *
-+ * This program is free software; you can redistribute it and/or
-+ * modify it under the terms of the GNU General Public License as
-+ * published by the Free Software Foundation; either version 2 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
-+ * General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU General Public License
-+ * along with this program; if not, write to the Free Software
-+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
-+ * 02110-1301 USA.
-+ */
-+
-+#define BRANCH(stack_pointer, destination) do {                       \
-+      asm volatile (                                          \
-+              "// Restore initial stack pointer.      \n\t"   \
-+              "mov sp, %0                             \n\t"   \
-+              "                                       \n\t"   \
-+              "// Clear rtld_fini.                    \n\t"   \
-+              "mov x0, #0                             \n\t"   \
-+              "                                       \n\t"   \
-+              "// Start the program.                  \n\t"   \
-+              "br %1                                  \n"     \
-+              : /* no output */                               \
-+              : "r" (stack_pointer), "r" (destination)        \
-+              : "memory", "sp", "x0");                        \
-+      __builtin_unreachable();                                \
-+      } while (0)
-+
-+#define PREPARE_ARGS_1(arg1_)                         \
-+      register word_t arg1 asm("x0") = arg1_;         \
-+
-+#define PREPARE_ARGS_3(arg1_, arg2_, arg3_)           \
-+      PREPARE_ARGS_1(arg1_)                           \
-+      register word_t arg2 asm("x1") = arg2_;         \
-+      register word_t arg3 asm("x2") = arg3_;         \
-+
-+#define PREPARE_ARGS_4(arg1_, arg2_, arg3_, arg4_)    \
-+      PREPARE_ARGS_3(arg1_, arg2_, arg3_)             \
-+      register word_t arg4 asm("x3") = arg4_;
-+
-+#define PREPARE_ARGS_6(arg1_, arg2_, arg3_, arg4_, arg5_, arg6_)      \
-+      PREPARE_ARGS_3(arg1_, arg2_, arg3_)                             \
-+      register word_t arg4 asm("x3") = arg4_;                         \
-+      register word_t arg5 asm("x4") = arg5_;                         \
-+      register word_t arg6 asm("x5") = arg6_;
-+
-+#define OUTPUT_CONTRAINTS_1                   \
-+      "r" (arg1)
-+
-+#define OUTPUT_CONTRAINTS_3                   \
-+      OUTPUT_CONTRAINTS_1,                    \
-+      "r" (arg2), "r" (arg3)
-+
-+#define OUTPUT_CONTRAINTS_4                   \
-+      OUTPUT_CONTRAINTS_3,                    \
-+      "r" (arg4)
-+
-+#define OUTPUT_CONTRAINTS_6                           \
-+      OUTPUT_CONTRAINTS_3,                            \
-+      "r" (arg4), "r" (arg5), "r" (arg6)
-+
-+#define SYSCALL(number_, nb_args, args...)                    \
-+      ({                                                      \
-+              register word_t number asm("w8") = number_;     \
-+              register word_t result asm("x0");               \
-+              PREPARE_ARGS_##nb_args(args)                    \
-+                      asm volatile (                          \
-+                              "svc #0x00000000        \n\t"   \
-+                              : "=r" (result)                 \
-+                              : "r" (number),                 \
-+                              OUTPUT_CONTRAINTS_##nb_args     \
-+                              : "memory");                    \
-+                      result;                                 \
-+      })
-+
-+#define OPENAT        56
-+#define CLOSE 57
-+#define MMAP  222
-+#define MMAP_OFFSET_SHIFT 0
-+#define EXECVE        221
-+#define EXIT  93
-+#define PRCTL 167
-+
diff --git a/disabled-packages/proot/src-loader-loader.c.patch b/disabled-packages/proot/src-loader-loader.c.patch
deleted file mode 100644 (file)
index a8a5e2a..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-See https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=788113
-
-diff -N -u -r ../PRoot-5.1.0/src/loader/loader.c ./src/loader/loader.c
---- ../PRoot-5.1.0/src/loader/loader.c 2014-12-15 09:18:11.000000000 -0500
-+++ ./src/loader/loader.c      2016-01-08 20:16:54.746809929 -0500
-@@ -39,6 +39,8 @@
- #    include "loader/assembly-x86_64.h"
- #elif defined(ARCH_ARM_EABI)
- #    include "loader/assembly-arm.h"
-+#elif defined(ARCH_ARM64)
-+#    include "loader/assembly-arm64.h"
- #elif defined(ARCH_X86)
- #    include "loader/assembly-x86.h"
- #else
-@@ -134,7 +136,11 @@
-                       /* Fall through.  */
-               case LOAD_ACTION_OPEN:
-+#ifdef OPENAT
-+                      fd = SYSCALL(OPENAT, 4, AT_FDCWD, stmt->open.string_address, O_RDONLY, 0);
-+#else
-                       fd = SYSCALL(OPEN, 3, stmt->open.string_address, O_RDONLY, 0);
-+#endif
-                       if (unlikely((int) fd < 0))
-                               FATAL();
diff --git a/disabled-packages/proot/src-syscall-rlimit.c.patch b/disabled-packages/proot/src-syscall-rlimit.c.patch
new file mode 100644 (file)
index 0000000..26596d2
--- /dev/null
@@ -0,0 +1,32 @@
+On 32-bit prlimit() does not exist. prlimit64 however exists on both.
+
+diff -u -r ../PRoot-next/src/syscall/rlimit.c ./src/syscall/rlimit.c
+--- ../PRoot-next/src/syscall/rlimit.c 2015-07-23 15:50:10.000000000 -0400
++++ ./src/syscall/rlimit.c     2016-03-21 20:29:49.544175830 -0400
+@@ -58,7 +58,7 @@
+  */
+ int translate_setrlimit_exit(const Tracee *tracee, bool is_prlimit)
+ {
+-      struct rlimit proot_stack;
++      struct rlimit64 proot_stack;
+       word_t resource;
+       word_t address;
+       word_t tracee_stack_limit;
+@@ -94,7 +94,7 @@
+               return -errno;
+       /* Get current PRoot's stack limit.  */
+-      status = prlimit(0, RLIMIT_STACK, NULL, &proot_stack);
++      status = prlimit64(0, RLIMIT_STACK, NULL, &proot_stack);
+       if (status < 0) {
+               VERBOSE(tracee, 1, "can't get stack limit.");
+               return 0; /* Not fatal.  */
+@@ -107,7 +107,7 @@
+       proot_stack.rlim_cur = tracee_stack_limit;
+       /* Increase current PRoot's stack limit.  */
+-      status = prlimit(0, RLIMIT_STACK, &proot_stack, NULL);
++      status = prlimit64(0, RLIMIT_STACK, &proot_stack, NULL);
+       if (status < 0)
+               VERBOSE(tracee, 1, "can't set stack limit.");
+       return 0; /* Not fatal.  */