1. 程式人生 > >Android高通平臺下編譯時能生成(拷貝)預編譯的so到system的lib目錄

Android高通平臺下編譯時能生成(拷貝)預編譯的so到system的lib目錄

 

  1. 參考hardware\qcom\display\libcopybit

通過編譯log可以知道編譯到這裡,生成的copybit.msm8937.so在out\target\product\msm8937_64\system\lib\hw下。libcopybit\Android.mk相關部分如下:

編譯相關的log

build/core/Makefile:54: Defined in: hardware/qcom/display/libcopybit/../common.mk hardware/qcom/display/libcopybit/../common.mk

build/core/Makefile:54: Duplicate header copy:

說明build/core/Makefile能找到hardware/qcom/display/libcopybit目錄

但我們增加的psam目錄,在整個系統編譯的時候沒有看到這樣的log,為什麼呢

 

2.在hardware\qcom增加psam資料夾

目的是想在編譯的時候把so拷貝到out\target\product\msm8937_64\system\lib下。用mmm單獨編譯可以,但是用make整個編譯的時候卻不會,為什麼呢?

 

先回到前面看看我們參考的hardware\qcom\display\libcopybit下的copybit.msm8937.so怎麼拷貝到system\lib\hw下。在device/qcom目錄下通過grep -wrn copybit.msm8937,查詢結果如下:

找到LIBCOPYBIT += copybit.msm8937,再通過LIBCOPYBIT再找到PRODUCT_PACKAGES += $(LIBCOPYBIT),android編譯系統應該就是通過這裡知道去編譯hardware\qcom\display\libcopybit,這裡需要注意copybit.msm8937是libcopybit資料夾下Android.mk中

LOCAL_MODULE                  :=copybit.$(TARGET_BOARD_PLATFORM)的LOCAL_MODULE的值,LOCAL_MODULE的值可以不需要和資料夾名字(libcopybit)一樣,但device/qcom/common/base.mk的PRODUCT_PACKAGES += $(LIBCOPYBIT)對應的值必須是和LOCAL_MODULE的值一樣。

 

3. 解決

根據上面的分析,在device/qcom/common/base.mk增加

#LIBPSAM

LIBPSAM := libpsam.so

PRODUCT_PACKAGES += $(LIBPSAM)

hardware\qcom\psam\Android.mk的內容如下:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE       := libpsam.so
LOCAL_SRC_FILES    := libpsam.so
#LOCAL_MODULE_CLASS := EXECUTABLES
LOCAL_MODULE_TAGS  := optional
LOCAL_MODULE_CLASS := SHARED_LIBRARIES
LOCAL_MODULE_PATH  := $(TARGET_OUT)/lib
include $(BUILD_PREBUILT)

確保LOCAL_MODULE       := libpsam.so和LIBPSAM := libpsam.so的值一樣。