提交 626ab0e6 编写于 作者: O Oleg Nesterov 提交者: Linus Torvalds

[PATCH] list: use list_replace_init() instead of list_splice_init()

list_splice_init(list, head) does unneeded job if it is known that
list_empty(head) == 1.  We can use list_replace_init() instead.
Signed-off-by: NOleg Nesterov <oleg@tv-sign.ru>
Acked-by: NDavid S. Miller <davem@davemloft.net>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 54e73770
...@@ -209,19 +209,19 @@ int change_page_attr(struct page *page, int numpages, pgprot_t prot) ...@@ -209,19 +209,19 @@ int change_page_attr(struct page *page, int numpages, pgprot_t prot)
} }
void global_flush_tlb(void) void global_flush_tlb(void)
{ {
LIST_HEAD(l); struct list_head l;
struct page *pg, *next; struct page *pg, *next;
BUG_ON(irqs_disabled()); BUG_ON(irqs_disabled());
spin_lock_irq(&cpa_lock); spin_lock_irq(&cpa_lock);
list_splice_init(&df_list, &l); list_replace_init(&df_list, &l);
spin_unlock_irq(&cpa_lock); spin_unlock_irq(&cpa_lock);
flush_map(); flush_map();
list_for_each_entry_safe(pg, next, &l, lru) list_for_each_entry_safe(pg, next, &l, lru)
__free_page(pg); __free_page(pg);
} }
#ifdef CONFIG_DEBUG_PAGEALLOC #ifdef CONFIG_DEBUG_PAGEALLOC
void kernel_map_pages(struct page *page, int numpages, int enable) void kernel_map_pages(struct page *page, int numpages, int enable)
......
...@@ -3359,12 +3359,11 @@ EXPORT_SYMBOL(end_that_request_chunk); ...@@ -3359,12 +3359,11 @@ EXPORT_SYMBOL(end_that_request_chunk);
*/ */
static void blk_done_softirq(struct softirq_action *h) static void blk_done_softirq(struct softirq_action *h)
{ {
struct list_head *cpu_list; struct list_head *cpu_list, local_list;
LIST_HEAD(local_list);
local_irq_disable(); local_irq_disable();
cpu_list = &__get_cpu_var(blk_cpu_done); cpu_list = &__get_cpu_var(blk_cpu_done);
list_splice_init(cpu_list, &local_list); list_replace_init(cpu_list, &local_list);
local_irq_enable(); local_irq_enable();
while (!list_empty(&local_list)) { while (!list_empty(&local_list)) {
......
...@@ -777,11 +777,11 @@ out: ...@@ -777,11 +777,11 @@ out:
static int __aio_run_iocbs(struct kioctx *ctx) static int __aio_run_iocbs(struct kioctx *ctx)
{ {
struct kiocb *iocb; struct kiocb *iocb;
LIST_HEAD(run_list); struct list_head run_list;
assert_spin_locked(&ctx->ctx_lock); assert_spin_locked(&ctx->ctx_lock);
list_splice_init(&ctx->run_list, &run_list); list_replace_init(&ctx->run_list, &run_list);
while (!list_empty(&run_list)) { while (!list_empty(&run_list)) {
iocb = list_entry(run_list.next, struct kiocb, iocb = list_entry(run_list.next, struct kiocb,
ki_run_list); ki_run_list);
......
...@@ -419,10 +419,10 @@ static inline void __run_timers(tvec_base_t *base) ...@@ -419,10 +419,10 @@ static inline void __run_timers(tvec_base_t *base)
spin_lock_irq(&base->lock); spin_lock_irq(&base->lock);
while (time_after_eq(jiffies, base->timer_jiffies)) { while (time_after_eq(jiffies, base->timer_jiffies)) {
struct list_head work_list = LIST_HEAD_INIT(work_list); struct list_head work_list;
struct list_head *head = &work_list; struct list_head *head = &work_list;
int index = base->timer_jiffies & TVR_MASK; int index = base->timer_jiffies & TVR_MASK;
/* /*
* Cascade timers: * Cascade timers:
*/ */
...@@ -431,8 +431,8 @@ static inline void __run_timers(tvec_base_t *base) ...@@ -431,8 +431,8 @@ static inline void __run_timers(tvec_base_t *base)
(!cascade(base, &base->tv3, INDEX(1))) && (!cascade(base, &base->tv3, INDEX(1))) &&
!cascade(base, &base->tv4, INDEX(2))) !cascade(base, &base->tv4, INDEX(2)))
cascade(base, &base->tv5, INDEX(3)); cascade(base, &base->tv5, INDEX(3));
++base->timer_jiffies; ++base->timer_jiffies;
list_splice_init(base->tv1.vec + index, &work_list); list_replace_init(base->tv1.vec + index, &work_list);
while (!list_empty(head)) { while (!list_empty(head)) {
void (*fn)(unsigned long); void (*fn)(unsigned long);
unsigned long data; unsigned long data;
......
...@@ -531,11 +531,11 @@ int current_is_keventd(void) ...@@ -531,11 +531,11 @@ int current_is_keventd(void)
static void take_over_work(struct workqueue_struct *wq, unsigned int cpu) static void take_over_work(struct workqueue_struct *wq, unsigned int cpu)
{ {
struct cpu_workqueue_struct *cwq = per_cpu_ptr(wq->cpu_wq, cpu); struct cpu_workqueue_struct *cwq = per_cpu_ptr(wq->cpu_wq, cpu);
LIST_HEAD(list); struct list_head list;
struct work_struct *work; struct work_struct *work;
spin_lock_irq(&cwq->lock); spin_lock_irq(&cwq->lock);
list_splice_init(&cwq->worklist, &list); list_replace_init(&cwq->worklist, &list);
while (!list_empty(&list)) { while (!list_empty(&list)) {
printk("Taking work for %s\n", wq->name); printk("Taking work for %s\n", wq->name);
......
...@@ -2980,7 +2980,7 @@ static void netdev_wait_allrefs(struct net_device *dev) ...@@ -2980,7 +2980,7 @@ static void netdev_wait_allrefs(struct net_device *dev)
static DEFINE_MUTEX(net_todo_run_mutex); static DEFINE_MUTEX(net_todo_run_mutex);
void netdev_run_todo(void) void netdev_run_todo(void)
{ {
struct list_head list = LIST_HEAD_INIT(list); struct list_head list;
/* Need to guard against multiple cpu's getting out of order. */ /* Need to guard against multiple cpu's getting out of order. */
mutex_lock(&net_todo_run_mutex); mutex_lock(&net_todo_run_mutex);
...@@ -2995,9 +2995,9 @@ void netdev_run_todo(void) ...@@ -2995,9 +2995,9 @@ void netdev_run_todo(void)
/* Snapshot list, allow later requests */ /* Snapshot list, allow later requests */
spin_lock(&net_todo_list_lock); spin_lock(&net_todo_list_lock);
list_splice_init(&net_todo_list, &list); list_replace_init(&net_todo_list, &list);
spin_unlock(&net_todo_list_lock); spin_unlock(&net_todo_list_lock);
while (!list_empty(&list)) { while (!list_empty(&list)) {
struct net_device *dev struct net_device *dev
= list_entry(list.next, struct net_device, todo_list); = list_entry(list.next, struct net_device, todo_list);
......
...@@ -91,11 +91,10 @@ static void rfc2863_policy(struct net_device *dev) ...@@ -91,11 +91,10 @@ static void rfc2863_policy(struct net_device *dev)
/* Must be called with the rtnl semaphore held */ /* Must be called with the rtnl semaphore held */
void linkwatch_run_queue(void) void linkwatch_run_queue(void)
{ {
LIST_HEAD(head); struct list_head head, *n, *next;
struct list_head *n, *next;
spin_lock_irq(&lweventlist_lock); spin_lock_irq(&lweventlist_lock);
list_splice_init(&lweventlist, &head); list_replace_init(&lweventlist, &head);
spin_unlock_irq(&lweventlist_lock); spin_unlock_irq(&lweventlist_lock);
list_for_each_safe(n, next, &head) { list_for_each_safe(n, next, &head) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册