util/rockchip: Port make_idb.py to python3
BUG=chromium:1023662 TEST=buildbot pass TEST=1. Use python2 script 2. Run `emerge-kevin coreboot` twice, so we get bootblock.bin.1 and bootblock.bin.2 3. Run `xxd` on these two bootblock so we get bootblock.bin.1.hex and bootblock.bin.2.hex 4. `diff bootblock.bin.1.hex bootblock.bin.2.hex` and record the difference. (at least, the time info changes) 5. Migrate to python3 6. Similar steps, we get bootblock.bin.py3.hex 7. `diff bootblock.bin.1.hex bootblock.bin.py3.hex`, the difference is similar. (time info, git hash changes) Signed-off-by: Yilin Yang <kerker@google.com> Change-Id: I04253084ec9b65310c52598b629390051cd2172b Reviewed-on: https://review.coreboot.org/c/coreboot/+/45447 Reviewed-by: Yu-Ping Wu <yupingso@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
12beaea5e2
commit
46eaa5a1ba
3 changed files with 26 additions and 25 deletions
|
@ -83,7 +83,7 @@ devices on the board such as dGPU. `C`
|
||||||
can be passed to SPIKE, the RISC-V reference emulator.`Bash`
|
can be passed to SPIKE, the RISC-V reference emulator.`Bash`
|
||||||
* _sifive-gpt.py_ - Wraps the bootblock in a GPT partition for
|
* _sifive-gpt.py_ - Wraps the bootblock in a GPT partition for
|
||||||
SiFive's bootrom. `Python3`
|
SiFive's bootrom. `Python3`
|
||||||
* __rockchip__ - Generate Rockchip idblock bootloader. `Python2`
|
* __rockchip__ - Generate Rockchip idblock bootloader. `Python3`
|
||||||
* __sconfig__ - coreboot device tree compiler `Lex` `Yacc`
|
* __sconfig__ - coreboot device tree compiler `Lex` `Yacc`
|
||||||
* __scripts__
|
* __scripts__
|
||||||
* _config_ - Manipulate options in a .config file from the
|
* _config_ - Manipulate options in a .config file from the
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Generate Rockchip idblock bootloader. `Python2`
|
Generate Rockchip idblock bootloader. `Python3`
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
#!/usr/bin/env python2
|
#!/usr/bin/env python3
|
||||||
# SPDX-License-Identifier: BSD-2-Clause
|
# SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
|
||||||
import struct
|
import struct
|
||||||
|
@ -7,7 +7,7 @@ from io import SEEK_SET, SEEK_END
|
||||||
|
|
||||||
class IDBTool:
|
class IDBTool:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
print "Initialize IDBTool"
|
print("Initialize IDBTool")
|
||||||
|
|
||||||
def p_rc4(self, buf, length):
|
def p_rc4(self, buf, length):
|
||||||
key = (124,78,3,4,85,5,9,7,45,44,123,56,23,13,23,17)
|
key = (124,78,3,4,85,5,9,7,45,44,123,56,23,13,23,17)
|
||||||
|
@ -25,7 +25,7 @@ class IDBTool:
|
||||||
j = (j + S[i]) % 256
|
j = (j + S[i]) % 256
|
||||||
temp = S[i]; S[i] = S[j]; S[j] = temp
|
temp = S[i]; S[i] = S[j]; S[j] = temp
|
||||||
k = (S[i] + S[j]) % 256
|
k = (S[i] + S[j]) % 256
|
||||||
buf[x] = struct.pack('B', ord(buf[x]) ^ S[k])
|
buf[x] = struct.pack('B', buf[x] ^ S[k])[0]
|
||||||
|
|
||||||
def makeIDB(self, chip, from_file, to_file, rc4_flag = False, align_flag = False):
|
def makeIDB(self, chip, from_file, to_file, rc4_flag = False, align_flag = False):
|
||||||
try:
|
try:
|
||||||
|
@ -45,17 +45,18 @@ class IDBTool:
|
||||||
data_len = len(data)
|
data_len = len(data)
|
||||||
SECTOR_SIZE = 512
|
SECTOR_SIZE = 512
|
||||||
PAGE_ALIGN = 4
|
PAGE_ALIGN = 4
|
||||||
sectors = (data_len + 4 - 1) / SECTOR_SIZE + 1
|
sectors = (data_len + 4 - 1) // SECTOR_SIZE + 1
|
||||||
pages = (sectors - 1) / PAGE_ALIGN + 1
|
pages = (sectors - 1) // PAGE_ALIGN + 1
|
||||||
sectors = pages * PAGE_ALIGN;
|
sectors = pages * PAGE_ALIGN
|
||||||
|
|
||||||
buf = [B'\0'] * sectors * SECTOR_SIZE
|
buf = bytearray(sectors * SECTOR_SIZE)
|
||||||
buf[:4] = chip
|
assert len(chip) == 4
|
||||||
|
buf[:4] = chip.encode('ascii')
|
||||||
buf[4 : 4+data_len] = data
|
buf[4 : 4+data_len] = data
|
||||||
|
|
||||||
idblock = [B'\0'] * 4 * SECTOR_SIZE
|
idblock = bytearray(4 * SECTOR_SIZE)
|
||||||
blank = [B'\0'] * 4 * SECTOR_SIZE
|
blank = bytearray(4 * SECTOR_SIZE)
|
||||||
idblock[:4] = ['\x55', '\xAA', '\xF0', '\x0F']
|
idblock[:4] = b'\x55\xAA\xF0\x0F'
|
||||||
|
|
||||||
if (not rc4_flag):
|
if (not rc4_flag):
|
||||||
idblock[8:12] = struct.pack("<I", 1)
|
idblock[8:12] = struct.pack("<I", 1)
|
||||||
|
@ -65,8 +66,8 @@ class IDBTool:
|
||||||
self.p_rc4(list_tmp, SECTOR_SIZE)
|
self.p_rc4(list_tmp, SECTOR_SIZE)
|
||||||
buf[SECTOR_SIZE*i : SECTOR_SIZE*(i+1)] = list_tmp
|
buf[SECTOR_SIZE*i : SECTOR_SIZE*(i+1)] = list_tmp
|
||||||
|
|
||||||
idblock[12:16] = struct.pack("<HH", 4, 4);
|
idblock[12:16] = struct.pack("<HH", 4, 4)
|
||||||
idblock[506:510] = struct.pack("<HH", sectors, sectors);
|
idblock[506:510] = struct.pack("<HH", sectors, sectors)
|
||||||
self.p_rc4(idblock, SECTOR_SIZE)
|
self.p_rc4(idblock, SECTOR_SIZE)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -76,25 +77,25 @@ class IDBTool:
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if (align_flag):
|
if (align_flag):
|
||||||
fout.write(''.join(idblock))
|
fout.write(idblock)
|
||||||
fout.write(''.join(blank))
|
fout.write(blank)
|
||||||
|
|
||||||
for s in xrange(0, sectors * SECTOR_SIZE, PAGE_ALIGN * SECTOR_SIZE):
|
for s in range(0, sectors * SECTOR_SIZE, PAGE_ALIGN * SECTOR_SIZE):
|
||||||
fout.write(''.join(buf[s : s + PAGE_ALIGN * SECTOR_SIZE]))
|
fout.write(buf[s : s + PAGE_ALIGN * SECTOR_SIZE])
|
||||||
fout.write(''.join(blank))
|
fout.write(blank)
|
||||||
else:
|
else:
|
||||||
fout.write(''.join(idblock))
|
fout.write(idblock)
|
||||||
fout.write(''.join(buf))
|
fout.write(buf)
|
||||||
fout.flush()
|
fout.flush()
|
||||||
except:
|
except:
|
||||||
sys.exit("Failed to write data to : " + to_file)
|
sys.exit("Failed to write data to : " + to_file)
|
||||||
finally:
|
finally:
|
||||||
fout.close()
|
fout.close()
|
||||||
print "DONE"
|
print("DONE")
|
||||||
|
|
||||||
def usage():
|
def usage():
|
||||||
print "Usage: make_idb.py [--chip=RKXX] [--enable-rc4] [--enable-align] [--to=out] --from=in"
|
print("Usage: make_idb.py [--chip=RKXX] [--enable-rc4] [--enable-align] [--to=out] --from=in")
|
||||||
print " --chip: default is RK32"
|
print(" --chip: default is RK32")
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
rc4_flag = align_flag = False
|
rc4_flag = align_flag = False
|
||||||
|
|
Loading…
Reference in a new issue