36 lines
1.1 KiB
Diff
36 lines
1.1 KiB
Diff
From 141ba113386b9bfd3698eb3f20efd30d72905fbd Mon Sep 17 00:00:00 2001
|
|
From: Peter Zijlstra <peterz@infradead.org>
|
|
Date: Tue, 21 Jun 2011 11:22:36 +0200
|
|
Subject: [PATCH 056/278] list-add-list-last-entry.patch
|
|
|
|
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
|
|
---
|
|
include/linux/list.h | 11 +++++++++++
|
|
1 file changed, 11 insertions(+)
|
|
|
|
diff --git a/include/linux/list.h b/include/linux/list.h
|
|
index cc6d2aa..7a9851b 100644
|
|
--- a/include/linux/list.h
|
|
+++ b/include/linux/list.h
|
|
@@ -362,6 +362,17 @@ static inline void list_splice_tail_init(struct list_head *list,
|
|
list_entry((ptr)->next, type, member)
|
|
|
|
/**
|
|
+ * list_last_entry - get the last element from a list
|
|
+ * @ptr: the list head to take the element from.
|
|
+ * @type: the type of the struct this is embedded in.
|
|
+ * @member: the name of the list_struct within the struct.
|
|
+ *
|
|
+ * Note, that list is expected to be not empty.
|
|
+ */
|
|
+#define list_last_entry(ptr, type, member) \
|
|
+ list_entry((ptr)->prev, type, member)
|
|
+
|
|
+/**
|
|
* list_for_each - iterate over a list
|
|
* @pos: the &struct list_head to use as a loop cursor.
|
|
* @head: the head for your list.
|
|
--
|
|
1.7.10
|
|
|