2 # gdb helper commands and functions for Linux kernel debugging
6 # Copyright (c) Siemens AG, 2011-2013
11 # This work is licensed under the terms of the GNU GPL version 2.
18 def __init__(self, name):
22 def _new_objfile_handler(self, event):
24 gdb.events.new_objfile.disconnect(self._new_objfile_handler)
27 if self._type is None:
28 self._type = gdb.lookup_type(self._name)
29 if self._type is None:
31 "cannot resolve type '{0}'".format(self._name))
32 if hasattr(gdb, 'events') and hasattr(gdb.events, 'new_objfile'):
33 gdb.events.new_objfile.connect(self._new_objfile_handler)
37 long_type = CachedType("long")
42 return long_type.get_type()
45 def offset_of(typeobj, field):
46 element = gdb.Value(0).cast(typeobj)
47 return int(str(element[field].address).split()[0], 16)
50 def container_of(ptr, typeobj, member):
51 return (ptr.cast(get_long_type()) -
52 offset_of(typeobj, member)).cast(typeobj)
55 class ContainerOf(gdb.Function):
56 """Return pointer to containing data structure.
58 $container_of(PTR, "TYPE", "ELEMENT"): Given PTR, return a pointer to the
59 data structure of the type TYPE in which PTR is the address of ELEMENT.
60 Note that TYPE and ELEMENT have to be quoted as strings."""
63 super(ContainerOf, self).__init__("container_of")
65 def invoke(self, ptr, typename, elementname):
66 return container_of(ptr, gdb.lookup_type(typename.string()).pointer(),
75 target_endianness = None
78 def get_target_endianness():
79 global target_endianness
80 if target_endianness is None:
81 endian = gdb.execute("show endian", to_string=True)
82 if "little endian" in endian:
83 target_endianness = LITTLE_ENDIAN
84 elif "big endian" in endian:
85 target_endianness = BIG_ENDIAN
87 raise gdb.GdbError("unknown endianness '{0}'".format(str(endian)))
88 return target_endianness
91 def read_memoryview(inf, start, length):
92 return memoryview(inf.read_memory(start, length))
98 if type(buffer[0]) is str:
99 value[0] = ord(buffer[0])
100 value[1] = ord(buffer[1])
105 if get_target_endianness() == LITTLE_ENDIAN:
106 return value[0] + (value[1] << 8)
108 return value[1] + (value[0] << 8)
111 def read_u32(buffer):
112 if get_target_endianness() == LITTLE_ENDIAN:
113 return read_u16(buffer[0:2]) + (read_u16(buffer[2:4]) << 16)
115 return read_u16(buffer[2:4]) + (read_u16(buffer[0:2]) << 16)
118 def read_u64(buffer):
119 if get_target_endianness() == LITTLE_ENDIAN:
120 return read_u32(buffer[0:4]) + (read_u32(buffer[4:8]) << 32)
122 return read_u32(buffer[4:8]) + (read_u32(buffer[0:4]) << 32)
128 def is_target_arch(arch):
129 if hasattr(gdb.Frame, 'architecture'):
130 return arch in gdb.newest_frame().architecture().name()
133 if target_arch is None:
134 target_arch = gdb.execute("show architecture", to_string=True)
135 return arch in target_arch
140 gdbserver_type = None
143 def get_gdbserver_type():
144 def exit_handler(event):
145 global gdbserver_type
146 gdbserver_type = None
147 gdb.events.exited.disconnect(exit_handler)
151 return gdb.execute("monitor info version", to_string=True) != ""
157 thread_info = gdb.execute("info thread 2", to_string=True)
158 return "shadowCPU0" in thread_info
162 global gdbserver_type
163 if gdbserver_type is None:
165 gdbserver_type = GDBSERVER_QEMU
167 gdbserver_type = GDBSERVER_KGDB
168 if gdbserver_type is not None and hasattr(gdb, 'events'):
169 gdb.events.exited.connect(exit_handler)
170 return gdbserver_type
173 def gdb_eval_or_none(expresssion):
175 return gdb.parse_and_eval(expresssion)
181 parent = d['d_parent']
182 if parent == d or parent == 0:
184 p = dentry_name(d['d_parent']) + "/"
185 return p + d['d_iname'].string()