Skip to content

Commit

Permalink
JNI patches for anon-android (#103)
Browse files Browse the repository at this point in the history
Co-authored-by: Hans-Christoph Steiner <[email protected]>
Co-authored-by: Torsten Grote <[email protected]>
  • Loading branch information
3 people authored Oct 25, 2024
1 parent fab3589 commit 1beafad
Show file tree
Hide file tree
Showing 12 changed files with 615 additions and 2 deletions.
7 changes: 7 additions & 0 deletions changes/ticket31882
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
o Minor feature (configure, build system):
- The standard __ANDROID__ macro is now used for platform detection.
- --enable-android provides the standard, minimal build configuration
for creating Tor binaries to run either as a shared library or a daemon.
It enables PIC, disables system torrc, systemd, and all doc generation.
This flag is not required to build for Android.
Closes ticket 31882.
19 changes: 19 additions & 0 deletions configure.ac
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,8 @@ AC_ARG_ENABLE(nss,
AS_HELP_STRING(--enable-nss, [Use Mozilla's NSS TLS library. (EXPERIMENTAL)]))
AC_ARG_ENABLE(pic,
AS_HELP_STRING(--enable-pic, [Build Anon's binaries as position-independent code, suitable to link as a library.]))
AC_ARG_ENABLE(jni,
AS_HELP_STRING(--enable-jni, [enable Java JNI API feature]))

AC_ARG_ENABLE(missing-doc-warnings,
AS_HELP_STRING(--enable-missing-doc-warnings, [Tell doxygen to warn about missing documentation. Makes doxygen warnings nonfatal.]))
Expand Down Expand Up @@ -1819,6 +1821,23 @@ AC_CHECK_TYPES([rlim_t], , ,
#endif
])

if test "x$enable_jni" = "xyes"; then
AX_JNI_INCLUDE_DIR
if test -n "$JNI_INCLUDE_DIRS"; then
AC_DEFINE(HAVE_JNI_H,1,[Have jni.h])
for JNI_INCLUDE_DIR in $JNI_INCLUDE_DIRS; do
CPPFLAGS="$CPPFLAGS -I$JNI_INCLUDE_DIR"
done
fi
dnl Enable Android only standard libs
case "$host" in
*android*)
AC_CHECK_LIB([log], [__android_log_write], [LIBS="-llog $LIBS"])
;;
esac
fi
AM_CONDITIONAL(USE_JNI, test -n "$JNI_INCLUDE_DIRS")

AX_CHECK_SIGN([time_t],
[ : ],
[ : ], [
Expand Down
151 changes: 151 additions & 0 deletions m4/ax_jni_include_dir.m4
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
# ===========================================================================
# https://www.gnu.org/software/autoconf-archive/ax_jni_include_dir.html
# ===========================================================================
#
# SYNOPSIS
#
# AX_JNI_INCLUDE_DIR
#
# DESCRIPTION
#
# AX_JNI_INCLUDE_DIR finds include directories needed for compiling
# programs using the JNI interface.
#
# JNI include directories are usually in the Java distribution. This is
# deduced from the value of $JAVA_HOME, $JAVAC, or the path to "javac", in
# that order. When this macro completes, a list of directories is left in
# the variable JNI_INCLUDE_DIRS.
#
# Example usage follows:
#
# AX_JNI_INCLUDE_DIR
#
# for JNI_INCLUDE_DIR in $JNI_INCLUDE_DIRS
# do
# CPPFLAGS="$CPPFLAGS -I$JNI_INCLUDE_DIR"
# done
#
# If you want to force a specific compiler:
#
# - at the configure.in level, set JAVAC=yourcompiler before calling
# AX_JNI_INCLUDE_DIR
#
# - at the configure level, setenv JAVAC
#
# This macro depends on AC_CANONICAL_HOST which requires that config.guess
# and config.sub be distributed along with the source code. See autoconf
# manual for details.
#
# Note: This macro can work with the autoconf M4 macros for Java programs.
# This particular macro is not part of the original set of macros.
#
# LICENSE
#
# Copyright (c) 2008 Don Anderson <[email protected]>
#
# Copying and distribution of this file, with or without modification, are
# permitted in any medium without royalty provided the copyright notice
# and this notice are preserved. This file is offered as-is, without any
# warranty.

#serial 15

AU_ALIAS([AC_JNI_INCLUDE_DIR], [AX_JNI_INCLUDE_DIR])
AC_DEFUN([AX_JNI_INCLUDE_DIR],[
AC_REQUIRE([AC_CANONICAL_HOST])
JNI_INCLUDE_DIRS=""
if test "x$JAVA_HOME" != x; then
_JTOPDIR="$JAVA_HOME"
else
if test "x$JAVAC" = x; then
JAVAC=javac
fi
AC_PATH_PROG([_ACJNI_JAVAC], [$JAVAC], [no])
if test "x$_ACJNI_JAVAC" = xno; then
AC_MSG_ERROR([cannot find JDK; try setting \$JAVAC or \$JAVA_HOME])
fi
_ACJNI_FOLLOW_SYMLINKS("$_ACJNI_JAVAC")
_JTOPDIR=`echo "$_ACJNI_FOLLOWED" | sed -e 's://*:/:g' -e 's:/[[^/]]*$::'`
fi
case "$host_os" in
darwin*) # Apple Java headers are inside the Xcode bundle.
macos_version=$(sw_vers -productVersion | sed -n -e 's/^@<:@0-9@:>@*.\(@<:@0-9@:>@*\).@<:@0-9@:>@*/\1/p')
if @<:@ "$macos_version" -gt "7" @:>@; then
_JTOPDIR="$(xcrun --show-sdk-path)/System/Library/Frameworks/JavaVM.framework"
_JINC="$_JTOPDIR/Headers"
else
_JTOPDIR="/System/Library/Frameworks/JavaVM.framework"
_JINC="$_JTOPDIR/Headers"
fi
;;
*) _JINC="$_JTOPDIR/include";;
esac
_AS_ECHO_LOG([_JTOPDIR=$_JTOPDIR])
_AS_ECHO_LOG([_JINC=$_JINC])
# On Mac OS X 10.6.4, jni.h is a symlink:
# /System/Library/Frameworks/JavaVM.framework/Versions/Current/Headers/jni.h
# -> ../../CurrentJDK/Headers/jni.h.
AC_CACHE_CHECK(jni headers, ac_cv_jni_header_path,
[
if test -f "$_JINC/jni.h"; then
ac_cv_jni_header_path="$_JINC"
JNI_INCLUDE_DIRS="$JNI_INCLUDE_DIRS $ac_cv_jni_header_path"
else
_JTOPDIR=`echo "$_JTOPDIR" | sed -e 's:/[[^/]]*$::'`
if test -f "$_JTOPDIR/include/jni.h"; then
ac_cv_jni_header_path="$_JTOPDIR/include"
JNI_INCLUDE_DIRS="$JNI_INCLUDE_DIRS $ac_cv_jni_header_path"
else
ac_cv_jni_header_path=none
fi
fi
])
# get the likely subdirectories for system specific java includes
case "$host_os" in
bsdi*) _JNI_INC_SUBDIRS="bsdos";;
freebsd*) _JNI_INC_SUBDIRS="freebsd";;
darwin*) _JNI_INC_SUBDIRS="darwin";;
linux*) _JNI_INC_SUBDIRS="linux genunix";;
osf*) _JNI_INC_SUBDIRS="alpha";;
solaris*) _JNI_INC_SUBDIRS="solaris";;
mingw*) _JNI_INC_SUBDIRS="win32";;
cygwin*) _JNI_INC_SUBDIRS="win32";;
*) _JNI_INC_SUBDIRS="genunix";;
esac
if test "x$ac_cv_jni_header_path" != "xnone"; then
# add any subdirectories that are present
for JINCSUBDIR in $_JNI_INC_SUBDIRS
do
if test -d "$_JTOPDIR/include/$JINCSUBDIR"; then
JNI_INCLUDE_DIRS="$JNI_INCLUDE_DIRS $_JTOPDIR/include/$JINCSUBDIR"
fi
done
fi
])

# _ACJNI_FOLLOW_SYMLINKS <path>
# Follows symbolic links on <path>,
# finally setting variable _ACJNI_FOLLOWED
# ----------------------------------------
AC_DEFUN([_ACJNI_FOLLOW_SYMLINKS],[
# find the include directory relative to the javac executable
_cur="$1"
while ls -ld "$_cur" 2>/dev/null | grep " -> " >/dev/null; do
AC_MSG_CHECKING([symlink for $_cur])
_slink=`ls -ld "$_cur" | sed 's/.* -> //'`
case "$_slink" in
/*) _cur="$_slink";;
# 'X' avoids triggering unwanted echo options.
*) _cur=`echo "X$_cur" | sed -e 's/^X//' -e 's:[[^/]]*$::'`"$_slink";;
esac
AC_MSG_RESULT([$_cur])
done
_ACJNI_FOLLOWED="$_cur"
])# _ACJNI
2 changes: 1 addition & 1 deletion scripts/maint/checkSpace.pl
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,7 @@ sub msg {
msg "$&:$fn:$.\n";
}
if (/\bmalloc\(/ or /\bfree\(/ or /\brealloc\(/ or
/\bstrdup\(/ or /\bstrndup\(/ or /\bcalloc\(/) {
/\bstrndup\(/ or /\bcalloc\(/) {
msg "$&:$fn:$. (use tor_malloc, tor_free, etc)\n";
}
}
Expand Down
1 change: 0 additions & 1 deletion scripts/maint/checkspace_tests/expected.txt
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@
malloc(:./dubious.c:77 (use tor_malloc, tor_free, etc)
free(:./dubious.c:78 (use tor_malloc, tor_free, etc)
realloc(:./dubious.c:79 (use tor_malloc, tor_free, etc)
strdup(:./dubious.c:80 (use tor_malloc, tor_free, etc)
strndup(:./dubious.c:81 (use tor_malloc, tor_free, etc)
calloc(:./dubious.c:82 (use tor_malloc, tor_free, etc)
noguard:./dubious.h (No #ifndef/#define header guard pair found)
Expand Down
3 changes: 3 additions & 0 deletions src/app/main/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,9 @@
#include "core/or/connection_or.h"
#include "core/or/relay.h"
#include "core/or/status.h"
#ifdef HAVE_JNI_H
#include "feature/api/io_anyone_jni_AnonService.h"
#endif
#include "feature/api/tor_api.h"
#include "feature/api/tor_api_internal.h"
#include "feature/client/addressmap.h"
Expand Down
1 change: 1 addition & 0 deletions src/feature/api/.may_include
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
*.h
*.c
8 changes: 8 additions & 0 deletions src/feature/api/include.am
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,17 @@
LIBANON_APP_A_SOURCES += \
src/feature/api/tor_api.c

if USE_JNI
LIBANON_APP_A_SOURCES += src/feature/api/io_anyone_jni_AnonService.c
endif

# ADD_C_FILE: INSERT HEADERS HERE.
noinst_HEADERS += \
src/feature/api/tor_api_internal.h

# This may someday want to be an installed file?
noinst_HEADERS += src/feature/api/tor_api.h

if USE_JNI
noinst_HEADERS += src/feature/api/io_anyone_jni_AnonService.h
endif
Loading

0 comments on commit 1beafad

Please sign in to comment.