On Sun Dec 20 09:02, Segher Boessenkool wrote: > On Wed, Nov 25, 2015 at 10:46:49AM -0800, Curt Brune wrote: > > + /* Check if the ports have an ordering, defined by 'cell-index' */ > > + if (((indexp = (u32*)of_get_property(np, "cell-index", &len)) != NULL) && > > + (len == sizeof(u32))) > > + index = *indexp; > > + > > /* Add port, irq will be dealt with later. We passed a translated > > * IO port value. It will be fixed up later along with the irq > > */ > > if (tsi && !strcmp(tsi->type, "tsi-bridge")) > > - return add_legacy_port(np, -1, UPIO_TSI, addr, addr, > > + return add_legacy_port(np, index, UPIO_TSI, addr, addr, > > NO_IRQ, legacy_port_flags, 0); > > else > > - return add_legacy_port(np, -1, UPIO_MEM, addr, addr, > > + return add_legacy_port(np, index, UPIO_MEM, addr, addr, > > NO_IRQ, legacy_port_flags, 0); > > What does this do if the value in cell-index is a duplicate. or the port > with that number is already created some other way? Are the numbers in > cell-index global anyway, or relative to some parent device (I couldn't > find the documentation for this). > > > Segher add_legacy_port() has support for handling duplicate index entries. Reading that code it looks like the recent entry wins and the older entry is moved to the next available index. The numbers in cell-index are not global nor explicitly relative to a parent device. I also could not find documentation on this. In common usage, however, the cell-index property is used in two different ways: 1. For devices that have "channels" or "regions" (DMA for example), the parent device node has child nodes enumerated by cell-index. For example see: arch/powerpc/boot/dts/fsl/pq3-dma-0.dtsi 2. For multiple instances of a device, for example UARTS, each device node is enumerated using cell-index. See: arch/powerpc/boot/dts/fsl/qoriq-duart-0.dtsi Cheers, Curt -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html