lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Mon, 21 Jan 2013 18:06:09 +0100 From: Jan Kiszka <jan.kiszka@...mens.com> To: Andrew Morton <akpm@...ux-foundation.org>, linux-kernel@...r.kernel.org Cc: Jason Wessel <jason.wessel@...driver.com>, kgdb-bugreport@...ts.sourceforge.net, Andi Kleen <andi@...stfloor.org>, Tom Tromey <tromey@...hat.com>, Ben Widawsky <ben@...dawsk.net> Subject: [PATCH v4 02/13] scripts/gdb: Add container_of helper and convenience function Provide an internal helper with container_of semantics. As type lookups are very slow in gdb-python and we need a type "long" for this, cache the reference to this type object. Then export the helper also as a convenience function form use at the gdb command line. Signed-off-by: Jan Kiszka <jan.kiszka@...mens.com> --- scripts/gdb/utils.py | 41 +++++++++++++++++++++++++++++++++++++++++ scripts/gdb/vmlinux-gdb.py | 2 ++ 2 files changed, 43 insertions(+), 0 deletions(-) diff --git a/scripts/gdb/utils.py b/scripts/gdb/utils.py index 65a2e91..2f6eafb 100644 --- a/scripts/gdb/utils.py +++ b/scripts/gdb/utils.py @@ -15,3 +15,44 @@ import gdb import re gdb_version = re.sub("^[^0-9]*", "", gdb.VERSION) + +long_type = None + +def get_type(type_name): + t = gdb.lookup_type(type_name) + if t == None: + raise gdb.GdbError("cannot resolve type '%s'" % type_name) + return t + +def get_long_type(): + global long_type + if long_type == None: + long_type = get_type("long") + return long_type + + +def offset_of(typeobj, field): + element = gdb.Value(0).cast(typeobj) + return int(str(element[field].address).split()[0], 16) + +def container_of(ptr, typeobj, member): + return (ptr.cast(get_long_type()) - + offset_of(typeobj, member)).cast(typeobj) + + +class ContainerOf(gdb.Function): + __doc__ = "Return pointer to containing data structure.\n" \ + "\n" \ + "$container_of(PTR, \"TYPE\", \"ELEMENT\"): Given PTR, return a pointer to the\n" \ + "data structure of the type TYPE in which PTR is the address of ELEMENT.\n" \ + "Note that TYPE and ELEMENT have to be quoted as strings." + + def __init__(self): + super(ContainerOf, self).__init__("container_of") + + def invoke(self, ptr, typename, elementname): + return container_of(ptr, + gdb.lookup_type(typename.string()).pointer(), + elementname.string()) + +ContainerOf() diff --git a/scripts/gdb/vmlinux-gdb.py b/scripts/gdb/vmlinux-gdb.py index bcb45cc..8ef76c9 100644 --- a/scripts/gdb/vmlinux-gdb.py +++ b/scripts/gdb/vmlinux-gdb.py @@ -20,3 +20,5 @@ from utils import gdb_version if gdb_version < "7.1": print "NOTE: gdb 7.1 or later required for Linux helper scripts " \ "to work." +else: + import utils -- 1.7.3.4 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists