vmalloc and Friends
The next memory allocation function that I’ll show you is
vmalloc, which allocates a contiguous memory region in
the virtual address space. Although the pages are not
necessarily consecutive in
physical memory (each page is retrieved with a separate call to
__get_free_page), the
kernel sees them as a contiguous range of addresses. The
allocated space is mapped only to the kernel segments and is not
visible from user space--not unlike the other allocation
techniques. vmalloc returns 0 (the NULL
address) if an error occurred, otherwise it returns a pointer to a
linear memory area of
size size
.
The prototypes of the function, and its relatives, are the following:
void * vmalloc(unsigned long size); void vfree(void * addr); void * vremap(unsigned long offset, unsigned long size);
Note that vremap was renamed ioremap
in version 2.1. Moreover, Linux 2.1 introduced a new header,
<linux/vmalloc.h>
, that
must be included if you use vmalloc.
vmalloc is different from the other memory allocation functions because it returns ``high'' addresses--addresses that are higher than the top of physical memory. The processor is able to access the returned memory range because vmalloc arranged the processor’s page tables to access the allocated pages through consecutive ``high'' addresses. Kernel code can use addresses returned by vmalloc just like any other address, but the address used by the program is not the same as the one that appears on the electrical data bus.
Addresses ...
Get Linux Device Drivers now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.