public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/3] x86: remove extraneous stack cpumask variables
@ 2008-09-09 15:50 Mike Travis
  2008-09-09 15:50 ` [PATCH 1/3] cpumask: add for_each_online_cpu_mask_nr function Mike Travis
                   ` (2 more replies)
  0 siblings, 3 replies; 6+ messages in thread
From: Mike Travis @ 2008-09-09 15:50 UTC (permalink / raw)
  To: Ingo Molnar, Andrew Morton
  Cc: Thomas Gleixner, H. Peter Anvin, Jack Steiner, Jes Sorensen,
	linux-kernel


Some more minor cleanups in cpumask stack usage with no new cpumask
functions (except for the for_each_online_cpu_mask_nr call).  Frees
up more memory for the stack.  Also, cleans up the genapic API to
always pass pointers (for both 32 and 64) and to not return cpumask
function values.

  * Add for_each_online_cpu_mask_nr to eliminate a common case of needing
    a temporary on-stack cpumask_t variable.

  * Change the genapic->send_IPI_mask function to accept cpumask_t pointer.

  * Rewrite "send_IPI_allbutself" to not need a temp cpumask_t variable.

  * Change send_IPI_mask function in xen to use for_each_online_cpu_mask_nr().

  * Modify internal io_apic.c functions to accept cpumask_t pointer where
    possible.


Applies to linux-2.6.tip/master.

Signed-off-by: Mike Travis <travis@sgi.com>
---

Summary from allmodconfig (NR_CPUS=4k, #NODES=512)

====== Stack (-l 500)
... files 4 vars 144 all 0 lim 500 unch 0

    1 - initial
    3 - send_IPI_mask
    4 - stack-hogs-kernel_sched_c

   .1.    .3.   .4.    ..final..
  1608  -1008     .  600   -62%  setup_IO_APIC_irq
  1592  -1024     .  568   -64%  msi_compose_msg
  1576      .  -512 1064   -32%  move_task_off_dead_cpu
  1560  -1024     .  536   -65%  setup_ioapic_dest
  1560  -1008     .  552   -64%  migrate_ioapic_irq
  1560  -1032     .  528   -66%  arch_setup_ht_irq
  1560  -1008     .  552   -64%  __assign_irq_vector
  1552  -1024     .  528   -65%  ir_set_msi_irq_affinity
  1144   -512     .  632   -44%  setup_IO_APIC
  1048   -520     .  528   -49%  setup_timer_IRQ0_pin
  1048  -1048     .    .  -100%  native_machine_crash_shutdown
  1048   -512     .  536   -48%  native_flush_tlb_others
  1040   -512     .  528   -49%  set_msi_irq_affinity
  1040   -512     .  528   -49%  set_ht_irq_affinity
  1040   -512     .  528   -49%  hpet_msi_set_affinity
  1040   -512     .  528   -49%  dmar_msi_set_affinity
  1032  -1032     .    .  -100%  set_ioapic_affinity_irq
  1032   -520     .  512   -50%  irq_complete_move
  1032   -520     .  512   -50%  create_irq_nr
  1024  -1024     .    .  -100%  x2apic_vector_allocation_domain
  1024  -1024     .    .  -100%  x2apic_send_IPI_allbutself
  1024  -1024     .    .  -100%  uv_vector_allocation_domain
  1024  -1024     .    .  -100%  uv_send_IPI_allbutself
  1024  -1024     .    .  -100%  physflat_send_IPI_allbutself
  1024  -1024     .    .  -100%  native_send_call_func_ipi
  1024  -1024     .    .  -100%  flat_send_IPI_allbutself
   552      .  -552    .  -100%  free_sched_groups
   520   -520     .    .  -100%  x2apic_send_IPI_all
   520   -520     .    .  -100%  uv_send_IPI_all
   520   -520     .    .  -100%  set_ir_ioapic_affinity_irq
   520   -520     .    .  -100%  physflat_send_IPI_mask
   520   -520     .    .  -100%  physflat_send_IPI_all
   520   -520     .    .  -100%  native_smp_send_reschedule
   520   -520     .    .  -100%  native_send_call_func_single_ipi
   520   -520     .    .  -100%  lapic_timer_broadcast
   512   -512     .    .  -100%  xen_smp_send_call_function_single_ipi
   512   -512     .    .  -100%  xen_smp_send_call_function_ipi
   512   -512     .    .  -100%  ioapic_retrigger_irq
   512   -512     .    .  -100%  flat_send_IPI_all
   512      .  -512    .  -100%  cpu_to_allnodes_group
   512   -512     .    .  -100%  assign_irq_vector
39064 -27192 -1576 10296  -73%  Totals

====== MemInfo ()
... files 0 vars 0 all 0 lim 0 unch 0

-- 

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2008-09-12 14:17 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-09-09 15:50 [PATCH 0/3] x86: remove extraneous stack cpumask variables Mike Travis
2008-09-09 15:50 ` [PATCH 1/3] cpumask: add for_each_online_cpu_mask_nr function Mike Travis
2008-09-12  4:33   ` Rusty Russell
2008-09-12 14:17     ` Mike Travis
2008-09-09 15:50 ` [PATCH 2/3] x86: modify send_IPI_mask interface to accept cpumask_t pointers Mike Travis
2008-09-09 15:50 ` [PATCH 3/3] sched: Optimize cpumask temp stack usage in kernel/sched.c Mike Travis

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox