On Fri, 2009-05-08 at 00:11 +0200, Arnd Bergmann wrote: > On Thursday 07 May 2009, Chris Wright wrote: > > > > > Chris, is that issue with the non ioread/iowrite access of a mangled > > > pointer still an issue here? I would think so, but I am a bit fuzzy on > > > whether there is still an issue of non-wrapped MMIO ever occuring. > > > > Arnd was saying it's a bug for other reasons, so perhaps it would work > > out fine. > > Well, maybe. I only said that __raw_writel and pointer dereference is > bad, but not writel. I have only vague recollection of that stuff, but basically, it boiled down to me attempting to use annotations to differenciate old style "ioremap" vs. new style iomap and effectively forbid mixing ioremap with iomap in either direction. This was shot down by a vast majority of people, with the outcome being an agreement that for IORESOURCE_MEM, pci_iomap and friends must return something that is strictly interchangeable with what ioremap would have returned. That means that readl and writel must work on the output of pci_iomap() and similar, but I don't see why __raw_writel would be excluded there, I think it's in there too. Direct dereference is illegal in all cases though. The token returned by pci_iomap for other type of resources (IO for example) is also only supported for use by iomap access functions (ioreadXX/iowriteXX) , and IO ports cannot be passed directly to those neither. Cheers, Ben. -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html