Ack, Tested the patch set on Freescale board and working good.
Thanks

Jason Jin 

> -----Original Message-----
> From: Michael Ellerman [mailto:[EMAIL PROTECTED] 
> Sent: Tuesday, July 15, 2008 10:46 PM
> To: Benjamin Herrenschmidt
> Cc: linuxppc-dev@ozlabs.org; Olof Johannsson; Gala Kumar; Jin 
> Zhengxiong
> Subject: [PATCH 1/4] powerpc: fsl_msi doesn't need it's own of_node
> 
> The FSL MSI code keeps a pointer to the of_node from the 
> device it represents. However it also has an irq_host, which 
> contains a pointer to the of_node, so use that one instead.
> 
> Signed-off-by: Michael Ellerman <[EMAIL PROTECTED]>
> ---
>  arch/powerpc/sysdev/fsl_msi.c |   12 +++++-------
>  arch/powerpc/sysdev/fsl_msi.h |    3 ---
>  2 files changed, 5 insertions(+), 10 deletions(-)
> 
> diff --git a/arch/powerpc/sysdev/fsl_msi.c 
> b/arch/powerpc/sysdev/fsl_msi.c index 2c5187c..d49fa99 100644
> --- a/arch/powerpc/sysdev/fsl_msi.c
> +++ b/arch/powerpc/sysdev/fsl_msi.c
> @@ -108,7 +108,8 @@ static int fsl_msi_free_dt_hwirqs(struct 
> fsl_msi *msi)
>       bitmap_allocate_region(msi->fsl_msi_bitmap, 0,
>                      get_count_order(NR_MSI_IRQS));
>  
> -     p = of_get_property(msi->of_node, "msi-available-ranges", &len);
> +     p = of_get_property(msi->irqhost->of_node, 
> "msi-available-ranges",
> +                         &len);
>  
>       if (!p) {
>               /* No msi-available-ranges property,
> @@ -120,7 +121,7 @@ static int fsl_msi_free_dt_hwirqs(struct 
> fsl_msi *msi)
>  
>       if ((len % (2 * sizeof(u32))) != 0) {
>               printk(KERN_WARNING "fsl_msi: Malformed 
> msi-available-ranges "
> -                    "property on %s\n", msi->of_node->full_name);
> +                    "property on %s\n", 
> msi->irqhost->of_node->full_name);
>               return -EINVAL;
>       }
>  
> @@ -317,14 +318,11 @@ static int __devinit 
> fsl_of_msi_probe(struct of_device *dev,
>               goto error_out;
>       }
>  
> -     msi->of_node = of_node_get(dev->node);
> +     msi->irqhost = irq_alloc_host(dev->node, IRQ_HOST_MAP_LINEAR,
> +                                   NR_MSI_IRQS, 
> &fsl_msi_host_ops, 0);
>  
> -     msi->irqhost = irq_alloc_host(of_node_get(dev->node),
> -                             IRQ_HOST_MAP_LINEAR,
> -                             NR_MSI_IRQS, &fsl_msi_host_ops, 0);
>       if (msi->irqhost == NULL) {
>               dev_err(&dev->dev, "No memory for MSI irqhost\n");
> -             of_node_put(dev->node);
>               err = -ENOMEM;
>               goto error_out;
>       }
> diff --git a/arch/powerpc/sysdev/fsl_msi.h 
> b/arch/powerpc/sysdev/fsl_msi.h index a653468..6574550 100644
> --- a/arch/powerpc/sysdev/fsl_msi.h
> +++ b/arch/powerpc/sysdev/fsl_msi.h
> @@ -22,9 +22,6 @@
>  #define FSL_PIC_IP_IPIC      0x00000002
>  
>  struct fsl_msi {
> -     /* Device node of the MSI interrupt*/
> -     struct device_node *of_node;
> -
>       struct irq_host *irqhost;
>  
>       unsigned long cascade_irq;
> --
> 1.5.5
> 
> 
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to