X-Git-Url: https://sigrok.org/gitweb/?p=sigrok-util.git;a=blobdiff_plain;f=firmware%2Fkingst-la%2Fsigrok-fwextract-kingst-la2016;h=0bcf9bf9d501edf8b7bf4a3743894a9087931898;hp=ac626bc5113bee8a3c1a892f351d203d52a90eda;hb=64859badb1221edccb103b6eadfbda9e760ed9a9;hpb=d22be723ad1e225939dd0ab1d32829aca4ccfafc diff --git a/firmware/kingst-la/sigrok-fwextract-kingst-la2016 b/firmware/kingst-la/sigrok-fwextract-kingst-la2016 index ac626bc..0bcf9bf 100755 --- a/firmware/kingst-la/sigrok-fwextract-kingst-la2016 +++ b/firmware/kingst-la/sigrok-fwextract-kingst-la2016 @@ -99,24 +99,31 @@ class qt_resources(object): child_count, first_child = which[2:] for i in range(child_count): child = table[first_child + i] - if child[1] & RCCFileInfo_Directory: + flags = child[1] + if flags & RCCFileInfo_Directory: read_dir_entries(table, child, parents + [child[0]]) else: country, language, data_offset = child[2:] full_name = "/".join(parents + [child[0]]) self._resources[full_name] = data_offset + self._resource_flags[full_name] = flags self._res_datas = self._get_elf_sym_value("_ZL16qt_resource_data") self._res_names = self._get_elf_sym_value("_ZL16qt_resource_name") self._res_struct = self._get_elf_sym_value("_ZL18qt_resource_struct") self._resources = {} # res_fn -> res_offset + self._resource_flags = {} # res_fn -> RCC_flags table = read_table() read_dir_entries(table, table[0]) def get_resource(self, res_fn): + RCCFileInfo_Compressed = 1 offset = self._resources[res_fn] + flags = self._resource_flags[res_fn] data = self._get_resource_data(offset) + if flags & RCCFileInfo_Compressed: + data = zlib.decompress(data[4:]) return data def find_resource_names(self, res_fn_re): @@ -129,25 +136,28 @@ class res_writer(object): def __init__(self, res): self.res = res - def _write_file(self, fn, data, decoder=None, zero_pad_to=None): + def _decode_crc(self, data, decoder=None): if decoder is not None: data = decoder(data) - if zero_pad_to is not None: - if len(data) > zero_pad_to: - raise Exception("can not zero_pad_to %d bytes -- data is already %d bytes" % (zero_pad_to, len(data))) - data += b"\0" * (zero_pad_to - len(data)) + data = bytearray(data) + crc = zlib.crc32(data) & 0xffffffff + return data, crc + + def _write_file(self, fn, data): with open(fn, "wb") as fp: fp.write(data) - data_crc32 = zlib.crc32(data) & 0xffffffff - print("saved %d bytes to %s (crc32=%08x)" % (len(data), fn, data_crc32)) - def extract(self, res_fn, out_fn, decoder=None, zero_pad_to=None): - self._write_file(out_fn, self.res.get_resource(res_fn), decoder=decoder, zero_pad_to=zero_pad_to) - - def extract_re(self, res_fn_re, out_fn, decoder=None): - for res_fn in res.find_resource_names(res_fn_re): - fn = re.sub(res_fn_re, out_fn, res_fn).lower() - self._write_file(fn, self.res.get_resource(res_fn), decoder=decoder) + def extract_re(self, resource_pattern, fname_pattern, decoder=None): + resources = sorted(res.find_resource_names(resource_pattern)) + for resource in resources: + fname = re.sub(resource_pattern, fname_pattern, resource) + fname = fname.lower() + data = self.res.get_resource(resource) + data, crc = self._decode_crc(data, decoder=decoder) + self._write_file(fname, data) + print("resource {rsc}, file {fname}, size {size}, checksum {crc:08x}".format( + rsc = resource, fname = fname, size = len(data), crc = crc, + )) def decode_intel_hex(hexdata): """ return list of (address, data) @@ -198,21 +208,14 @@ if __name__ == "__main__": exe_fn = options.executable res = qt_resources(exe_fn) - writer = res_writer(res) - # extract all firmware and fpga bitstreams - # writer.extract_re(r"fwfpga/(.*)", r"kingst-\1-fpga.bitstream") - # writer.extract_re(r"fwusb/fw(.*)", r"kingst-la-\1.fw", decoder=maybe_intel_hex_as_blob) - - # extract fx2 mcu firmware for both the la2016 and la1016 - # note that 0x01a2 is the usb pid for both of these devices - writer.extract_re("fwusb/fw01A2", "kingst-la-01a2.fw", decoder=maybe_intel_hex_as_blob) - - # extract fpga bitstreams for la2016 - # there are two bitstreams, newer hardware uses the 'a1' bitstream - writer.extract_re("fwfpga/LA2016(.*)", r"kingst-la2016\1-fpga.bitstream") - - # extract fpga bitstreams for la1016 - # there are two bitstreams, newer hardware uses the 'a1' bitstream - writer.extract_re("fwfpga/LA1016(.*)", r"kingst-la1016\1-fpga.bitstream") + # Extract all MCU firmware and FPGA bitstream images. The sigrok + # project may not cover all KingstVIS supported devices. Users can + # either just copy those files which are strictly required for their + # specific device (diagnostics will identify those). Or just copy a + # few more files while some of them remain unused later (their size + # is small). Seeing which files would be contained is considered + # valuable, to identify device variants or candidate models. + writer.extract_re(r"fwusb/fw(.*)", r"kingst-la-\1.fw", decoder=maybe_intel_hex_as_blob) + writer.extract_re(r"fwfpga/(.*)", r"kingst-\1-fpga.bitstream")