Re: remap kernel static memory to user space
From: Hugh Dickins
Date: Sat Mar 23 2013 - 17:34:28 EST
On Wed, 20 Mar 2013, Eduardo Cruz wrote:
> I'm trying to remap some kernel static memory to user space using
> For that, I wrote a module that initializes a device, which later I
> use mknod, etc.
> When I allocate the memory with kmalloc, everything works: (where
> user_space_shared was allocated with kmalloc)
> if ((ret = remap_pfn_range(vma, vma->vm_start,
> virt_to_phys(user_space_shared) >> PAGE_SHIFT, length,
> vma->vm_page_prot)) < 0)
I have no ia64 experience, but my guess is that your problem is with
virt_to_phys() expects to be given an address from the kernel's direct
map of physical memory; whereas if you declare user_space_shared in
kernel static memory, I believe ia64 places that in a different region.
Try changing that to virt_to_phys(ia64_imva(user_space_shared))
and I expect it will then work: see comment above ia64_imva()
> In the application in user space:
> kstc = mmap(0, sizeof(user_space_shared_t), PROT_READ|PROT_WRITE,
> MAP_SHARED| MAP_LOCKED, fd, 0);
> With user_space_shared allocated using kmalloc, it is working.
> The application is able to read the data I wrote in the kernel module.
> However, when I define and allocate that var in arch/ia64/mm/fault.c:
> unsigned char user_space_shared[ sizeof(user_space_shared_t) +
> PAGE_SIZE ] __attribute__((aligned(PAGE_SIZE)));
> And access that var from the module:
> extern unsigned char user_space_shared[ sizeof(user_space_shared_t) +
> PAGE_SIZE ];
> There is no error message, but I can't read the contents i wrote
> inside the kernel module from the application.
> Your help would be appreciated.
> I am taking care of page offsets/boundaries.
> I'm using kernel 2.6.32 for ia64.
> Eduardo Henrique Molina da Cruz
> PhD student
> Parallel and Distributed Processing Group
> Federal University of Rio Grande do Sul (UFRGS)
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/