-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathREADME.android
74 lines (54 loc) · 2.68 KB
/
README.android
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
Overview
========
This version of libusb has been modified to work on Android. Besides some build
changes, the buggest addition is that libusb now tries to use Android's Java
USB host API to open the the devices, which means it will be able to
successfully open them, even if the application is running as non-root (which
they usually do).
This modification is not perfect, read the Caveats section before using it.
Building and using
==================
To build libusb for Android, you use the usual configure/make machinery,
however, there's a build script in the 'android' directory, which simplifies
the job. To use it, prepare Android standalone toolchains for the
architectures that you want to build for (see STANDALONE-TOOLCHAIN.html
in Android NDK documentation for how to do this).
Run the autogen script in the source root to prepare the necessary files.
Afterwards, you can run "make distclean" to remove files you won't need.
Then, make sure the cross-compilers (e.g. arm-linux-androideabi-gcc)
are in your PATH, and run build.sh in the 'android' directory one or more
times, passing it the name of the architecture to build for, e.g.:
./build.sh armeabi
./build.sh armeabi-v7a
./build.sh mips
./build.sh x86
Naturally, you don't need to run the script for all available architectures,
but only for those you want to build for.
This will build the libraries and place them into
'android/ndk-modules/libusb-1.0'.
If you're using ndk-build as your build system, you can use libusb by adding
the 'android/ndk-modules' directory to your NDK_MODULE_PATH environment
variable, and then appending:
$(call import-module,libusb-1.0)
to your Android.mk file.
Caveats
=======
For this version of libusb to work, several other requirements must be
fulfilled:
1) Include the org.libusb.UsbHelper class from the 'android/LibusbSupport'
directory in your application. The directory is also usable as an Android
library project.
2) Have an application class (see
<http://developer.android.com/reference/android/app/Application.html>).
In that class's onCreate(), put the following line:
UsbHelper.useContext(getApplicationContext());
3) You must load libusb into the JVM before using it (for example, in the
application class):
System.loadLibrary("usb-1.0")
4) Beware: libusb will open a USB device if the application's user has given
permission to do so; however, it will not ask for that permission! It is
impossible for it to do so, since libusb_open is synchronous, and
android.hardware.usb.UsbManager.requestPermission is not. You must request
this permission yourself; see
<http://developer.android.com/guide/topics/connectivity/usb/host.html#permission-d>
for details.