sm6225-common: Sync extract scripts with templates
Change-Id: I98a36854c5a0c0390592911bb2558b34eff77efc
This commit is contained in:
parent
f146e70de9
commit
d7163d49fe
2 changed files with 61 additions and 36 deletions
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue