On Thu, 14 Mar 2019 07:38:55 +0100
Cédric Le Goater <c...@kaod.org> wrote:

> From: Benjamin Herrenschmidt <b...@kernel.crashing.org>
> 
> H_IPOLL takes the CPU# of the processor to poll as an argument,
> it doesn't operate on self.
> 

True.

> Signed-off-by: Benjamin Herrenschmidt <b...@kernel.crashing.org>
> Signed-off-by: Cédric Le Goater <c...@kaod.org>
> ---

Reviewed-by: Greg Kurz <gr...@kaod.org>

>  hw/intc/xics_spapr.c | 9 ++++++++-
>  1 file changed, 8 insertions(+), 1 deletion(-)
> 
> diff --git a/hw/intc/xics_spapr.c b/hw/intc/xics_spapr.c
> index 607e1c167ba2..9d2b8adef7c5 100644
> --- a/hw/intc/xics_spapr.c
> +++ b/hw/intc/xics_spapr.c
> @@ -95,8 +95,15 @@ static target_ulong h_eoi(PowerPCCPU *cpu, 
> SpaprMachineState *spapr,
>  static target_ulong h_ipoll(PowerPCCPU *cpu, SpaprMachineState *spapr,
>                              target_ulong opcode, target_ulong *args)
>  {
> +    ICPState *icp = xics_icp_get(XICS_FABRIC(spapr), args[0]);
>      uint32_t mfrr;
> -    uint32_t xirr = icp_ipoll(spapr_cpu_state(cpu)->icp, &mfrr);
> +    uint32_t xirr;
> +
> +    if (!icp) {
> +        return H_PARAMETER;
> +    }
> +
> +    xirr = icp_ipoll(icp, &mfrr);
>  
>      args[0] = xirr;
>      args[1] = mfrr;


Reply via email to