On Wed, Dec 28, 2016 at 05:46:21PM +0100, Thomas Petazzoni wrote: > This commit adds the definition of the PPv2.2 HW descriptors, adjusts > the mvpp2_tx_desc and mvpp2_rx_desc structures accordingly, and adapts > the accessors to work on both PPv2.1 and PPv2.2. > > Signed-off-by: Thomas Petazzoni <thomas.petazzoni@xxxxxxxxxxxxxxxxxx> ... > + /* On PPv2.2, the situation is more complicated, > + * because there is only 40 bits to store the virtual > + * address, which is not sufficient. So on 64 bits > + * systems, we use phys_to_virt() to get the virtual > + * address from the physical address, which is fine > + * because the kernel linear mapping includes the > + * entire 40 bits physical address space. On 32 bits > + * systems however, we can't use phys_to_virt(), but > + * since virtual addresses are 32 bits only, there is > + * enough space in the RX descriptor for the full > + * virtual address. > + */ > +#ifdef CONFIG_ARCH_DMA_ADDR_T_64BIT > + dma_addr_t dma_addr = > + rx_desc->pp22.buf_phys_addr_key_hash & DMA_BIT_MASK(40); > + phys_addr_t phys_addr = > + dma_to_phys(port->dev->dev.parent, dma_addr); > + > + return (unsigned long)phys_to_virt(phys_addr); > +#else > + return rx_desc->pp22.buf_cookie_misc & DMA_BIT_MASK(40); > +#endif I'm not sure that's the best way of selecting the difference. It seems that the issue here is the size of the virtual address, so why not test the size of a virtual address pointer? if (8 * sizeof(rx_desc) > 40) { /* do phys addr dance */ } else { return rx_desc->pp22.buf_cookie_misc & DMA_BIT_MASK(40); } It also means that we get compile coverage over both sides of the conditional. -- RMK's Patch system: http://www.armlinux.org.uk/developer/patches/ FTTC broadband for 0.8mile line: currently at 9.6Mbps down 400kbps up according to speedtest.net. -- 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