Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 1 | #!/usr/bin/env python3 |
Jerome Forissier | 1bb9298 | 2017-12-15 14:27:02 +0100 | [diff] [blame] | 2 | # SPDX-License-Identifier: BSD-2-Clause |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 3 | # |
| 4 | # Copyright (c) 2016, Linaro Limited |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 5 | import struct |
| 6 | |
Jerome Forissier | e06fa02 | 2018-11-14 11:02:49 +0100 | [diff] [blame] | 7 | |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 8 | def main(): |
Jerome Forissier | e06fa02 | 2018-11-14 11:02:49 +0100 | [diff] [blame] | 9 | with open("../out/arm/core/tee.bin", "rb") as f: |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 10 | data = f.read(4) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 11 | magic = struct.unpack('<I', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 12 | print("Magic: \t\t0x{:08x}".format(magic)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 13 | |
| 14 | data = f.read(1) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 15 | version = struct.unpack('<B', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 16 | print("Version: \t0x{:02x}".format(version)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 17 | |
| 18 | data = f.read(1) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 19 | arch_id = struct.unpack('<B', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 20 | print("ArchID: \t0x{:02x}".format(arch_id)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 21 | |
| 22 | data = f.read(2) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 23 | flags = struct.unpack('<H', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 24 | print("Arch Flags: \t0x{:04x}".format(arch_id)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 25 | |
| 26 | data = f.read(4) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 27 | init_size = struct.unpack('<I', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 28 | print("Init size: \t0x{:04x}".format(init_size)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 29 | |
| 30 | data = f.read(4) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 31 | laddr_h = struct.unpack('<I', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 32 | print("Load addr high:\t0x{:04x}".format(laddr_h)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 33 | |
| 34 | data = f.read(4) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 35 | laddr_l = struct.unpack('<I', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 36 | print("Load addr low: \t0x{:04x}".format(laddr_l)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 37 | |
| 38 | data = f.read(4) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 39 | mem_usage = struct.unpack('<I', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 40 | print("Mem usage: \t0x{:04x}".format(mem_usage)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 41 | |
| 42 | data = f.read(4) |
Jens Wiklander | 8108ed3 | 2019-12-17 10:00:54 +0100 | [diff] [blame^] | 43 | pgd_size = struct.unpack('<I', data)[0] |
Rouven Czerwinski | bbaeed4 | 2019-08-07 20:07:00 +0200 | [diff] [blame] | 44 | print("Pages size: \t0x{:04x}".format(pgd_size)) |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 45 | |
Jerome Forissier | e06fa02 | 2018-11-14 11:02:49 +0100 | [diff] [blame] | 46 | |
Joakim Bech | 09871a7 | 2016-07-29 21:24:49 +0200 | [diff] [blame] | 47 | if __name__ == "__main__": |
Jerome Forissier | e06fa02 | 2018-11-14 11:02:49 +0100 | [diff] [blame] | 48 | main() |