#!/usr/bin/env python # BlueKitchen GmbH (c) 2017 # primitive dump for .tlv format import re import sys import time import datetime def read_net_32(f): a = f.read(1) if a == '': return -1 b = f.read(1) if b == '': return -1 c = f.read(1) if c == '': return -1 d = f.read(1) if d == '': return -1 return ord(a) << 24 | ord(b) << 16 | ord(c) << 8 | ord(d) def as_hex(data): str_list = [] for byte in data: str_list.append("{0:02x} ".format(ord(byte))) return ''.join(str_list) if len(sys.argv) == 1: print 'Dump TLV file' print 'Copyright 2017, BlueKitchen GmbH' print '' print 'Usage: ', sys.argv[0], 'file.tlv' exit(0) infile = sys.argv[1] with open (infile, 'rb') as fin: pos = 0 try: # check header magic_0 = read_net_32(fin) magic_1 = read_net_32(fin) if magic_0 != 0x42547374 or magic_1 != 0x61636b00: print("%x" % magic_0) print("%x" % magic_1) print ("Not a valid BTstack .tlv file\n") exit(0) pos += 8 print("Valid .tlv file") while True: tag = read_net_32(fin) if tag < 0: break pos += 4 len = read_net_32(fin) pos += 4 packet = fin.read(len) pos += len print('%04x: ' % tag + as_hex(packet)) print("Done") except TypeError: print ("Error parsing tlv at offset %u (%x)." % (pos, pos))