This is an old revision of the document!
The DTVKit Android Tuner HAL solution integrates DVBCore with Android using the Android TV Input Framework (TIF) and the Android Tuner Framework. By using the TIF and the Tuner Framework, manufacturers can provide a TV input source that new and existing apps, such as Live Channels, can use through a standard Android API.
The input source is built as an Android system application. It provides:
The TV input source uses parts of the companion library (Apache License 2.0), which can be found in the Android TV sample inputs project (the companion library is not used as a third-party library, but is copied into the project).
Our copy has a number of modifications. We have removed ads, XMLTV parsing, the template set up activity and the base TV input service (which has been replaced by our own implementation).
The repository can be cloned from Github and can be placed in the external
directory from the Android source tree.
1. Set up Android build environment
source build/envsetup.sh lunch BUILD_TARGET
2. Clone the DTVKit Android components and overlay DVBCore
cd $ANDROID_BUILD_TOP git clone https://github.com/DTVKit/Android_11_Reference external/dtvkit git clone https://github.com/DTVKit/DVBCore external/dtvkit/androidtunerlibrary/src/main/libs/dvbcore/DVBCore
3. Build androidtunerlibrary module and native library
mmm external/dtvkit -j8
4. Copy the built libraries into tis module as dependencies
cd external/dtvkit mkdir -p tis/libs cp $ANDROID_PRODUCT_OUT/obj/JAVA_LIBRARIES/androidtunerlibrary_intermediates/javalib.jar tis/libs/androidtunerlibrary.jar cp $ANDROID_PRODUCT_OUT/system/lib/libdvbglue.so tis/libs/libdvbglue.so
5. Build tis module (TV input service app) using Gradle. This can be done from within Android Studio or command line
6. Sign the built app with the platform keys from your Android source
SIGN_APK_JAR=$ANDROID_BUILD_TOP/prebuilts/sdk/tools/lib/signapk.jar PLATFORM_KEYS_DIR=$ANDROID_BUILD_TOP/build/target/product/security PLATFORM_KEYS="$PLATFORM_KEYS_DIR/platform.x509.pem $PLATFORM_KEYS_DIR/platform.pk8" java -Djava.library.path="$ANDROID_BUILD_TOP/prebuilts/sdk/tools/linux/lib64" -jar $SIGN_APK_JAR $PLATFORM_KEYS ./tis/build/outputs/apk/debug/tis-debug.apk ./tis/build/outputs/apk/debug/tis-debug-signed.apk
7. Run the zipalign tool
ZIPALIGN=$ANDROID_SDK/build-tools/30.0.3/zipalign $ZIPALIGN -p -f -v 4 ./tis/build/outputs/apk/debug/tis-debug-signed.apk ./tis/build/outputs/apk/debug/tis-debug-zipaligned.apk
8. Install native library onto device
adb root adb remount adb push ./tis/libs/libdvbglue.so /system/lib/libdvbglue.so
9. Install the TIS app onto device as a system app. First time installation will require device reboot after running the following command:
adb push ./tis/build/outputs/apk/debug/tis-debug-zipaligned.apk /system/app/inputsource/inputsource.apk
The repository can be cloned from Github. This release of the tuner HAL implementation is for the emulator.
1. Clone repo and copy default
folder contents into $ANDROID_BUILD_TOP/hardware/interfaces/tv/tuner/1.0/default
2. Build the tuner interface
cd $ANDROID_BUILD_TOP mmm hardware/interfaces/tv/tuner/1.0/default -j8
3. Install the built service onto device
adb root adb remount adb push $ANDROID_PRODUCT_OUT/vendor/bin/hw/android.hardware.tv.tuner@1.0-service /vendor/bin/hw/android.hardware.tv.tuner@1.0-service
Android uses Security-Enhanced Linux (SELinux) to enforce mandatory access control (MAC) over all processes. SELinux operates in two modes:
For non-production devices (e.g. development) SELinux can be disabled by setting it to permissive mode.
Currently the DTVKit Tuner HAL solution only works in permissive mode.