On Wed, 2013-07-31 at 16:47 +0800, Gavin Shan wrote: > Usually, the property "ibm,opal-num-pes" of PHB dev-tree node > indicates the number of total PEs. If that property isn't existing > or valid, we should fall back to pick the correct number of total > PEs according to PHB type: IODA1 or IODA2.
Is that correct ? Don't we get the total number of PEs from a config register on the bridge ? I didn't think the IODA architecture specified the total number of PE of a given implementation... For example, does Torrent implement 128 ? I'd rather stick to safe here, if the firmware doesn't say, just use one. Now some of the PHB registers are actually architected in IODA afaik, so we could just go look but let's not make a precedent here. Cheers, Ben. > Signed-off-by: Gavin Shan <sha...@linux.vnet.ibm.com> > --- > arch/powerpc/platforms/powernv/pci-ioda.c | 11 +++++++---- > 1 files changed, 7 insertions(+), 4 deletions(-) > > diff --git a/arch/powerpc/platforms/powernv/pci-ioda.c > b/arch/powerpc/platforms/powernv/pci-ioda.c > index 829047b..6386bb4 100644 > --- a/arch/powerpc/platforms/powernv/pci-ioda.c > +++ b/arch/powerpc/platforms/powernv/pci-ioda.c > @@ -1172,11 +1172,14 @@ void __init pnv_pci_init_ioda_phb(struct device_node > *np, > > /* Initialize more IODA stuff */ > prop32 = of_get_property(np, "ibm,opal-num-pes", NULL); > - if (!prop32) > - phb->ioda.total_pe = 1; > - else > + if (prop32) > phb->ioda.total_pe = *prop32; > - > + else if (phb->type == PNV_PHB_IODA1) > + phb->ioda.total_pe = 128; > + else if (phb->type == PNV_PHB_IODA2) > + phb->ioda.total_pe = 256; > + else > + phb->ioda.total_pe = 1; > phb->ioda.m32_size = resource_size(&hose->mem_resources[0]); > /* FW Has already off top 64k of M32 space (MSI space) */ > phb->ioda.m32_size += 0x10000; _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev