On Mon, 2007-09-17 at 16:05 +1000, Michael Ellerman wrote:
> Now that dcr_host_t contains the base address, we can use that in the mpic
> code, rather than storing it separately.
> 
> Signed-off-by: Michael Ellerman <[EMAIL PROTECTED]>

Acked-by: Benjamin Herrenschmidt <[EMAIL PROTECTED]>

> ---
>  arch/powerpc/sysdev/mpic.c |   28 +++++++++++-----------------
>  include/asm-powerpc/mpic.h |    6 ------
>  2 files changed, 11 insertions(+), 23 deletions(-)
> 
> diff --git a/arch/powerpc/sysdev/mpic.c b/arch/powerpc/sysdev/mpic.c
> index 8de29f2..16b1f4b 100644
> --- a/arch/powerpc/sysdev/mpic.c
> +++ b/arch/powerpc/sysdev/mpic.c
> @@ -156,8 +156,7 @@ static inline u32 _mpic_read(enum mpic_reg_type type,
>       switch(type) {
>  #ifdef CONFIG_PPC_DCR
>       case mpic_access_dcr:
> -             return dcr_read(rb->dhost,
> -                             rb->dbase + reg + rb->doff);
> +             return dcr_read(rb->dhost, rb->dhost.base + reg);
>  #endif
>       case mpic_access_mmio_be:
>               return in_be32(rb->base + (reg >> 2));
> @@ -174,8 +173,7 @@ static inline void _mpic_write(enum mpic_reg_type type,
>       switch(type) {
>  #ifdef CONFIG_PPC_DCR
>       case mpic_access_dcr:
> -             return dcr_write(rb->dhost,
> -                              rb->dbase + reg + rb->doff, value);
> +             return dcr_write(rb->dhost, rb->dhost.base + reg, value);
>  #endif
>       case mpic_access_mmio_be:
>               return out_be32(rb->base + (reg >> 2), value);
> @@ -279,9 +277,11 @@ static void _mpic_map_mmio(struct mpic *mpic, unsigned 
> long phys_addr,
>  static void _mpic_map_dcr(struct mpic *mpic, struct mpic_reg_bank *rb,
>                         unsigned int offset, unsigned int size)
>  {
> -     rb->dbase = mpic->dcr_base;
> -     rb->doff = offset;
> -     rb->dhost = dcr_map(mpic->irqhost->of_node, rb->dbase + rb->doff, size);
> +     const u32 *dbasep;
> +
> +     dbasep = of_get_property(mpic->irqhost->of_node, "dcr-reg", NULL);
> +
> +     rb->dhost = dcr_map(mpic->irqhost->of_node, *dbasep + offset, size);
>       BUG_ON(!DCR_MAP_OK(rb->dhost));
>  }
>  
> @@ -1075,20 +1075,14 @@ struct mpic * __init mpic_alloc(struct device_node 
> *node,
>       BUG_ON(paddr == 0 && node == NULL);
>  
>       /* If no physical address passed in, check if it's dcr based */
> -     if (paddr == 0 && of_get_property(node, "dcr-reg", NULL) != NULL)
> -             mpic->flags |= MPIC_USES_DCR;
> -
> +     if (paddr == 0 && of_get_property(node, "dcr-reg", NULL) != NULL) {
>  #ifdef CONFIG_PPC_DCR
> -     if (mpic->flags & MPIC_USES_DCR) {
> -             const u32 *dbasep;
> -             dbasep = of_get_property(node, "dcr-reg", NULL);
> -             BUG_ON(dbasep == NULL);
> -             mpic->dcr_base = *dbasep;
> +             mpic->flags |= MPIC_USES_DCR;
>               mpic->reg_type = mpic_access_dcr;
> -     }
>  #else
> -     BUG_ON (mpic->flags & MPIC_USES_DCR);
> +             BUG();
>  #endif /* CONFIG_PPC_DCR */
> +     }
>  
>       /* If the MPIC is not DCR based, and no physical address was passed
>        * in, try to obtain one
> diff --git a/include/asm-powerpc/mpic.h b/include/asm-powerpc/mpic.h
> index edb4a7c..ae84dde 100644
> --- a/include/asm-powerpc/mpic.h
> +++ b/include/asm-powerpc/mpic.h
> @@ -224,8 +224,6 @@ struct mpic_reg_bank {
>       u32 __iomem     *base;
>  #ifdef CONFIG_PPC_DCR
>       dcr_host_t      dhost;
> -     unsigned int    dbase;
> -     unsigned int    doff;
>  #endif /* CONFIG_PPC_DCR */
>  };
>  
> @@ -289,10 +287,6 @@ struct mpic
>       struct mpic_reg_bank    cpuregs[MPIC_MAX_CPUS];
>       struct mpic_reg_bank    isus[MPIC_MAX_ISU];
>  
> -#ifdef CONFIG_PPC_DCR
> -     unsigned int            dcr_base;
> -#endif
> -
>       /* Protected sources */
>       unsigned long           *protected;
>  

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to