getprop("ro.product.device") == "beryllium" || abort("E3004: This package is for \"beryllium\" devices; this is a \"" + getprop("ro.product.device") + "\".");
ui_print("Source: Xiaomi/beryllium/beryllium:10/QKQ1.190828.002/V12.0.2.0.QEJMIXM:user/release-keys");
ui_print("Target: Xiaomi/beryllium/beryllium:10/QKQ1.190828.002/V12.0.3.0.QEJMIXM:user/release-keys");
ui_print("Verifying current system...");
getprop("ro.build.fingerprint") == "Xiaomi/beryllium/beryllium:10/QKQ1.190828.002/V12.0.2.0.QEJMIXM:user/release-keys" ||
    getprop("ro.build.fingerprint") == "Xiaomi/beryllium/beryllium:10/QKQ1.190828.002/V12.0.3.0.QEJMIXM:user/release-keys" ||
    abort("E3001: Package expects build fingerprint of Xiaomi/beryllium/beryllium:10/QKQ1.190828.002/V12.0.2.0.QEJMIXM:user/release-keys or Xiaomi/beryllium/beryllium:10/QKQ1.190828.002/V12.0.3.0.QEJMIXM:user/release-keys; this device has " + getprop("ro.build.fingerprint") + ".");
show_progress(0.100000, 10);
patch_partition_check("EMMC:/dev/block/bootdevice/by-name/boot:22791498:b6375a3c6d992049c9dfac503e4353fb95e8cc9c",
                      "EMMC:/dev/block/bootdevice/by-name/boot:22791498:cf178e988f3a0ebbb14a61f8570ddb7d55a74cdc") ||
    abort("E3005: \"EMMC:/dev/block/bootdevice/by-name/boot:22791498:b6375a3c6d992049c9dfac503e4353fb95e8cc9c\" or \"EMMC:/dev/block/bootdevice/by-name/boot:22791498:cf178e988f3a0ebbb14a61f8570ddb7d55a74cdc\" has unexpected contents.");
apply_patch_space(112586752) || abort("E3006: Not enough free space on /cache to apply patches.");
show_progress(0.100000, 70);
if (range_sha1("/dev/block/bootdevice/by-name/system", "128,1,584,698,712,744,751,753,754,1000,1005,1007,1008,1114,1115,1599,1600,2288,2289,2291,2293,2294,2295,2310,2311,2492,2505,3634,3665,3667,3668,3672,3673,3681,3682,3683,3684,5003,5207,5517,5787,6267,6388,8535,8565,9041,9042,9044,9450,9452,9453,9471,32770,32959,32960,33466,65537,66043,90929,96526,98306,98495,98496,99002,115974,116502,129982,130301,131073,131579,163842,164031,164032,164538,196609,197115,229378,229567,229568,230074,262145,262651,294914,295103,295104,295610,327681,328187,334550,334692,360449,360955,393217,393723,425985,426491,458445,458752,458753,460516,464953,464954,465016,465018,465059,465060,491521,492027,524289,524795,557057,557563,589825,590331,622593,623099,655361,655867,688129,688635,720897,721403,753665,754171,771937,774155,780254,780261,780364") == "c0dc3e770af9ca151c30fe65cffea6931de23c09" || block_image_verify("/dev/block/bootdevice/by-name/system", package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat")) then
ui_print("Verified system image...");
else
check_first_block("/dev/block/bootdevice/by-name/system");
ifelse (block_image_recover("/dev/block/bootdevice/by-name/system", "128,1,584,698,712,744,751,753,754,1000,1005,1007,1008,1114,1115,1599,1600,2288,2289,2291,2293,2294,2295,2310,2311,2492,2505,3634,3665,3667,3668,3672,3673,3681,3682,3683,3684,5003,5207,5517,5787,6267,6388,8535,8565,9041,9042,9044,9450,9452,9453,9471,32770,32959,32960,33466,65537,66043,90929,96526,98306,98495,98496,99002,115974,116502,129982,130301,131073,131579,163842,164031,164032,164538,196609,197115,229378,229567,229568,230074,262145,262651,294914,295103,295104,295610,327681,328187,334550,334692,360449,360955,393217,393723,425985,426491,458445,458752,458753,460516,464953,464954,465016,465018,465059,465060,491521,492027,524289,524795,557057,557563,589825,590331,622593,623099,655361,655867,688129,688635,720897,721403,753665,754171,771937,774155,780254,780261,780364") && block_image_verify("/dev/block/bootdevice/by-name/system", package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat"), ui_print("system recovered successfully."), abort("E1004: system partition fails to recover"));
endif;
if (range_sha1("/dev/block/bootdevice/by-name/vendor", "72,1,220,570,578,588,589,670,671,693,694,798,799,863,864,866,867,869,880,885,886,888,889,897,898,1357,1407,1426,1731,1798,1799,2870,3618,4827,4828,4946,4947,5068,5120,5883,5884,6567,6568,6836,32770,32832,32833,33338,65537,66042,72466,72467,98306,98368,98369,98874,131073,131578,163842,163904,163905,164410,196609,197114,229378,229440,229441,229946,243039,258044,260078,260085,260203") == "7cd236d86395a7171825a5c1d830fea0992590b4" || block_image_verify("/dev/block/bootdevice/by-name/vendor", package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat")) then
ui_print("Verified vendor image...");
else
check_first_block("/dev/block/bootdevice/by-name/vendor");
ifelse (block_image_recover("/dev/block/bootdevice/by-name/vendor", "72,1,220,570,578,588,589,670,671,693,694,798,799,863,864,866,867,869,880,885,886,888,889,897,898,1357,1407,1426,1731,1798,1799,2870,3618,4827,4828,4946,4947,5068,5120,5883,5884,6567,6568,6836,32770,32832,32833,33338,65537,66042,72466,72467,98306,98368,98369,98874,131073,131578,163842,163904,163905,164410,196609,197114,229378,229440,229441,229946,243039,258044,260078,260085,260203") && block_image_verify("/dev/block/bootdevice/by-name/vendor", package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat"), ui_print("vendor recovered successfully."), abort("E2004: vendor partition fails to recover"));
endif;

# ---- start making changes here ----

ui_print("Patching boot image...");
show_progress(0.100000, 10);
patch_partition("EMMC:/dev/block/bootdevice/by-name/boot:22791498:b6375a3c6d992049c9dfac503e4353fb95e8cc9c",
                "EMMC:/dev/block/bootdevice/by-name/boot:22791498:cf178e988f3a0ebbb14a61f8570ddb7d55a74cdc",
                package_extract_file("boot.img.p")) ||
    abort("E3008: Failed to apply patch to EMMC:/dev/block/bootdevice/by-name/boot:22791498:cf178e988f3a0ebbb14a61f8570ddb7d55a74cdc");

# ---- radio update tasks ----

ui_print("Patching firmware images...");
package_extract_file("firmware-update/abl.elf", "/dev/block/bootdevice/by-name/abl_a");
package_extract_file("firmware-update/abl.elf", "/dev/block/bootdevice/by-name/abl_b");
show_progress(0.600000, 600);
ui_print("Patching system image after verification.");
block_image_update("/dev/block/bootdevice/by-name/system", package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat") ||
  abort("E1001: Failed to update system image.");
ui_print("Patching vendor image after verification.");
block_image_update("/dev/block/bootdevice/by-name/vendor", package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat") ||
  abort("E2001: Failed to update vendor image.");
show_progress(0.100000, 2);

# ---- radio update tasks 2 ----

ui_print("Patching vbmeta dtbo logo binimages...");
package_extract_file("firmware-update/xbl_config.img", "/dev/block/bootdevice/by-name/xbl_config_a");
package_extract_file("firmware-update/devcfg.img", "/dev/block/bootdevice/by-name/devcfg_a");
package_extract_file("firmware-update/aop.img", "/dev/block/bootdevice/by-name/aop_a");
package_extract_file("firmware-update/qupfw.img", "/dev/block/bootdevice/by-name/qupfw_a");
package_extract_file("firmware-update/tz.img", "/dev/block/bootdevice/by-name/tz_a");
package_extract_file("firmware-update/storsec.img", "/dev/block/bootdevice/by-name/storsec_a");
package_extract_file("firmware-update/keymaster.img", "/dev/block/bootdevice/by-name/keymaster_a");
package_extract_file("firmware-update/bluetooth.img", "/dev/block/bootdevice/by-name/bluetooth");
package_extract_file("firmware-update/xbl.img", "/dev/block/bootdevice/by-name/xbl_a");
package_extract_file("firmware-update/modem.img", "/dev/block/bootdevice/by-name/modem");
package_extract_file("firmware-update/dsp.img", "/dev/block/bootdevice/by-name/dsp");
package_extract_file("firmware-update/cmnlib64.img", "/dev/block/bootdevice/by-name/cmnlib64_a");
package_extract_file("firmware-update/cmnlib.img", "/dev/block/bootdevice/by-name/cmnlib_a");
package_extract_file("firmware-update/hyp.img", "/dev/block/bootdevice/by-name/hyp_a");
