sm6225-common: Sync extract scripts with templates

Change-Id: I98a36854c5a0c0390592911bb2558b34eff77efc
This commit is contained in:
Michael Bestas 2024-08-27 22:05:28 +03:00
parent f146e70de9
commit d7163d49fe
No known key found for this signature in database
GPG key ID: CC95044519BE6669
2 changed files with 61 additions and 36 deletions

View file

@ -1,8 +1,7 @@
#!/bin/bash #!/bin/bash
# #
# Copyright (C) 2016 The CyanogenMod Project # SPDX-FileCopyrightText: 2016 The CyanogenMod Project
# Copyright (C) 2017-2023 The LineageOS Project # SPDX-FileCopyrightText: 2017-2024 The LineageOS Project
#
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -14,6 +13,10 @@ if [[ ! -d "${MY_DIR}" ]]; then MY_DIR="${PWD}"; fi
ANDROID_ROOT="${MY_DIR}/../../.." ANDROID_ROOT="${MY_DIR}/../../.."
# If XML files don't have comments before the XML header, use this flag
# Can still be used with broken XML files by using blob_fixup
export TARGET_DISABLE_XML_FIXING=true
HELPER="${ANDROID_ROOT}/tools/extract-utils/extract_utils.sh" HELPER="${ANDROID_ROOT}/tools/extract-utils/extract_utils.sh"
if [ ! -f "${HELPER}" ]; then if [ ! -f "${HELPER}" ]; then
echo "Unable to find helper script at ${HELPER}" echo "Unable to find helper script at ${HELPER}"
@ -25,29 +28,35 @@ source "${HELPER}"
CLEAN_VENDOR=true CLEAN_VENDOR=true
ONLY_COMMON= ONLY_COMMON=
ONLY_FIRMWARE=
ONLY_TARGET= ONLY_TARGET=
KANG= KANG=
SECTION= SECTION=
CARRIER_SKIP_FILES=()
while [ "${#}" -gt 0 ]; do while [ "${#}" -gt 0 ]; do
case "${1}" in case "${1}" in
--only-common ) --only-common)
ONLY_COMMON=true ONLY_COMMON=true
;; ;;
--only-target ) --only-firmware)
ONLY_FIRMWARE=true
;;
--only-target)
ONLY_TARGET=true ONLY_TARGET=true
;; ;;
-n | --no-cleanup ) -n | --no-cleanup)
CLEAN_VENDOR=false CLEAN_VENDOR=false
;; ;;
-k | --kang ) -k | --kang)
KANG="--kang" KANG="--kang"
;; ;;
-s | --section ) -s | --section)
SECTION="${2}"; shift SECTION="${2}"
shift
CLEAN_VENDOR=false CLEAN_VENDOR=false
;; ;;
* ) *)
SRC="${1}" SRC="${1}"
;; ;;
esac esac
@ -61,19 +70,24 @@ fi
function blob_fixup() { function blob_fixup() {
case "${1}" in case "${1}" in
system_ext/etc/permissions/moto-telephony.xml) system_ext/etc/permissions/moto-telephony.xml)
[ "$2" = "" ] && return 0
sed -i "s#/system/#/system_ext/#" "${2}" sed -i "s#/system/#/system_ext/#" "${2}"
;; ;;
system_ext/priv-app/ims/ims.apk) system_ext/priv-app/ims/ims.apk)
[ "$2" = "" ] && return 0
apktool_patch "${2}" "$MY_DIR/ims-patches" apktool_patch "${2}" "$MY_DIR/ims-patches"
;; ;;
vendor/etc/init/android.hardware.nfc@1.2-service-moto.rc) vendor/etc/init/android.hardware.nfc@1.2-service-moto.rc)
[ "$2" = "" ] && return 0
sed -i "s/class hal/override\n class hal/" "${2}" sed -i "s/class hal/override\n class hal/" "${2}"
;; ;;
vendor/etc/init/android.hardware.nfc@1.2-service.sec.rc) vendor/etc/init/android.hardware.nfc@1.2-service.sec.rc)
[ "$2" = "" ] && return 0
sed -i "s/sec/samsung/g" "${2}" sed -i "s/sec/samsung/g" "${2}"
sed -i "s/class hal/override\n class hal/" "${2}" sed -i "s/class hal/override\n class hal/" "${2}"
;; ;;
vendor/etc/init/android.hardware.nfc@1.2-service.st-moto.rc) vendor/etc/init/android.hardware.nfc@1.2-service.st-moto.rc)
[ "$2" = "" ] && return 0
sed -i "s/class hal/override\n class hal/" "${2}" sed -i "s/class hal/override\n class hal/" "${2}"
;; ;;
vendor/lib64/camera/components/com.qti.node.gpu.so | \ vendor/lib64/camera/components/com.qti.node.gpu.so | \
@ -81,13 +95,24 @@ function blob_fixup() {
vendor/lib64/com.qti.feature2.rt.so | \ vendor/lib64/com.qti.feature2.rt.so | \
vendor/lib64/hw/camera.qcom.so | \ vendor/lib64/hw/camera.qcom.so | \
vendor/lib64/hw/com.qti.chi.override.so) vendor/lib64/hw/com.qti.chi.override.so)
[ "$2" = "" ] && return 0
sed -i "s/camera.mot.is.coming.cts/vendor.camera.coming.cts/g" "${2}" sed -i "s/camera.mot.is.coming.cts/vendor.camera.coming.cts/g" "${2}"
;; ;;
vendor/lib64/vendor.qti.hardware.camera.postproc@1.0-service-impl.so) vendor/lib64/vendor.qti.hardware.camera.postproc@1.0-service-impl.so)
[ "$2" = "" ] && return 0
hexdump -ve '1/1 "%.2X"' "${2}" | sed "s/130A0094/1F2003D5/g" | xxd -r -p > "${EXTRACT_TMP_DIR}/${1##*/}" hexdump -ve '1/1 "%.2X"' "${2}" | sed "s/130A0094/1F2003D5/g" | xxd -r -p > "${EXTRACT_TMP_DIR}/${1##*/}"
mv "${EXTRACT_TMP_DIR}/${1##*/}" "${2}" mv "${EXTRACT_TMP_DIR}/${1##*/}" "${2}"
;; ;;
*)
return 1
;;
esac esac
return 0
}
function blob_fixup_dry() {
blob_fixup "$1" ""
} }
function prepare_firmware() { function prepare_firmware() {
@ -102,7 +127,7 @@ function prepare_firmware() {
fi fi
} }
if [ -z "${ONLY_TARGET}" ]; then if [ -z "${ONLY_FIRMWARE}" ] && [ -z "${ONLY_TARGET}" ]; then
# Initialize the helper for common device # Initialize the helper for common device
setup_vendor "${DEVICE_COMMON}" "${VENDOR_COMMON:-$VENDOR}" "${ANDROID_ROOT}" true "${CLEAN_VENDOR}" setup_vendor "${DEVICE_COMMON}" "${VENDOR_COMMON:-$VENDOR}" "${ANDROID_ROOT}" true "${CLEAN_VENDOR}"
@ -114,19 +139,18 @@ if [ -z "${ONLY_COMMON}" ] && [ -s "${MY_DIR}/../../${VENDOR}/${DEVICE}/propriet
source "${MY_DIR}/../../${VENDOR}/${DEVICE}/extract-files.sh" source "${MY_DIR}/../../${VENDOR}/${DEVICE}/extract-files.sh"
setup_vendor "${DEVICE}" "${VENDOR}" "${ANDROID_ROOT}" false "${CLEAN_VENDOR}" setup_vendor "${DEVICE}" "${VENDOR}" "${ANDROID_ROOT}" false "${CLEAN_VENDOR}"
if [ -z "${ONLY_FIRMWARE}" ]; then
extract "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files.txt" "${SRC}" "${KANG}" --section "${SECTION}" extract "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files.txt" "${SRC}" "${KANG}" --section "${SECTION}"
if [ -s "$EXTRACT_TMP_DIR/super_dump/product.img" ]; then
bash "${MY_DIR}/../../${VENDOR}/${DEVICE}/regen-carriersettings.sh" "$EXTRACT_TMP_DIR/super_dump/product.img" "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt"
fi
if [ -f "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt" ]; then if [ -f "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt" ]; then
generate_prop_list_from_image "product.img" "${MY_DIR}/../../proprietary-files-carriersettings.txt" CARRIER_SKIP_FILES carriersettings
extract "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt" "${SRC}" "${KANG}" --section "${SECTION}" extract "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt" "${SRC}" "${KANG}" --section "${SECTION}"
extract_carriersettings extract_carriersettings
fi fi
fi
if [ -f "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-firmware.txt" ]; then if [ -z "${SECTION}" ] && [ -f "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-firmware.txt" ]; then
extract_firmware "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-firmware.txt" "${SRC}" extract_firmware "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-firmware.txt" "${SRC}"
fi fi
fi fi

View file

@ -1,8 +1,7 @@
#!/bin/bash #!/bin/bash
# #
# Copyright (C) 2016 The CyanogenMod Project # SPDX-FileCopyrightText: 2016 The CyanogenMod Project
# Copyright (C) 2017-2023 The LineageOS Project # SPDX-FileCopyrightText: 2017-2024 The LineageOS Project
#
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -44,6 +43,8 @@ if [ -s "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files.txt" ]; then
write_makefiles "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files.txt" true write_makefiles "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files.txt" true
if [ -f "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt" ]; then if [ -f "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt" ]; then
write_makefiles "${MY_DIR}/../../${VENDOR}/${DEVICE}/proprietary-files-carriersettings.txt" true
write_rro_package "CarrierConfigOverlay" "com.android.carrierconfig" product write_rro_package "CarrierConfigOverlay" "com.android.carrierconfig" product
write_single_product_packages "CarrierConfigOverlay" write_single_product_packages "CarrierConfigOverlay"
fi fi