Skip to content
Snippets Groups Projects
Commit 810aa68d authored by markchien's avatar markchien Committed by Mark Chien
Browse files

[Tether07] Clean up build rule for libtetheroffloadjni

- Statically include android.hardware.tetheroffload.config@1.0,
  libcutils and their dependency library.
- Use shared-lib if there is NDK or NDK-compliant version
- Remove android.hardware.tetheroffload.control-V1.0-java from
  service.core because it is already statically built in tethering apk

Bug: 143195885
Test: -build, flash, boot
Change-Id: Ic082045bc04d3989f7f095c7a499bc0d943e4031
Merged-In: Ic082045bc04d3989f7f095c7a499bc0d943e4031
parent 226aed20
No related branches found
No related tags found
No related merge requests found
...@@ -41,20 +41,26 @@ android_library { ...@@ -41,20 +41,26 @@ android_library {
defaults: ["TetheringAndroidLibraryDefaults"], defaults: ["TetheringAndroidLibraryDefaults"],
} }
cc_library_shared { // Due to b/143733063, APK can't access a jni lib that is in APEX (but not in the APK).
cc_library {
name: "libtetheroffloadjni", name: "libtetheroffloadjni",
srcs: [ srcs: [
"jni/com_android_server_connectivity_tethering_OffloadHardwareInterface.cpp", "jni/com_android_server_connectivity_tethering_OffloadHardwareInterface.cpp",
], ],
shared_libs: [ shared_libs: [
"libnativehelper", "libcgrouprc",
"libcutils", "libnativehelper_compat_libc++",
"android.hardware.tetheroffload.config@1.0", "libvndksupport",
], ],
static_libs: [ static_libs: [
"android.hardware.tetheroffload.config@1.0",
"liblog", "liblog",
"libbase", "libbase",
"libbinderthreadstate",
"libcutils",
"libhidlbase", "libhidlbase",
"libjsoncpp",
"libprocessgroup",
"libutils", "libutils",
], ],
...@@ -64,6 +70,8 @@ cc_library_shared { ...@@ -64,6 +70,8 @@ cc_library_shared {
"-Wno-unused-parameter", "-Wno-unused-parameter",
"-Wthread-safety", "-Wthread-safety",
], ],
ldflags: ["-Wl,--exclude-libs=ALL,-error-limit=0"],
} }
// Common defaults for compiling the actual APK. // Common defaults for compiling the actual APK.
...@@ -71,7 +79,12 @@ java_defaults { ...@@ -71,7 +79,12 @@ java_defaults {
name: "TetheringAppDefaults", name: "TetheringAppDefaults",
platform_apis: true, platform_apis: true,
privileged: true, privileged: true,
// Build system doesn't track transitive dependeicies for jni_libs, list all the dependencies
// explicitly.
jni_libs: [ jni_libs: [
"libcgrouprc",
"libnativehelper_compat_libc++",
"libvndksupport",
"libtetheroffloadjni", "libtetheroffloadjni",
], ],
resource_dirs: [ resource_dirs: [
......
# Copyright (C) 2019 The Android Open Source Project
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# If you don't need to do a full clean build but would like to touch
# a file or delete some intermediate files, add a clean step to the end
# of the list. These steps will only be run once, if they haven't been
# run before.
#
# E.g.:
# $(call add-clean-step, touch -c external/sqlite/sqlite3.h)
# $(call add-clean-step, rm -rf $(PRODUCT_OUT)/obj/STATIC_LIBRARIES/libz_intermediates)
#
# Always use "touch -c" and "rm -f" or "rm -rf" to gracefully deal with
# files that are missing or have been moved.
#
# Use $(PRODUCT_OUT) to get to the "out/target/product/blah/" directory.
# Use $(OUT_DIR) to refer to the "out" directory.
#
# If you need to re-do something that's already mentioned, just copy
# the command and add it to the bottom of the list. E.g., if a change
# that you made last week required touching a file and a change you
# made today requires touching the same file, just copy the old
# touch step and add it to the end of the list.
#
# *****************************************************************
# NEWER CLEAN STEPS MUST BE AT THE END OF THE LIST ABOVE THE BANNER
# *****************************************************************
# For example:
#$(call add-clean-step, rm -rf $(OUT_DIR)/target/common/obj/APPS/AndroidTests_intermediates)
#$(call add-clean-step, rm -rf $(OUT_DIR)/target/common/obj/JAVA_LIBRARIES/core_intermediates)
#$(call add-clean-step, find $(OUT_DIR) -type f -name "IGTalkSession*" -print0 | xargs -0 rm -f)
#$(call add-clean-step, rm -rf $(PRODUCT_OUT)/data/*)
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/system/priv-app/Tethering)
$(call add-clean-step, rm -rf $(PRODUCT_OUT)/system/priv-app/InProcessTethering)
# ******************************************************************
# NEWER CLEAN STEPS MUST BE AT THE END OF THE LIST ABOVE THIS BANNER
# ******************************************************************
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment