diff --git a/linux-ramdump-parser-v2/cachedumplib.py b/linux-ramdump-parser-v2/cachedumplib.py old mode 100755 new mode 100644 index 28714d8c4fac76066e8010fbe782d826f2564252..62b0fea050341880612677e5b8f2cfceb5c24708 --- a/linux-ramdump-parser-v2/cachedumplib.py +++ b/linux-ramdump-parser-v2/cachedumplib.py @@ -1,4 +1,4 @@ -# Copyright (c) 2015-2016, The Linux Foundation. All rights reserved. +# Copyright (c) 2015-2017, The Linux Foundation. All rights reserved. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License version 2 and @@ -431,9 +431,165 @@ class L1_ICache_KRYO2XX_GOLD(CacheDumpType_v1): output.append(n) output.append(addr) +class L1_DCache_KRYO3XX_SILVER(CacheDumpType_v1): + """Refer to documentation:ad003_atrm""" + def __init__(self): + super(L1_DCache_KRYO3XX_SILVER, self).__init__() + self.tableformat.addColumn('MESI') + self.tableformat.addColumn('Tag Address [39:12]') + self.tableformat.addColumn('NS') + self.tableformat.addColumn('Outer Allocation Hint') + self.unsupported_header_offset = 0 + self.TagSize = 2 + self.LineSize = 16 + self.NumSets = 0x80 + self.NumWays = 4 + + def MESI_to_string(MESI_d): + if MESI_d == 0: + return 'I' + elif MESI_d == 1: + return 'S' + elif MESI_d == 2: + return 'E' + else: + return 'M' + + def parse_tag_fn(self, output, data, nset, nway): + if self.TagSize != 2: + raise Exception('cache tag size mismatch') + + MESI_d = (data[1] >> 30) & 0x3 + addr = (data[1] >> 1) & 0xfffffff + ns = (data[1] >> 29) & 0x1 + alloc_hint = data[0] & 0x1 + + mesi = self.MESI_to_string(MESI_d) + output.append(mesi) + output.append(addr) + output.append(ns) + output.append(alloc_hint) + +class L1_ICache_KRYO3XX_SILVER(CacheDumpType_v1): + """Refer to documentation:ad003_atrm""" + def __init__(self): + super(L1_ICache_KRYO3XX_SILVER, self).__init__() + self.tableformat.addColumn('Valid and set mode') + self.tableformat.addColumn('NS') + self.tableformat.addColumn('Tag address') + self.unsupported_header_offset = 0 + self.TagSize = 2 + self.LineSize = 16 + self.NumSets = 0x80 + self.NumWays = 4 + + def valid_to_string(valid_d): + if valid_d == 0: + return 'A32' + elif valid_d == 1: + return 'T32' + elif valid_d == 2: + return 'A64' + else: + return 'Invalid' + + def parse_tag_fn(self, output, data, nset, nway): + if self.TagSize != 2: + raise Exception('cache tag size mismatch') + + valid_d = (data[0] >> 29) & 0x3 + ns = (data[0] >> 28) & 0x1 + addr = data[0] & 0xfffffff + + set_mode = self.valid_to_string(valid_d) + output.append(set_mode) + output.append(ns) + output.append(addr) + +class L1_DCache_KRYO3XX_GOLD(CacheDumpType_v1): + """Refer to documentation:ad003_atrm""" + def __init__(self): + super(L1_DCache_KRYO3XX_GOLD, self).__init__() + self.tableformat.addColumn('PA [43:12]') + self.tableformat.addColumn('MESI') + self.unsupported_header_offset = 0 + self.TagSize = 3 + self.LineSize = 16 + self.NumSets = 0x40 + self.NumWays = 16 + + def MESI_to_string(MESI_d): + if MESI_d == 0: + return 'I' + elif MESI_d == 1: + return 'S' + elif MESI_d == 2: + return 'E' + else: + return 'M' + + def parse_tag_fn(self, output, data, nset, nway): + if self.TagSize != 3: + raise Exception('cache tag size mismatch') + + addr_lower = (data[0] >> 10) & 0x3fffff + addr_higher = data[1] & 0x3ff + mesi_d = (data[0] >> 2) & 0x3 + + addr = (addr_higher << 22) | addr_lower + mesi = MESI_to_string(mesi_d) + output.append(addr) + output.append(mesi) + + +class L1_ICache_KRYO3XX_GOLD(CacheDumpType_v1): + """Refer to documentation:ad003_atrm""" + def __init__(self): + super(L1_ICache_KRYO3XX_GOLD, self).__init__() + self.tableformat.addColumn('Valid and set mode') + self.tableformat.addColumn('NS') + self.tableformat.addColumn('Tag address') + self.unsupported_header_offset = 0 + self.TagSize = 2 + self.LineSize = 16 + self.NumSets = 0x100 + self.NumWays = 4 + + def parse_tag_fn(self, output, data, nset, nway): + if self.TagSize != 2: + raise Exception('cache tag size mismatch') + + valid = (data[0] >> 29) & 0x1 + ns = (data[0] >> 28) & 0x1 + addr = data[0] & 0xfffffff + + output.append(valid) + output.append(ns) + output.append(addr) + L1_DCache_KRYO2XX_SILVER = L1_DCache_A53 L1_ICache_KYRO2XX_SILVER = L1_ICache_A53 +# "sdm845" +lookuptable[("sdm845", 0x80, 0x14)] = L1_DCache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x81, 0x14)] = L1_DCache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x82, 0x14)] = L1_DCache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x83, 0x14)] = L1_DCache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x84, 0x14)] = L1_DCache_KRYO3XX_GOLD() +lookuptable[("sdm845", 0x85, 0x14)] = L1_DCache_KRYO3XX_GOLD() +lookuptable[("sdm845", 0x86, 0x14)] = L1_DCache_KRYO3XX_GOLD() +lookuptable[("sdm845", 0x87, 0x14)] = L1_DCache_KRYO3XX_GOLD() + + +lookuptable[("sdm845", 0x60, 0x14)] = L1_ICache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x61, 0x14)] = L1_ICache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x62, 0x14)] = L1_ICache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x63, 0x14)] = L1_ICache_KRYO3XX_SILVER() +lookuptable[("sdm845", 0x64, 0x14)] = L1_ICache_KRYO3XX_GOLD() +lookuptable[("sdm845", 0x65, 0x14)] = L1_ICache_KRYO3XX_GOLD() +lookuptable[("sdm845", 0x66, 0x14)] = L1_ICache_KRYO3XX_GOLD() +lookuptable[("sdm845", 0x67, 0x14)] = L1_ICache_KRYO3XX_GOLD() + # "msmcobalt" lookuptable[("cobalt", 0x80, 0x14)] = L1_DCache_KRYO2XX_SILVER() lookuptable[("cobalt", 0x81, 0x14)] = L1_DCache_KRYO2XX_SILVER()