Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754329Ab0AGWBK (ORCPT ); Thu, 7 Jan 2010 17:01:10 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754322Ab0AGWBA (ORCPT ); Thu, 7 Jan 2010 17:01:00 -0500 Received: from casper.infradead.org ([85.118.1.10]:50254 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752406Ab0AGV7z (ORCPT ); Thu, 7 Jan 2010 16:59:55 -0500 From: Arnaldo Carvalho de Melo To: Ingo Molnar Cc: linux-kernel@vger.kernel.org, Arnaldo Carvalho de Melo , =?utf-8?q?Fr=C3=A9d=C3=A9ric=20Weisbecker?= , Mike Galbraith , Peter Zijlstra , Paul Mackerras Subject: [PATCH 4/6] rbtree: Introduce rb_for_each_entry Date: Thu, 7 Jan 2010 19:59:41 -0200 Message-Id: <1262901583-8074-4-git-send-email-acme@infradead.org> X-Mailer: git-send-email 1.6.2.5 In-Reply-To: <1262901583-8074-1-git-send-email-acme@infradead.org> References: <1262901583-8074-1-git-send-email-acme@infradead.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-SRS-Rewrite: SMTP reverse-path rewritten from by casper.infradead.org See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1570 Lines: 45 From: Arnaldo Carvalho de Melo Similar to list_for_each_entry, helps reducing boilerplate in many places and makes rbtrees closer to list.h macros. First conversion will be in the tools/perf. Cc: Frédéric Weisbecker Cc: Mike Galbraith Cc: Peter Zijlstra Cc: Paul Mackerras Signed-off-by: Arnaldo Carvalho de Melo --- include/linux/rbtree.h | 12 ++++++++++++ 1 files changed, 12 insertions(+), 0 deletions(-) diff --git a/include/linux/rbtree.h b/include/linux/rbtree.h index 9c29541..044b150 100644 --- a/include/linux/rbtree.h +++ b/include/linux/rbtree.h @@ -158,4 +158,16 @@ static inline void rb_link_node(struct rb_node * node, struct rb_node * parent, *rb_link = node; } +/** + * rb_for_each_entry - iterate over rbtree of given type + * @pos: the type * to hold the current entry being traversed + * @node: the rb_node to hold the current entry being traversed + * @root: the root for your tree. + * @member: the name of the rb_node within the struct. + */ +#define rb_for_each_entry(pos, node, root, member) \ + for (node = rb_first(root); \ + node && (pos = rb_entry(node, typeof(*pos), member)); \ + node = rb_next(node)) + #endif /* _LINUX_RBTREE_H */ -- 1.6.2.5 -- 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/