summaryrefslogtreecommitdiff
path: root/scripts/tee_bin_parser.py
blob: 73dac8eedb4dd8c7d78dbc7999b3a5d27d08cb92 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#!/usr/bin/env python3
# SPDX-License-Identifier: BSD-2-Clause
#
# Copyright (c) 2016, Linaro Limited
import struct


def main():
    with open("../out/arm/core/tee.bin", "rb") as f:
        data = f.read(4)
        magic = struct.unpack('<I', data)
        print("Magic: \t\t0x{:08x}".format(magic))

        data = f.read(1)
        version = struct.unpack('<B', data)
        print("Version: \t0x{:02x}".format(version))

        data = f.read(1)
        arch_id = struct.unpack('<B', data)
        print("ArchID: \t0x{:02x}".format(arch_id))

        data = f.read(2)
        flags = struct.unpack('<H', data)
        print("Arch Flags: \t0x{:04x}".format(arch_id))

        data = f.read(4)
        init_size = struct.unpack('<I', data)
        print("Init size: \t0x{:04x}".format(init_size))

        data = f.read(4)
        laddr_h = struct.unpack('<I', data)
        print("Load addr high:\t0x{:04x}".format(laddr_h))

        data = f.read(4)
        laddr_l = struct.unpack('<I', data)
        print("Load addr low: \t0x{:04x}".format(laddr_l))

        data = f.read(4)
        mem_usage = struct.unpack('<I', data)
        print("Mem usage: \t0x{:04x}".format(mem_usage))

        data = f.read(4)
        pgd_size = struct.unpack('<I', data)
        print("Pages size: \t0x{:04x}".format(pgd_size))


if __name__ == "__main__":
    main()