@@ -73,4 +73,46 @@ cd dist
|
||||
mv electrum-setup.exe $NAME_ROOT-$VERSION-setup.exe
|
||||
cd ..
|
||||
|
||||
info "Padding binaries to 8-byte boundaries, and fixing COFF image checksum in PE header"
|
||||
# note: 8-byte boundary padding is what osslsigncode uses:
|
||||
# https://github.com/mtrojnar/osslsigncode/blob/6c8ec4427a0f27c145973450def818e35d4436f6/osslsigncode.c#L3047
|
||||
(
|
||||
cd dist
|
||||
for binary_file in ./*.exe; do
|
||||
info ">> fixing $binary_file..."
|
||||
# code based on https://github.com/erocarrera/pefile/blob/bbf28920a71248ed5c656c81e119779c131d9bd4/pefile.py#L5877
|
||||
python3 <<EOF
|
||||
pe_file = "$binary_file"
|
||||
with open(pe_file, "rb") as f:
|
||||
binary = bytearray(f.read())
|
||||
pe_offset = int.from_bytes(binary[0x3c:0x3c+4], byteorder="little")
|
||||
checksum_offset = pe_offset + 88
|
||||
checksum = 0
|
||||
|
||||
# Pad data to 8-byte boundary.
|
||||
remainder = len(binary) % 8
|
||||
binary += bytes(8 - remainder)
|
||||
|
||||
for i in range(len(binary) // 4):
|
||||
if i == checksum_offset // 4: # Skip the checksum field
|
||||
continue
|
||||
dword = int.from_bytes(binary[i*4:i*4+4], byteorder="little")
|
||||
checksum = (checksum & 0xffffffff) + dword + (checksum >> 32)
|
||||
if checksum > 2 ** 32:
|
||||
checksum = (checksum & 0xffffffff) + (checksum >> 32)
|
||||
|
||||
checksum = (checksum & 0xffff) + (checksum >> 16)
|
||||
checksum = (checksum) + (checksum >> 16)
|
||||
checksum = checksum & 0xffff
|
||||
checksum += len(binary)
|
||||
|
||||
# Set the checksum
|
||||
binary[checksum_offset : checksum_offset + 4] = int.to_bytes(checksum, byteorder="little", length=4)
|
||||
|
||||
with open(pe_file, "wb") as f:
|
||||
f.write(binary)
|
||||
EOF
|
||||
done
|
||||
)
|
||||
|
||||
sha256sum dist/electrum*.exe
|
||||
|
||||
Reference in New Issue
Block a user