2011-01-12 06:56:53 +08:00
|
|
|
#include <linux/kernel.h>
|
2011-05-22 16:07:37 +08:00
|
|
|
|
2009-07-02 01:46:08 +08:00
|
|
|
#include "../../../../include/linux/list.h"
|
|
|
|
|
|
|
|
#ifndef PERF_LIST_H
|
|
|
|
#define PERF_LIST_H
|
|
|
|
/**
|
|
|
|
* list_del_range - deletes range of entries from list.
|
|
|
|
* @begin: first element in the range to delete from the list.
|
|
|
|
* @end: last element in the range to delete from the list.
|
|
|
|
* Note: list_empty on the range of entries does not return true after this,
|
|
|
|
* the entries is in an undefined state.
|
|
|
|
*/
|
|
|
|
static inline void list_del_range(struct list_head *begin,
|
|
|
|
struct list_head *end)
|
|
|
|
{
|
|
|
|
begin->prev->next = end->next;
|
|
|
|
end->next->prev = begin->prev;
|
|
|
|
}
|
2010-08-07 03:51:12 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* list_for_each_from - iterate over a list from one of its nodes
|
|
|
|
* @pos: the &struct list_head to use as a loop cursor, from where to start
|
|
|
|
* @head: the head for your list.
|
|
|
|
*/
|
|
|
|
#define list_for_each_from(pos, head) \
|
2011-05-21 03:50:29 +08:00
|
|
|
for (; pos != (head); pos = pos->next)
|
2009-07-02 01:46:08 +08:00
|
|
|
#endif
|