不知道从哪里开始,所以选择kmalloc . kfree先研究了!
2.6.14内核kmalloc代码如下(linux/mm/slab.h):
static inline void *kmalloc(size_t size, gfp_t flags)
{
if (__builtin_constant_p(size)) {
int i = 0;
#define CACHE(x) /
if (size <= x) /
goto found; /
else /
i++;
#include "kmalloc_sizes.h"
#undef CACHE
{
extern void __you_cannot_kmalloc_that_much(void);
__you_cannot_kmalloc_that_much();
}
found:
return kmem_cache_alloc((flags & GFP_DMA) ?
malloc_sizes[i].cs_dmacachep :
malloc_sizes[i].cs_cachep, flags);
}
return __kmalloc(size, flags);
}
_builtin_constant_p(x) gcc 专用
如果x在编译的时候就能获得常值,则为TRUE;如果是变量则为FALSE
if分支真的时候往kmem_cache_alloc()走,假的时候往__kmalloc()走.
继续往__kmalloc(size, flags)方向跟.
mm/slab.c
void *__kmalloc(size_t size, gfp_t flags)
{
kmem_cache_t *cachep;
/* If you want to save a few bytes .text space: replace
* __ with kmem_.
* Then kmalloc uses the uninlined functions instead of the inline
* functions.
*/
cachep = __find_general_cachep(size, flags);
if (unlikely(cachep == NULL))
return NULL;
return __cache_alloc(cachep, flags);
}
flags标记有GFP_USER、GFP_KERNEL、GFP_ATOMIC、GFP_DMA。
size 已字节为单位
__find_general_cachep函数返回数组malloc_sizes[]的某个项,malloc_sizes