On Mon, Jan 14, 2013 at 01:07:56PM +0200, Gleb Natapov wrote: > Ah, of course. This is ident map so by definition it cannot map phys > addresses above 4G. And since __virt_to_phys() suppose to work only on > ident map it's OK to returns unsigned long. Let's get this right... the lack of correct definition in these comments needs correction. Firstly, __virt_to_phys() is an ARM-arch private function. Only ARM-arch private code should be using it - it must not be used outside that context. Secondly, it's "public" counterpart, virt_to_phys(), and itself are valid _only_ for what we call the "kernel direct map", which are the addresses corresponding with the lowmem pages mapped from PAGE_OFFSET up to the _start_ of vmalloc space. No other mapping is valid for this. That means that addresses in the identity mapping, if the identity mapping is outside of the range {PAGE_OFFSET..vmalloc start}, are _not_ valid for virt_to_phys(). The same is true of their counterparts, __phys_to_virt() and phys_to_virt(). These are _only_ valid for physical addresses corresponding to the pages mapped in as "lowmem" and they will return addresses for that mapping of the pages. Both these functions are invalid when used on highmem pages. *virt_to_phys() is invalid when used on pointers returned from ioremap(), vmalloc(), vmap(), dma_alloc_coherent(), and any other interface which remaps memory. -- 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