Hello.
I'm trying to remap some kernel static memory to user space using
remap_pfn_range.
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)
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)));
EXPORT_SYMBOL(user_space_shared);
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.
ps:
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)
Please, anyone knows how to solve this problem?
2013/3/20 Eduardo Cruz <[email protected]>:
> Hello.
>
> I'm trying to remap some kernel static memory to user space using
> remap_pfn_range.
> 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)
>
> 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)));
> EXPORT_SYMBOL(user_space_shared);
>
> 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.
>
> ps:
> 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)
--
Eduardo Henrique Molina da Cruz
PhD student
Parallel and Distributed Processing Group
Federal University of Rio Grande do Sul (UFRGS)
Eduardo Cruz wrote:
> Please, anyone knows how to solve this problem?
>
> 2013/3/20 Eduardo Cruz <[email protected]>:
>> I'm trying to remap some kernel static memory to user space using
>> remap_pfn_range.
Well, don't do that.
What is the actual problem you're trying to solve?
Regards,
Clemens
I'm adding some asm code in arch/ia64/kernel/ivt.S
to gather some memory usage statistics.
>From whatever reason, when I allocate the memory using
kmalloc/vmalloc, my assembly code cashes the machine when I load the
allocated memory.
If I use static allocated memory, the asm code works.
I know the problem is not the assembly code.
The problem is that I want to be able to read this data from user space.
Since the code performance critical, I don't want to do a
copy_to_user, I prefer to mmap this data into user space.
The problem is, if I use kmalloc/vmalloc, I managed to map the memory
to user space.
However, the asm interrupt handler crashs.
On the other hand, if I use static data, the asm interrupt handler
works, while the mmap fails.
Do you have any clues?
2013/3/22 Clemens Ladisch <[email protected]>:
> Eduardo Cruz wrote:
>> Please, anyone knows how to solve this problem?
>>
>> 2013/3/20 Eduardo Cruz <[email protected]>:
>>> I'm trying to remap some kernel static memory to user space using
>>> remap_pfn_range.
>
> Well, don't do that.
>
> What is the actual problem you're trying to solve?
>
>
> Regards,
> Clemens
--
Eduardo Henrique Molina da Cruz
PhD student
Parallel and Distributed Processing Group
Federal University of Rio Grande do Sul (UFRGS)
On Wed, 20 Mar 2013, Eduardo Cruz wrote:
> Hello.
>
> I'm trying to remap some kernel static memory to user space using
> remap_pfn_range.
> 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
that virt_to_phys(user_space_shared).
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 arch/ia64/include/asm/processor.h.
Hugh
>
> 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)));
> EXPORT_SYMBOL(user_space_shared);
>
> 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.
>
> ps:
> 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)
Man, it worked!
You saved my life kkkkkkkkkkkkkkk.
Thank you very much!
2013/3/23 Hugh Dickins <[email protected]>:
> On Wed, 20 Mar 2013, Eduardo Cruz wrote:
>
>> Hello.
>>
>> I'm trying to remap some kernel static memory to user space using
>> remap_pfn_range.
>> 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
> that virt_to_phys(user_space_shared).
>
> 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 arch/ia64/include/asm/processor.h.
>
> Hugh
>
>>
>> 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)));
>> EXPORT_SYMBOL(user_space_shared);
>>
>> 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.
>>
>> ps:
>> 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)
--
Eduardo Henrique Molina da Cruz
PhD student
Parallel and Distributed Processing Group
Federal University of Rio Grande do Sul (UFRGS)