diff options
Diffstat (limited to 'kernel/trace/ring_buffer.c')
-rw-r--r-- | kernel/trace/ring_buffer.c | 41 |
1 files changed, 15 insertions, 26 deletions
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c index 68388f876d43..6420cda62336 100644 --- a/kernel/trace/ring_buffer.c +++ b/kernel/trace/ring_buffer.c | |||
@@ -473,7 +473,7 @@ struct ring_buffer_per_cpu { | |||
473 | int nr_pages_to_update; | 473 | int nr_pages_to_update; |
474 | struct list_head new_pages; /* new pages to add */ | 474 | struct list_head new_pages; /* new pages to add */ |
475 | struct work_struct update_pages_work; | 475 | struct work_struct update_pages_work; |
476 | struct completion update_completion; | 476 | struct completion update_done; |
477 | }; | 477 | }; |
478 | 478 | ||
479 | struct ring_buffer { | 479 | struct ring_buffer { |
@@ -1058,7 +1058,7 @@ rb_allocate_cpu_buffer(struct ring_buffer *buffer, int nr_pages, int cpu) | |||
1058 | lockdep_set_class(&cpu_buffer->reader_lock, buffer->reader_lock_key); | 1058 | lockdep_set_class(&cpu_buffer->reader_lock, buffer->reader_lock_key); |
1059 | cpu_buffer->lock = (arch_spinlock_t)__ARCH_SPIN_LOCK_UNLOCKED; | 1059 | cpu_buffer->lock = (arch_spinlock_t)__ARCH_SPIN_LOCK_UNLOCKED; |
1060 | INIT_WORK(&cpu_buffer->update_pages_work, update_pages_handler); | 1060 | INIT_WORK(&cpu_buffer->update_pages_work, update_pages_handler); |
1061 | init_completion(&cpu_buffer->update_completion); | 1061 | init_completion(&cpu_buffer->update_done); |
1062 | 1062 | ||
1063 | bpage = kzalloc_node(ALIGN(sizeof(*bpage), cache_line_size()), | 1063 | bpage = kzalloc_node(ALIGN(sizeof(*bpage), cache_line_size()), |
1064 | GFP_KERNEL, cpu_to_node(cpu)); | 1064 | GFP_KERNEL, cpu_to_node(cpu)); |
@@ -1461,7 +1461,7 @@ static void update_pages_handler(struct work_struct *work) | |||
1461 | struct ring_buffer_per_cpu *cpu_buffer = container_of(work, | 1461 | struct ring_buffer_per_cpu *cpu_buffer = container_of(work, |
1462 | struct ring_buffer_per_cpu, update_pages_work); | 1462 | struct ring_buffer_per_cpu, update_pages_work); |
1463 | rb_update_pages(cpu_buffer); | 1463 | rb_update_pages(cpu_buffer); |
1464 | complete(&cpu_buffer->update_completion); | 1464 | complete(&cpu_buffer->update_done); |
1465 | } | 1465 | } |
1466 | 1466 | ||
1467 | /** | 1467 | /** |
@@ -1534,39 +1534,29 @@ int ring_buffer_resize(struct ring_buffer *buffer, unsigned long size, | |||
1534 | get_online_cpus(); | 1534 | get_online_cpus(); |
1535 | /* | 1535 | /* |
1536 | * Fire off all the required work handlers | 1536 | * Fire off all the required work handlers |
1537 | * Look out for offline CPUs | 1537 | * We can't schedule on offline CPUs, but it's not necessary |
1538 | */ | ||
1539 | for_each_buffer_cpu(buffer, cpu) { | ||
1540 | cpu_buffer = buffer->buffers[cpu]; | ||
1541 | if (!cpu_buffer->nr_pages_to_update || | ||
1542 | !cpu_online(cpu)) | ||
1543 | continue; | ||
1544 | |||
1545 | schedule_work_on(cpu, &cpu_buffer->update_pages_work); | ||
1546 | } | ||
1547 | /* | ||
1548 | * This loop is for the CPUs that are not online. | ||
1549 | * We can't schedule anything on them, but it's not necessary | ||
1550 | * since we can change their buffer sizes without any race. | 1538 | * since we can change their buffer sizes without any race. |
1551 | */ | 1539 | */ |
1552 | for_each_buffer_cpu(buffer, cpu) { | 1540 | for_each_buffer_cpu(buffer, cpu) { |
1553 | cpu_buffer = buffer->buffers[cpu]; | 1541 | cpu_buffer = buffer->buffers[cpu]; |
1554 | if (!cpu_buffer->nr_pages_to_update || | 1542 | if (!cpu_buffer->nr_pages_to_update) |
1555 | cpu_online(cpu)) | ||
1556 | continue; | 1543 | continue; |
1557 | 1544 | ||
1558 | rb_update_pages(cpu_buffer); | 1545 | if (cpu_online(cpu)) |
1546 | schedule_work_on(cpu, | ||
1547 | &cpu_buffer->update_pages_work); | ||
1548 | else | ||
1549 | rb_update_pages(cpu_buffer); | ||
1559 | } | 1550 | } |
1560 | 1551 | ||
1561 | /* wait for all the updates to complete */ | 1552 | /* wait for all the updates to complete */ |
1562 | for_each_buffer_cpu(buffer, cpu) { | 1553 | for_each_buffer_cpu(buffer, cpu) { |
1563 | cpu_buffer = buffer->buffers[cpu]; | 1554 | cpu_buffer = buffer->buffers[cpu]; |
1564 | if (!cpu_buffer->nr_pages_to_update || | 1555 | if (!cpu_buffer->nr_pages_to_update) |
1565 | !cpu_online(cpu)) | ||
1566 | continue; | 1556 | continue; |
1567 | 1557 | ||
1568 | wait_for_completion(&cpu_buffer->update_completion); | 1558 | if (cpu_online(cpu)) |
1569 | /* reset this value */ | 1559 | wait_for_completion(&cpu_buffer->update_done); |
1570 | cpu_buffer->nr_pages_to_update = 0; | 1560 | cpu_buffer->nr_pages_to_update = 0; |
1571 | } | 1561 | } |
1572 | 1562 | ||
@@ -1593,13 +1583,12 @@ int ring_buffer_resize(struct ring_buffer *buffer, unsigned long size, | |||
1593 | if (cpu_online(cpu_id)) { | 1583 | if (cpu_online(cpu_id)) { |
1594 | schedule_work_on(cpu_id, | 1584 | schedule_work_on(cpu_id, |
1595 | &cpu_buffer->update_pages_work); | 1585 | &cpu_buffer->update_pages_work); |
1596 | wait_for_completion(&cpu_buffer->update_completion); | 1586 | wait_for_completion(&cpu_buffer->update_done); |
1597 | } else | 1587 | } else |
1598 | rb_update_pages(cpu_buffer); | 1588 | rb_update_pages(cpu_buffer); |
1599 | 1589 | ||
1600 | put_online_cpus(); | ||
1601 | /* reset this value */ | ||
1602 | cpu_buffer->nr_pages_to_update = 0; | 1590 | cpu_buffer->nr_pages_to_update = 0; |
1591 | put_online_cpus(); | ||
1603 | } | 1592 | } |
1604 | 1593 | ||
1605 | out: | 1594 | out: |