You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
After going through the code, and the dump/restore/ADB process a handful of times, I've gathered a few ideas on optimising the processes:
1. Device Dumping
While it is great to have full partition dumps, due to the speed limit imposed by the lack of mread in pyamlboot, it's not the best way forward to dump both A/B partitions and userdata as well.
My proposal to fix this is to make the dumping logic a bit smarter:
First step should be dumping env and parsing it to TXT
Then dumping other non-A/B partitions (bootloader, logo, misc, settings)
Reading out the active slot from env
Dumping boot/dtbo/fip/system/vbmeta of the selected slot
Ignoring data partition (it is unnecessary for a working dump
This altogether would reduce dump sizes by:
~3GB for data (2731MB if I'm not mistaken)
516MB for system
4MB for FIP
4MB for DTBO
16MB for boot
2MB for vbmeta
Making the dumping process from 4GB to ~863MB, while also reducing the dumping time from nearly two hours (or in my case, since on macOS the maximum bandwidth seems to be around 94kBps, from around 12 hours!) to around 30 minutes (or, in my case, "only" 3 hours).
This also reduces duplicate/unnecessary data, as well as personally identifying stuff (I've seen a few people in the community share their dumps with a full data partition dump, containing their phone MAC addresses, etc.).
2. Device restoration
Similarly to the above approach, restoration could be optimised by not restoring all partitions, instead:
Taking the input dump (and using the old method if an old style dump is found)
Reading out the active slot from env
Writing non-A/B partitions (incl. env)
Writing the A/B partition dumps into the right slot
Writing zeroed out data to the inactive slot ( + optionally data, if the user chooses a "wipe" option - or possibly just wiping data's partition headers)
As by the looks of it, Android's A/B tooling is used, the handling of the inactive slot partitions is automatic - upon receiving an update, if an invalid/faulty partition (in our case, zeroed out) is detected, the current slot's appropriate partition is copied over before the OTA delta patch is applied. This means that zeroing out these partitions is perfectly fine.
This would similarly reduce the time needed to restore a device (especially since the nulling can be done by writing zeros to the memory once, then issuing the copy command from the same memory region again and again, speeding up things) as number 1 above.
3. ADB process
This is where you'll hate me. The current ADB process uses a prebuilt boot.img with ADB enabled. This poses a number of compatibility issues, as Spotify, to date, is issuing firmware updates to the CarThing, often patching the kernel/initrd, which can sometimes cause boot issues.
Therefore I'd like to propose a more dynamic approach to enabling ADB, by integrating mkbootimg and possibly abootimg into the process. Instead of booting a prepared boot.img, the ADB option should:
Pull env and get current boot slot
Pull boot_{activeSlot} and save locally
Unpack the newly pulled boot.img
Apply ADB enabling patch (and anything else if needed)
Build patched boot.img
Push that to the device (either write to eMMC or boot directly, dealer's choice)
The text was updated successfully, but these errors were encountered:
After going through the code, and the dump/restore/ADB process a handful of times, I've gathered a few ideas on optimising the processes:
1. Device Dumping
While it is great to have full partition dumps, due to the speed limit imposed by the lack of
mread
in pyamlboot, it's not the best way forward to dump both A/B partitions and userdata as well.My proposal to fix this is to make the dumping logic a bit smarter:
env
and parsing it to TXTenv
This altogether would reduce dump sizes by:
Making the dumping process from 4GB to ~863MB, while also reducing the dumping time from nearly two hours (or in my case, since on macOS the maximum bandwidth seems to be around 94kBps, from around 12 hours!) to around 30 minutes (or, in my case, "only" 3 hours).
Therefore, a future dump would look like this:
This also reduces duplicate/unnecessary data, as well as personally identifying stuff (I've seen a few people in the community share their dumps with a full data partition dump, containing their phone MAC addresses, etc.).
2. Device restoration
Similarly to the above approach, restoration could be optimised by not restoring all partitions, instead:
env
env
)data
's partition headers)As by the looks of it, Android's A/B tooling is used, the handling of the inactive slot partitions is automatic - upon receiving an update, if an invalid/faulty partition (in our case, zeroed out) is detected, the current slot's appropriate partition is copied over before the OTA delta patch is applied. This means that zeroing out these partitions is perfectly fine.
This would similarly reduce the time needed to restore a device (especially since the nulling can be done by writing zeros to the memory once, then issuing the copy command from the same memory region again and again, speeding up things) as number 1 above.
3. ADB process
This is where you'll hate me. The current ADB process uses a prebuilt boot.img with ADB enabled. This poses a number of compatibility issues, as Spotify, to date, is issuing firmware updates to the CarThing, often patching the kernel/initrd, which can sometimes cause boot issues.
Therefore I'd like to propose a more dynamic approach to enabling ADB, by integrating
mkbootimg
and possiblyabootimg
into the process. Instead of booting a prepared boot.img, the ADB option should:env
and get current boot slotboot_{activeSlot}
and save locallyThe text was updated successfully, but these errors were encountered: