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
Indeed, you use “CurrentBlockDataEntry.dwBlockCount” but, I tried with a FFU (Xiaomi Mi4) and this value is always 0 or 1. Because “FFUStoreHeader.dwBlockSizeInBytes” is always the same, the final value is always the same.
Shouldn't we use “CurrentBlockDataEntry.dwBlockIndex” instead?
The text was updated successfully, but these errors were encountered:
Yes, you're correct - according to the documentation, dwBlockIndex should be used. However, on the RPi FFU file, that was unsuccessful and I had to use dwBlockCount. I intend to review this issue and determine why the RPi FFU is different than the others, or if I made a mistake somewhere else.
I figured that out: your script doesn't take in consideration _BLOCK_DATA_ENTRY->dwLocationCount. This allows a block from the FFU to be copied at different location. On mobile phones' FFU, it's mainly used for the GPT which has to be at the begining of the disk and also at the end as a backup.
Indeed, initially, you should read 32 bytes:
4 for dwLocationCount
4 for dwBlockCount
4 for dwDiskAccessMethod
4 for dwBlockIndex
But, if dwLocationCount is different than 1, you need to read (dwLocationCount - 1) * 8 bytes. Indeed, you need to re-read for each additional location:
Hello,
I have a question about your ffutoimg python script.
I don’t understand line 104, when you seek at the location where to copy the data in the final image:
imgfp.seek(CurrentBlockDataEntry.dwBlockCount*FFUStoreHeader.dwBlockSizeInBytes)
Indeed, you use “CurrentBlockDataEntry.dwBlockCount” but, I tried with a FFU (Xiaomi Mi4) and this value is always 0 or 1. Because “FFUStoreHeader.dwBlockSizeInBytes” is always the same, the final value is always the same.
Shouldn't we use “CurrentBlockDataEntry.dwBlockIndex” instead?
The text was updated successfully, but these errors were encountered: