[PATCH] powerpc: Make early memory scan more resilient to out of order nodes

2011-05-11 Thread Benjamin Herrenschmidt
We keep track of the size of the lowest block of memory and call setup_initial_memory_limit() only after we've parsed them all Signed-off-by: Benjamin Herrenschmidt --- arch/powerpc/kernel/prom.c | 15 ++- 1 files changed, 10 insertions(+), 5 deletions(-) diff --git a/arch/powerpc

RE: [linuxppc-release] [PATCH 1/2] powerpc, e5500: add networking to defconfig

2011-05-11 Thread Li Yang-R58472
>Subject: [linuxppc-release] [PATCH 1/2] powerpc, e5500: add networking to >defconfig > >Even though support for the p5020's on-chip ethernet is not yet upstream, >it is not appropriate to disable all networking support (including >loopback, unix domain sockets, external ethernet devices, etc) in t

Re: [PATCH 7/8] powerpc: use the newly added get_required_mask dma_map_ops hook

2011-05-11 Thread Geert Uytterhoeven
On Thu, May 12, 2011 at 00:25, Nishanth Aravamudan wrote: > diff --git a/arch/powerpc/platforms/ps3/system-bus.c > b/arch/powerpc/platforms/ps3/system-bus.c > index 23083c3..688141c 100644 > --- a/arch/powerpc/platforms/ps3/system-bus.c > +++ b/arch/powerpc/platforms/ps3/system-bus.c > @@ -695,12

[PATCH 3/5] v2 seccomp_filters: Enable ftrace-based system call filtering

2011-05-11 Thread Will Drewry
This change adds a new seccomp mode based on the work by a...@chromium.org in [1]. This new mode, "filter mode", provides a hash table of seccomp_filter objects. When in the new mode (2), all system calls are checked against the filters - first by system call number, then by a filter string. If a

Re: [RFC] powerpc: respect how command line nr_cpus is set

2011-05-11 Thread Milton Miller
On Wed, 04 May 2011 around 10:17:37 -, Kumar Gala wrote: > We should utilize nr_cpus as the max # of CPUs that we can have present > instead of NR_CPUS. This way we actually respect how nr_cpus is set on > the command line rather than ignoring it. > > Signed-off-by: Kumar Gala > > --- > I t

[PATCH 7/8] powerpc: use the newly added get_required_mask dma_map_ops hook

2011-05-11 Thread Nishanth Aravamudan
From: Milton Miller Now that the generic code has dma_map_ops set, instead of having a messy ifdef & if block in the base dma_get_required_mask hook push the computation into the dma ops. If the ops fails to set the get_required_mask hook default to the width of dma_addr_t. This also corrects i

[PATCH 8/8] powerpc: tidy up dma_map_ops after adding new hook

2011-05-11 Thread Nishanth Aravamudan
From: Milton Miller The new get_required_mask hook name is longer than many of but not all of the prior ops. Tidy the struct initializers to align the equal signs using the local whitespace. Signed-off-by: Milton Miller Signed-off-by: Nishanth Aravamudan --- arch/powerpc/kernel/dma-iommu.c |

[PATCH 4/8] pseries/iommu: cleanup ddw naming

2011-05-11 Thread Nishanth Aravamudan
From: Milton Miller When using a property refering to the availibily of dynamic dma windows call it ddw_avail not ddr_avail. dupe_ddw_if_already_created does not dupilcate anything, it only finds and reuses the windows we already created, so rename it to find_existing_ddw. Also, it does not nee

[PATCH 2/8] pseries/iommu: remove ddw property when destroying window

2011-05-11 Thread Nishanth Aravamudan
From: Milton Miller If we destroy the window, we need to remove the property recording that we setup the window. Otherwise the next kernel we kexec will be confused. Also we should remove the property if even if we don't find the ibm,ddw-applicable window or if one of the property sizes is unex

[PATCH 1/8] pseries/iommu: add additional checks when changing iommu mask

2011-05-11 Thread Nishanth Aravamudan
From: Milton Miller Do not check dma supported until we have chosen the right dma ops. Check that the device is pci before treating it as such. Check the mask is supported by the selected dma ops before committing it. We only need to set iommu ops if it is not the current ops; this avoids searc

[PATCH 5/8] powerpc: override dma_get_required_mask by platform hook and ops

2011-05-11 Thread Nishanth Aravamudan
From: Milton Miller The hook dma_get_required_mask is supposed to return the mask required by the platform to operate efficently. The generic version of dma_get_required_mask in driver/base/platform.c returns a mask based only on max_pfn. However, this is likely too big for iommu systems and co

[PATCH 3/8] pseries/iommu: find windows after kexec during boot

2011-05-11 Thread Nishanth Aravamudan
From: Milton Miller Move the discovery of windows previously setup from when the pci driver calls set_dma_mask to an arch_initcall. When kexecing into a kernel with dynamic dma windows allocated, we need to find the windows early so that memory hot remove will be able to delete the tces mapping

[PATCH 0/8] pseries/iommu: bug-fixes and cleanups for dynamic dma windows

2011-05-11 Thread Nishanth Aravamudan
This series of patches attempts to cleanup and fix some bugs related to dynamic dma windows and kexec/kdump. They build on the three patches I have submitted most recently: powerpc: fix kexec with dynamic dma windows http://patchwork.ozlabs.org/patch/94445/ pseries/iommu: restore iommu tab

fsl_udc_core: BUG: scheduling while atomic

2011-05-11 Thread Matthew L. Creech
Hi, My MPC8313-based board, running a 2.6.37 kernel, is occasionally hitting this bug while doing RNDIS-based communication: BUG: scheduling while atomic: lighttpd/1145/0x1200 Call Trace: [c6a8b910] [c00086c0] show_stack+0x7c/0x194 (unreliable) [c6a8b950] [c0019e28] __schedule_bug+0x54/0x68 [

Re: [PATCH 13/13] kvm/powerpc: Allow book3s_hv guests to use SMT processor modes

2011-05-11 Thread Paul Mackerras
On Wed, May 11, 2011 at 03:44:15PM +0200, Christoph Hellwig wrote: > On Wed, May 11, 2011 at 08:46:56PM +1000, Paul Mackerras wrote: > > arch/powerpc/sysdev/xics/icp-native.c. > > What kernel tree do I need to actually have that file? The "next" branch of git://git.kernel.org/pub/scm/linux/kernel

[PATCH] pseries/iommu: use correct return type in dupe_ddw_if_already_created

2011-05-11 Thread Nishanth Aravamudan
Otherwise we get silent truncations. Signed-off-by: Nishanth Aravamudan Cc: Anton Blanchard Cc: Milton Miller Cc: linuxppc-...@ozlabs.org --- arch/powerpc/platforms/pseries/iommu.c |2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/arch/powerpc/platforms/pseries/iommu.

Re: [PATCH] RapidIO: Fix default routing initialization

2011-05-11 Thread Andrew Morton
On Wed, 11 May 2011 10:46:03 -0400 Alexandre Bounine wrote: > Fix switch initialization to ensure that all switches have default > routing disabled. This guarantees that no unexpected RapidIO packets > arrive to the default port set by reset and there is no default routing > destination until it

Re: [PATCH 00/37] fix paca memory usage and NR_CPU loops, factor ipi and simplify irq code

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:43 AM, Milton Miller wrote: [...] > After doing a bunch of grep's on arch/sh, I think the interesting > parts of super8 interrupt handling that Thomas referred to are in > drivers/sh/intc.  For some reason they populate the radix tree first > with a descriptor of their co

Re: [PATCH 37/37] powerpc: make IRQ_NOREQUEST last to clear, first to set

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:30 AM, Milton Miller wrote: > When allocating irqs, wait to clear the IRQ_NOREQUEST flag until the > host map hook has been called. > > When freeing irqs, set the IRQ_NOREQUEST flag before calling the host > unmap hook. A description describing why this change is being m

Re: [PATCH 36/37] powerpc: remove virq_to_host

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:30 AM, Milton Miller wrote: > The only references to the irq_map[].host field are internal to > arch/powerpc/kernel/irq.c > > Signed-off-by: Milton Miller Acked-by: Grant Likely > --- > --- >  arch/powerpc/include/asm/irq.h |    1 - >  arch/powerpc/kernel/irq.c      |

Re: [PATCH 35/37] powerpc: add virq_is_host to reduce virq_to_host usage

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:30 AM, Milton Miller wrote: > Some irq_host implementations are using virq_to_host to check if > they are the irq_host for a virtual irq.  To allow us to make space > versus time tradeoffs, replace this usage with an assertive > virq_is_host that confirms or denies the ir

Re: [PATCH 33/37] powerpc: spider-pic: get pic from chip_data instead of irq_map

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:30 AM, Milton Miller wrote: > Building on Grant's efforts to remove the irq_map array, this patch > moves spider-pics use of virq_to_host() to use irq_data_get_chip_data > and sets the irq chip data in the map call, like most other interrupt > controllers in powerpc. Loo

Re: [PATCH 30/37] powerpc: mpc62xx_pic: fix get_irq handling of NO_IRQ

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:30 AM, Milton Miller wrote: > If none of irq category bits were set mpc52xx_get_irq() would pass > NO_IRQ_IGNORE (-1) to irq_linear_revmap, which does an unsigned compare > and declares the interrupt above the linear map range.  It then punts > to irq_find_mapping, which

Re: [PATCH 29/37] powerpc: mpc5121_ads_cpld: remove use of NO_IRQ_IGNORE

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:30 AM, Milton Miller wrote: > As NO_IRQ_IGNORE is only used between the static function cpld_pic_get_irq > and its caller cpld_pic_cascade, and cpld_pic_cascade only uses it to > suppress calling handle_generic_irq, we can change these uses to NO_IRQ > and remove the extr

Re: [PATCH 27/37] powerpc fsl_msi: don't abuse platform_data for driver_data

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:30 AM, Milton Miller wrote: > The msi platform device driver was abusing dev.platform_data for its > platform_driver_data.  Use the correct pointer for storage. > > Platform_data is supposed to be for platforms to communicate to drivers > parameters that are not otherwise

Re: [PATCH 24/37] powerpc: return early if irq_host lookup type is wrong

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:29 AM, Milton Miller wrote: > If for some reason the code incrorectly calls the wrong function to > manage the revmap, not only should we warn, we should take action. > However, in the paths we expect to be taken every delivered interrupt > change to WARN_ON_ONCE.  Use th

Re: [PATCH 23/37] powerpc: radix trees are available before init_IRQ

2011-05-11 Thread Grant Likely
On Wed, May 11, 2011 at 7:29 AM, Milton Miller wrote: > Since the generic irq code uses a radix tree for sparse interrupts, > the initcall ordering has been changed to initialize radix trees before > irqs.   We no longer need to defer creating revmap radix trees to the > arch_initcall irq_late_ini

Re: [BUG] rebuild_sched_domains considered dangerous

2011-05-11 Thread Jesse Larrew
On 05/10/2011 09:09 AM, Peter Zijlstra wrote: > On Mon, 2011-05-09 at 16:26 -0500, Jesse Larrew wrote: >> >> According the the Power firmware folks, updating the home node of a >> virtual cpu happens rather infrequently. The VPHN code currently >> checks for topology updates every 60 seconds, but w

[PATCH] RapidIO: Fix default routing initialization

2011-05-11 Thread Alexandre Bounine
Fix switch initialization to ensure that all switches have default routing disabled. This guarantees that no unexpected RapidIO packets arrive to the default port set by reset and there is no default routing destination until it is properly configured by software. This update also unifies handling

Re: [PATCH 13/13] kvm/powerpc: Allow book3s_hv guests to use SMT processor modes

2011-05-11 Thread Christoph Hellwig
On Wed, May 11, 2011 at 08:46:56PM +1000, Paul Mackerras wrote: > arch/powerpc/sysdev/xics/icp-native.c. What kernel tree do I need to actually have that file? ___ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo

Re: Regarding P2020 in AMP mode

2011-05-11 Thread Prasanna Khanapur
I tried the suggestion of setting eTSEC2 as active port for the u-boot . Ethernet of Core1 (connected to 1G) is working now. Thanks for the inputs , they really helped ! Best Regards Prasanna Khanapur On Tue, May 10, 2011 at 9:50 AM, Aggrwal Poonam-B10812 wrote: > The code looks to be correc

[PATCH 09/13] powerpc: Set up LPCR for running guest partitions

2011-05-11 Thread Paul Mackerras
In hypervisor mode, the LPCR controls several aspects of guest partitions, including virtual partition memory mode, and also controls whether the hypervisor decrementer interrupts are enabled. This sets up LPCR at boot time so that guest partitions will use a virtual real memory area (VRMA) compos

[PATCH 02/13] kvm/powerpc: Fix kvmppc_core_pending_dec

2011-05-11 Thread Paul Mackerras
The vcpu->arch.pending_exceptions field is a bitfield indexed by interrupt priority number as returned by kvmppc_book3s_vec2irqprio. However, kvmppc_core_pending_dec was using an interrupt vector shifted by 7 as the bit index. Fix it to use the irqprio value for the decrementer interrupt instead.

[PATCH 06/13] kvm/powerpc: Deliver program interrupts right away instead of queueing them

2011-05-11 Thread Paul Mackerras
Doing so means that we don't have to save the flags anywhere and gets rid of the last reference to to_book3s(vcpu) in arch/powerpc/kvm/book3s.c. Doing so is OK because a program interrupt won't be generated at the same time as any other synchronous interrupt. If a program interrupt and an asynchr

[PATCH 01/13] kvm/powerpc: Move fields between struct kvm_vcpu_arch and kvmppc_vcpu_book3s

2011-05-11 Thread Paul Mackerras
This moves the slb field, which represents the state of the emulated SLB, from the kvmppc_vcpu_book3s struct to the kvm_vcpu_arch, and the hpte_hash_[v]pte[_long] fields from kvm_vcpu_arch to kvmppc_vcpu_book3s. This is in accord with the principle that the kvm_vcpu_arch struct represents the state

[PATCH 03/13] kvm/powerpc: Fix the build for 32-bit Book 3S (classic) processors

2011-05-11 Thread Paul Mackerras
Commits a5d4f3ad3a ("powerpc: Base support for exceptions using HSRR0/1") and 673b189a2e ("powerpc: Always use SPRN_SPRG_HSCRATCH0 when running in HV mode") cause compile and link errors for 32-bit classic Book 3S processors when KVM is enabled. This fixes these errors. Signed-off-by: Paul Macker

[PATCH 07/13] kvm/powerpc: Pass init/destroy vm and prepare/commit memory region ops down

2011-05-11 Thread Paul Mackerras
>From d8fc78f42250481db50898ab3df95c21283cb9b0 Mon Sep 17 00:00:00 2001 From: Paul Mackerras Date: Tue, 10 May 2011 15:37:13 +1000 Subject: [PATCH 07/13] kvm/powerpc: Pass init/destroy vm and prepare/commit memory region ops down This arranges for the top-level arch/powerpc/kvm/powerpc.c file to

[PATCH 12/13] kvm/powerpc: Accelerate H_PUT_TCE by implementing it in real mode

2011-05-11 Thread Paul Mackerras
From: David Gibson This improves I/O performance for guests using the PAPR paravirtualization interface by making the H_PUT_TCE hcall faster, by implementing it in real mode. H_PUT_TCE is used for updating virtual IOMMU tables, and is used both for virtual I/O and for real I/O in the PAPR interf

[PATCH 08/13] kvm/powerpc: Move guest enter/exit down into subarch-specific code

2011-05-11 Thread Paul Mackerras
>From 964ee93b2d728e4fb16ae66eaceb6e912bf114ad Mon Sep 17 00:00:00 2001 From: Paul Mackerras Date: Tue, 10 May 2011 22:23:18 +1000 Subject: [PATCH 08/13] kvm/powerpc: Move guest enter/exit down into subarch-specific code Instead of doing the kvm_guest_enter/exit() and local_irq_dis/enable() call

[PATCH 13/13] kvm/powerpc: Allow book3s_hv guests to use SMT processor modes

2011-05-11 Thread Paul Mackerras
This lifts the restriction that book3s_hv guests can only run one hardware thread per core, and allows them to use up to 4 threads per core on POWER7. The host still has to run single-threaded. This capability is advertised to qemu through a new KVM_CAP_PPC_SMT capability. To use this, the host

[PATCH 0/13] Hypervisor-mode KVM on POWER7

2011-05-11 Thread Paul Mackerras
The following series of patches enable KVM to exploit the hardware hypervisor mode on 64-bit Power ISA Book3S machines. At present only POWER7 is supported, but it would be easy to add other processors. Running the KVM host in hypervisor mode means that the guest can use both supervisor mode and

[PATCH 05/13] powerpc, kvm: Rework KVM checks in first-level interrupt handlers

2011-05-11 Thread Paul Mackerras
Instead of branching out-of-line with the DO_KVM macro to check if we are in a KVM guest at the time of an interrupt, this moves the KVM check inline in the first-level interrupt handlers. This speeds up the non-KVM case and makes sure that none of the interrupt handlers are missing the check. Be

[PATCH 11/13] kvm/powerpc: Handle some PAPR hcalls in the kernel

2011-05-11 Thread Paul Mackerras
This adds the infrastructure for handling PAPR hcalls in the kernel, either early in the guest exit path while we are still in real mode, or later once the MMU has been turned back on and we are in the full kernel context. The advantage of handling hcalls in real mode if possible is that we avoid

[PATCH 02/37] powerpc: don't search for paca in freed memory

2011-05-11 Thread Milton Miller
Starting with 1426d5a3bd07589534286375998c0c8c6fdc5260 (powerpc: Dynamically allocate pacas) we free the memory for pacas beyond cpu_possible, but we failed to update the loop the secondary cpus use to find their paca. If the system has running cpu threads for which the kernel did not allocate a p

[PATCH 17/37] powerpc cell: use smp_request_message_ipi

2011-05-11 Thread Milton Miller
This is a request to merge patchwork id 3780 with the same subject. I believe it was marked "changes requested" because it depended on a patch that had requested changes, but those were resolved and this one got overlooked. The next patch will remove smp_msg_recv. thanks, milton Here is the orig

[PATCH 00/37] fix paca memory usage and NR_CPU loops, factor ipi and simplify irq code

2011-05-11 Thread Milton Miller
This series represents a somewhat ordered, somewhat meandering series development series of patches I've been working on for the past few weeks. It starts with memory corruption fixes that need to go back to stable relating to slave cpu searches and paca allocation. After refactoring and taking i

[PATCH 07/37] powerpc: call no-longer static setup_nr_cpu_ids instead of replicating it

2011-05-11 Thread Milton Miller
c1854e00727f50f7ac99e98d26ece04c087ef785 (powerpc: Set nr_cpu_ids early and use it to free PACAs) copied the formerly static setup_nr_cpu_ids from init/main.c but 34db18a054c600b6f81787165669dc572fe4de25 (smp: move smp setup functions to kernel/smp.c) moved it to kernel/smp.c with a declaration in

[PATCH 08/37] powerpc: mpic: limit NR_CPUS loop to 32 bit

2011-05-11 Thread Milton Miller
mpic_physmask was looping NR_CPUS times over a mask that was passed as a u32. Since mpic is architecturaly limited to 32 physical cpus, clamp the logical cpus to 32 when compiling (we could also clamp at runtime to nr_cpu_ids). Signed-off-by: Milton Miller --- arch/powerpc/sysdev/mpic.c |2 +

[PATCH 09/37] powerpc: mpic: break cpumask abstraction earlier

2011-05-11 Thread Milton Miller
mpic_set_affinity is allocating and freeing a cpumask var even though it was breaking the cpumask abstraction when passing the mask to mpic_physmask. It also didn't have any check for allocatin failure. Break the cpumask abstraction earlier and use simple bitwise and of the bits from the mask wit

[PATCH 10/37] powerpc: remove call sites of MSG_ALL_BUT_SELF

2011-05-11 Thread Milton Miller
The only user of MSG_ALL_BUT_SELF in the whole kernel tree is powerpc, and it only uses it to start the debugger. Both debuggers always call smp_send_debugger_break with MSG_ALL_BUT_SELF, and only mpic can do anything more optimal than a loop over all online cpus, but all message passing implementa

[PATCH 11/37] powerpc: remove checks for MSG_ALL and MSG_ALL_BUT_SELF

2011-05-11 Thread Milton Miller
Now that smp_ops->smp_message_pass is always called with an (online) cpu number for the target remove the checks for MSG_ALL and MSG_ALL_BUT_SELF. Signed-off-by: Milton Miller --- rediffed for ppc-next xics split --- arch/powerpc/include/asm/dbell.h |2 +- arch/powerpc/include/asm/mach

[PATCH 12/37] linux/smp.h: remove unused MSG_ flags

2011-05-11 Thread Milton Miller
Now that powerpc has removed its use of MSG_ALL_BUT_SELF and MSG_ALL all these MSG_ flags are unused. Signed-off-by: Milton Miller --- To be merged by powerpc with the series posted to linuxppc-dev After the previous 2 patches, grep shows the following false hits (from partial symbol matches):

[PATCH 13/37] powerpc/mpic: simplify ipi cpu mask handling

2011-05-11 Thread Milton Miller
Now that MSG_ALL and MSG_ALL_BUT_SELF have been eliminated, smp_mpic_mesage_pass no longer needs to lookup the cpumask just to have mpic_send_ipi extract part of it and recode it in a NR_CPUS loop by mpic_physmask. Signed-off-by: Milton Miller --- I chose stepwise refinement but this could be mer

[PATCH 14/37] powerpc: remove powermac/pic.h

2011-05-11 Thread Milton Miller
Its unused, and of the three declarations, one is duplicated in pmac.h, the second is static and the third is renamed and static. Signed-off-by: Milton Miller --- --- arch/powerpc/platforms/powermac/pic.h | 11 --- 1 files changed, 0 insertions(+), 11 deletions(-) delete mode 100644 a

[PATCH 15/37] powerpc: remove alloc_maybe_bootmem for zalloc version

2011-05-11 Thread Milton Miller
Replace all remaining callers of alloc_maybe_bootmem with zalloc_maybe_bootmem. The callsite in pci_dn is followed with a memset to clear the memory, and not zeroing at the other callsites in the celleb fake pci code could lead to following uninitialized memory as pointers or even freeing said po

[PATCH 16/37] powerpc: remove stubbed beat smp support

2011-05-11 Thread Milton Miller
I have no idea if the beat hypervisor supports multiple cpus in a partition, but the code has not been touched since these stubs were added in February of 2007 except to move them in April of 2008. These are stubs: start_cpu always returns fail (which is dropped), the message passing and reciving a

[PATCH 19/37] powerpc: consolidate ipi message mux and demux

2011-05-11 Thread Milton Miller
Consolidate the mux and demux of ipi messages into smp.c and call a new smp_ops callback to actually trigger the ipi. The powerpc architecture code is optimised for having 4 distinct ipi triggers, which are mapped to 4 distinct messages (ipi many, ipi single, scheduler ipi, and enter debugger). H

[PATCH 18/37] powerpc: move smp_ops_t from machdep.h to smp.h

2011-05-11 Thread Milton Miller
I can't see any reason these functions are needed by machdep.h and they are all hidden by CONFIG_SMP with no UP alternative. Also move the declarations for the fallback timebase ops, which are used to fill in the smp ops. Signed-off-by: Milton Miller --- arch/powerpc/include/asm/machdep.h | 2

[PATCH 20/37] powerpc: add kconfig for muxed smp ipi support

2011-05-11 Thread Milton Miller
Compile the new smp ipi mux and demux code only if a platform will make use of it. The new config is selected as required. The new cause_ipi smp op is only available conditionally to point out configs where the select is required; this makes setting the op an immediate fail instead of a deferred

[PATCH 36/37] powerpc: remove virq_to_host

2011-05-11 Thread Milton Miller
The only references to the irq_map[].host field are internal to arch/powerpc/kernel/irq.c Signed-off-by: Milton Miller --- --- arch/powerpc/include/asm/irq.h |1 - arch/powerpc/kernel/irq.c |6 -- 2 files changed, 0 insertions(+), 7 deletions(-) diff --git a/arch/powerpc/includ

[PATCH 22/37] powerpc: xics: cleanup xics_host_map and ipi

2011-05-11 Thread Milton Miller
Since we already have a special case in map to set the ipi handler, use the desired flow. If we don't find an ics to handle the interrupt complain instead of returning 0 without having set a chip or handler. Signed-off-by: Milton Miller --- arch/powerpc/sysdev/xics/xics-common.c | 10 +---

[PATCH 23/37] powerpc: radix trees are available before init_IRQ

2011-05-11 Thread Milton Miller
Since the generic irq code uses a radix tree for sparse interrupts, the initcall ordering has been changed to initialize radix trees before irqs. We no longer need to defer creating revmap radix trees to the arch_initcall irq_late_init. Also, the kmem caches are allocated so we don't need to use

[PATCH 21/37] powerpc: use bytes instead of bitops in smp ipi multiplexing

2011-05-11 Thread Milton Miller
Since there are only 4 messages, we can replace the atomic bit set (which uses atomic load reserve and store conditional sequence) with a byte stores to seperate bytes. We still have to perform a load reserve and store conditional sequence to avoid loosing messages on reception but we can do that

[PATCH 24/37] powerpc: return early if irq_host lookup type is wrong

2011-05-11 Thread Milton Miller
If for some reason the code incrorectly calls the wrong function to manage the revmap, not only should we warn, we should take action. However, in the paths we expect to be taken every delivered interrupt change to WARN_ON_ONCE. Use the if (WARN_ON(x)) format to get the unlikely for free. Signed-

[PATCH 25/37] powerpc: remove trival irq_host_ops.unmap

2011-05-11 Thread Milton Miller
These all just clear chip or chipdata fields, which will be done by the generic code when we call irq_free_descs. Signed-off-by: Milton Miller --- arch/powerpc/platforms/82xx/pq2ads-pci-pic.c |8 arch/powerpc/platforms/embedded6xx/flipper-pic.c |7 --- arch/powerpc/platf

[PATCH 26/37] powerpc: remove i8259 irq_host_ops->unmap

2011-05-11 Thread Milton Miller
It was never called because the host is always IRQ_HOST_MAP_LEGACY. And what it purported to do was mask the interrupt (which will already have happend if we shutdown the interrupt), then synchronise_irq and clear the chip pointer, both of which will have been be done by the caller were we to call

[PATCH 32/37] powerpc: remove irq_host_ops->remap hook

2011-05-11 Thread Milton Miller
It was called from irq_create_mapping if that was called for a host and hwirq that was previously mapped, "to update the flags". But the only implementation was in beat_interrupt and all it did was repeat a hypervisor call without error checking that was performed with error checking at the beginn

[PATCH 31/37] powerpc: psurge: create a irq_host for secondary cpus

2011-05-11 Thread Milton Miller
Create a dummy irq_host using the generic dummy irq chip for the secondary cpus to use. Create a direct irq mapping for the ipi and register the ipi action handler against it. If for some unlikely reason part of this fails then don't detect the secondary cpus. This removes another instance of NO

[PATCH 27/37] powerpc fsl_msi: don't abuse platform_data for driver_data

2011-05-11 Thread Milton Miller
The msi platform device driver was abusing dev.platform_data for its platform_driver_data. Use the correct pointer for storage. Platform_data is supposed to be for platforms to communicate to drivers parameters that are not otherwise discoverable. Its lifetime matches the platform_device not the

[PATCH 28/37] powerpc: fsl_msi: use chip_data not handler_data

2011-05-11 Thread Milton Miller
handler_data should be reserved for flow handlers on the dependent irq, not consumed by the parent irq code that is part of the irq_chip code. The msi_data pointer was already set in msidesc->irqhost->hostdata and being copied to irq_data->chipdata in the msidesc->irqhost->map() method called via

[PATCH 04/37] powerpc/iseries: cleanup and fix secondary startup

2011-05-11 Thread Milton Miller
9cb82f2f4692293a27c578c3038518ce4477de72 (Make iSeries spin on __secondary_hold_spinloop, like pSeries) added a load of current_set but this load was repeated later and we don't even have the paca yet. It also checked __secondary_hold_spinloop with a 32 bit compare instead of a 64 bit compare. b6f

[PATCH 29/37] powerpc: mpc5121_ads_cpld: remove use of NO_IRQ_IGNORE

2011-05-11 Thread Milton Miller
As NO_IRQ_IGNORE is only used between the static function cpld_pic_get_irq and its caller cpld_pic_cascade, and cpld_pic_cascade only uses it to suppress calling handle_generic_irq, we can change these uses to NO_IRQ and remove the extra tests and pathlength in cpld_pic_cascade. Signed-off-by: Mil

[PATCH 30/37] powerpc: mpc62xx_pic: fix get_irq handling of NO_IRQ

2011-05-11 Thread Milton Miller
If none of irq category bits were set mpc52xx_get_irq() would pass NO_IRQ_IGNORE (-1) to irq_linear_revmap, which does an unsigned compare and declares the interrupt above the linear map range. It then punts to irq_find_mapping, which performs a linear search of all irqs, which will likely miss an

[PATCH 05/37] powerpc: Respect nr_cpu_ids when calling set_cpu_possible and set_cpu_present

2011-05-11 Thread Milton Miller
We should not set cpus above nr_cpu_ids to possible. While we will trigger a warning with CONFIG_CPUMASK_DEBUG, even then the mask initializers will set the bits beyond what the iterators check and cause nr_cpu_ids to increase. Respecting nr_cpu_ids during setup will allow us to use it in our ini

[PATCH 06/37] powerpc: use nr_cpu_ids in initial paca allocation

2011-05-11 Thread Milton Miller
Now that we never set a cpu above nr_cpu_ids possible we can limit our initial paca allocation to nr_cpu_ids. We can then clamp the number of cpus in platforms/iseries/setup.c. Signed-off-by: Milton Miller --- --- arch/powerpc/kernel/paca.c | 17 ++--- arch/powerpc/pla

[PATCH 35/37] powerpc: add virq_is_host to reduce virq_to_host usage

2011-05-11 Thread Milton Miller
Some irq_host implementations are using virq_to_host to check if they are the irq_host for a virtual irq. To allow us to make space versus time tradeoffs, replace this usage with an assertive virq_is_host that confirms or denies the irq is associated with the given irq_host. Signed-off-by: Milton

[PATCH 37/37] powerpc: make IRQ_NOREQUEST last to clear, first to set

2011-05-11 Thread Milton Miller
When allocating irqs, wait to clear the IRQ_NOREQUEST flag until the host map hook has been called. When freeing irqs, set the IRQ_NOREQUEST flag before calling the host unmap hook. Signed-off-by: Milton Miller --- arch/powerpc/kernel/irq.c | 14 +++--- 1 files changed, 7 insertions(+

[PATCH 34/37] powerpc: axon_msi: validate msi irq via chip_data

2011-05-11 Thread Milton Miller
Instead of checking for rogue msi numbers via the irq_map host field set the chip_data to h.host_data (which is the msic struct pointer) at map and compare it in get_irq. Signed-off-by: Milton Miller --- --- arch/powerpc/platforms/cell/axon_msi.c |3 ++- 1 files changed, 2 insertions(+), 1 d

[PATCH 33/37] powerpc: spider-pic: get pic from chip_data instead of irq_map

2011-05-11 Thread Milton Miller
Building on Grant's efforts to remove the irq_map array, this patch moves spider-pics use of virq_to_host() to use irq_data_get_chip_data and sets the irq chip data in the map call, like most other interrupt controllers in powerpc. Signed-off-by: Milton Miller --- --- arch/powerpc/platforms/cell

[PATCH 03/37] powerpc/kdump64: Don't reference freed memory as pacas

2011-05-11 Thread Milton Miller
Starting with 1426d5a3bd07589534286375998c0c8c6fdc5260 (powerpc: Dynamically allocate pacas) the space for pacas beyond cpu_possible is freed, but we failed to update the loop in crash.c. Since c1854e00727f50f7ac99e98d26ece04c087ef785 (powerpc: Set nr_cpu_ids early and use it to free PACAs) the nu

[PATCH 01/37] powerpc: fix memory corruption from unallocated slaves

2011-05-11 Thread Milton Miller
Commit 1fc711f7ffb01089efc58042cfdbac8573d1b59a (powerpc/kexec: Fix race in kexec shutdown) moved the write to signal the cpu had exited the kernel from before the transition to real mode in kexec_smp_wait to kexec_wait. Unfornately it missed that kexec_wait is used both by cpus leaving the kernel