On Wed, 2008-01-30 at 01:13 +1100, Michael Ellerman wrote: > Split out the logic that allocates a struct iommu into a separate > function. This can fail however the calling code has never cared - so > just return if we can't allocate an iommu. > > Signed-off-by: Michael Ellerman <[EMAIL PROTECTED]>
Acked-by: Benjamin Herrenschmidt <[EMAIL PROTECTED]> > --- > arch/powerpc/platforms/cell/iommu.c | 20 ++++++++++++++++---- > 1 files changed, 16 insertions(+), 4 deletions(-) > > diff --git a/arch/powerpc/platforms/cell/iommu.c > b/arch/powerpc/platforms/cell/iommu.c > index 9223559..4f1ca43 100644 > --- a/arch/powerpc/platforms/cell/iommu.c > +++ b/arch/powerpc/platforms/cell/iommu.c > @@ -565,10 +565,9 @@ static int __init cell_iommu_get_window(struct > device_node *np, > return 0; > } > > -static void __init cell_iommu_init_one(struct device_node *np, unsigned long > offset) > +static struct cbe_iommu * __init cell_iommu_alloc(struct device_node *np) > { > struct cbe_iommu *iommu; > - unsigned long base, size; > int nid, i; > > /* Get node ID */ > @@ -576,7 +575,7 @@ static void __init cell_iommu_init_one(struct device_node > *np, unsigned long off > if (nid < 0) { > printk(KERN_ERR "iommu: failed to get node for %s\n", > np->full_name); > - return; > + return NULL; > } > pr_debug("iommu: setting up iommu for node %d (%s)\n", > nid, np->full_name); > @@ -592,7 +591,7 @@ static void __init cell_iommu_init_one(struct device_node > *np, unsigned long off > if (cbe_nr_iommus >= NR_IOMMUS) { > printk(KERN_ERR "iommu: too many IOMMUs detected ! (%s)\n", > np->full_name); > - return; > + return NULL; > } > > /* Init base fields */ > @@ -603,6 +602,19 @@ static void __init cell_iommu_init_one(struct > device_node *np, unsigned long off > snprintf(iommu->name, sizeof(iommu->name), "iommu%d", i); > INIT_LIST_HEAD(&iommu->windows); > > + return iommu; > +} > + > +static void __init cell_iommu_init_one(struct device_node *np, > + unsigned long offset) > +{ > + struct cbe_iommu *iommu; > + unsigned long base, size; > + > + iommu = cell_iommu_alloc(np); > + if (!iommu) > + return; > + > /* Obtain a window for it */ > cell_iommu_get_window(np, &base, &size); > _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev