Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965986AbbDVJ6n (ORCPT ); Wed, 22 Apr 2015 05:58:43 -0400 Received: from 1.mo68.mail-out.ovh.net ([46.105.41.146]:50418 "EHLO 1.mo68.mail-out.ovh.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965955AbbDVJ6l (ORCPT ); Wed, 22 Apr 2015 05:58:41 -0400 X-Greylist: delayed 7801 seconds by postgrey-1.27 at vger.kernel.org; Wed, 22 Apr 2015 05:58:40 EDT Message-ID: <55374E8B.1040408@weksteen.fr> Date: Wed, 22 Apr 2015 17:32:27 +1000 From: =?UTF-8?B?VGhpw6liYXVkIFdla3N0ZWVu?= User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.6.0 MIME-Version: 1.0 To: linux-kernel@vger.kernel.org CC: Jan Kiszka Subject: [PATCH] scripts/gdb: Add command to check list consistency Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Ovh-Tracer-Id: 5671157831989023254 X-Ovh-Remote: 121.44.82.37 (ppp121-44-82-37.lns20.syd4.internode.on.net) X-Ovh-Local: 213.186.33.20 (ns0.ovh.net) X-OVH-SPAMSTATE: OK X-OVH-SPAMSCORE: -100 X-OVH-SPAMCAUSE: gggruggvucftvghtrhhoucdtuddrfeektddrheejucetufdoteggodetrfcurfhrohhfihhlvgemucfqggfjnecuuegrihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmd X-VR-SPAMSTATE: OK X-VR-SPAMSCORE: -100 X-VR-SPAMCAUSE: gggruggvucftvghtrhhoucdtuddrfeektddrheejucetufdoteggodetrfcurfhrohhfihhlvgemucfqggfjnecuuegrihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmd Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3391 Lines: 109 Add a gdb script to verify the consistency of lists. Signed-off-by: ThiƩbaud Weksteen --- scripts/gdb/linux/lists.py | 78 ++++++++++++++++++++++++++++++++++++++++++++++ scripts/gdb/vmlinux-gdb.py | 1 + 2 files changed, 79 insertions(+) create mode 100644 scripts/gdb/linux/lists.py diff --git a/scripts/gdb/linux/lists.py b/scripts/gdb/linux/lists.py new file mode 100644 index 0000000..d512f62 --- /dev/null +++ b/scripts/gdb/linux/lists.py @@ -0,0 +1,78 @@ +# +# gdb helper commands and functions for Linux kernel debugging +# +# list tools +# +# Authors: +# Thiebaud Weksteen +# +# This work is licensed under the terms of the GNU GPL version 2. +# + +import gdb + +from linux import utils + +list_head = utils.CachedType("struct list_head") + +def check_list(head): + nb = 0 + list_head_ptr_type = list_head.get_type().pointer() + c = head.cast(list_head_ptr_type) + try: + gdb.write("Starting with: {} {}\n".format(c, c.dereference())) + except gdb.MemoryError: + gdb.write('head is not accessible\n') + return + while True: + p = c['prev'] + n = c['next'] + try: + if p['next'] != c: + gdb.write('prev.next != current: current={current} ' + 'prev={p} prev.next={pnext}\n'.format( + current=c, + p=p, + pnext=p['next'] + )) + return + except gdb.MemoryError: + gdb.write('prev is not accessible: current={current} ' + 'current.prev={p}\n'.format( + current=c, + p=p + )) + return + try: + if n['prev'] != c: + gdb.write('next.prev != current: current={current} ' + 'next={n}, next.prev={nprev}\n'.format( + current=c, + n=n, + nprev=n['prev'] + )) + return + except gdb.MemoryError: + gdb.write('next is not accessible: current={current} ' + 'current.next={n}\n'.format( + current=c, + n=n + )) + return + c = n + nb += 1 + if c == head: + gdb.write("list is consistent: {} node(s)\n".format(nb)) + return + +class LxChkList(gdb.Command): + """Verify a list consistency""" + + def __init__(self): + super(LxChkList, self).__init__("lx-check-list", gdb.COMMAND_DATA) + + def invoke(self, arg, from_tty): + argv = gdb.string_to_argv(arg) + check_list(gdb.parse_and_eval(argv[0])) + +LxChkList() diff --git a/scripts/gdb/vmlinux-gdb.py b/scripts/gdb/vmlinux-gdb.py index 4848928..ce82bf5 100644 --- a/scripts/gdb/vmlinux-gdb.py +++ b/scripts/gdb/vmlinux-gdb.py @@ -28,3 +28,4 @@ else: import linux.dmesg import linux.tasks import linux.cpus + import linux.lists -- 2.1.0 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/