[tor-bugs] #33291 [Core Tor/Tor]: making the tor library size smaller
Tor Bug Tracker & Wiki
blackhole at torproject.org
Wed Feb 12 22:32:01 UTC 2020
#33291: making the tor library size smaller
--------------------------+------------------------
Reporter: gaba | Owner: (none)
Type: project | Status: new
Priority: Medium | Milestone:
Component: Core Tor/Tor | Version:
Severity: Normal | Resolution:
Keywords: | Actual Points:
Parent ID: | Points:
Reviewer: | Sponsor:
--------------------------+------------------------
Description changed by gaba:
Old description:
> Goal: To reduce the size of the tor library so that applications that
> are sensitive to download size can link it easily.
>
> Information from The Guardian Project on data from their "Orbot mini"
> app:
>
> {{{
> The Android APK for the arm 32-bit build is about 5MB. An APK is a JAR
> file, which is basically a ZIP file. This means everything gets
> compressed.
>
> Below, then you can see the version of Tor built into this (this is the
> old 0.4.0.4 without any of the more recent size optimizations) is almost
> 7MB. However, it is compressed 67%, ending up somewhere closer to 2.2MB
> in actual distribution form.
>
> Archive:
> Orbot-mini-mini-1.0.0-BETA-1-tor-0.4.0.4-rc-mini-armeabi-v7a-release.apk
> Zip file size: 4998235 bytes, number of entries: 623
>
> -rw---- 2.4 fat 6911768 b- 67% defN 80-000-00 00:00 lib/armeabi-
> v7a/tor.so
>
> Now, distribution size is thing for sure, the second is amount of space
> on disk when it is unpacked and running. Users of inexpensive phones
> with limited storage will often scroll through installed apps and look at
> actual storage size being used, and uninstall apps based on that. This
> means we should be concerned with both distribution size an runtime total
> storage use.
>
>
> }}}
> '''Possible routes'''
>
> 1. making different parts of tor more optional/modular (like relay mode,
> dirauth mode) . Did we try this before? Is this possible?
>
> 2. Is there a TLS stack you can link on android? Only in Java
>
> 3. A maybe sketchy possibility is to let google to optimize code in the
> cloud...
>
> 4. A small java implementation of core onion routing. Would applications
> be able to run it?
>
> * java ones, easily
> * other ones with some (considerable?) effort. JNI makes it possible,
> but not necessarily so easy.
>
> 5. libssl - 600kb is the shared library. The Guardian Project's
> experiments on making a smaller binary:
> __[https://github.com/guardianproject/tor-android/issues/18
> https://github.com/guardianproject/tor-android/issues/18]__
>
> Anything else?
New description:
Goal: To reduce the size of the tor library so that applications that are
sensitive to download size can link it easily.
Information from The Guardian Project on data from their "Orbot mini" app:
{{{
The Android APK for the arm 32-bit build is about 5MB. An APK is a JAR
file, which is basically a ZIP file. This means everything gets
compressed.
Below, then you can see the version of Tor built into this (this is the
old 0.4.0.4 without any of the more recent size optimizations) is almost
7MB. However, it is compressed 67%, ending up somewhere closer to 2.2MB
in actual distribution form.
Archive:
Orbot-mini-mini-1.0.0-BETA-1-tor-0.4.0.4-rc-mini-armeabi-v7a-release.apk
Zip file size: 4998235 bytes, number of entries: 623
-rw---- 2.4 fat 6911768 b- 67% defN 80-000-00 00:00 lib/armeabi-
v7a/tor.so
Now, distribution size is thing for sure, the second is amount of space on
disk when
it is unpacked and running. Users of inexpensive phones with limited
storage will often
scroll through installed apps and look at actual storage size being used,
and uninstall
apps based on that. This means we should be concerned with both
distribution size an
runtime total storage use.
}}}
'''Possible routes'''
1. making different parts of tor more optional/modular (like relay mode,
dirauth mode) . Did we try this before? Is this possible?
2. Is there a TLS stack you can link on android? Only in Java
3. A maybe sketchy possibility is to let google to optimize code in the
cloud...
4. A small java implementation of core onion routing. Would applications
be able to run it?
* java ones, easily
* other ones with some (considerable?) effort. JNI makes it possible, but
not necessarily so easy.
5. libssl - 600kb is the shared library. The Guardian Project's
experiments on making a smaller binary:
__[https://github.com/guardianproject/tor-android/issues/18
https://github.com/guardianproject/tor-android/issues/18]__
Anything else?
--
--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/33291#comment:2>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online
More information about the tor-bugs
mailing list