在mm/util.c 中对kmalloc有一些简单封装,以kmemdup为例,这个函数会帮你申请一块memory,并将制定的原地址中的内容copy带新申请的memory中。
void *kmemdup(const void *src, size_t len, gfp_t gfp)
{
void *p;
p = kmalloc_track_caller(len, gfp);
if (p)
memcpy(p, src, len);
return p;
}
可以看到先通过kmalloc_track_caller 申请一块新的内从,让有将src中的内容通过memcpy copy到p中,然后返回p给你,这样可以将原本程序中的kmalloc和memcpy两部操作简化成一步操作。
类似的还有kstrndup。
char *kstrndup(const char *s, size_t max, gfp_t gfp)
{
size_t len;
char *buf;
if (!s)
return NULL;
len = strnlen(s, max);
buf = kmalloc_track_caller(len+1, gfp);
if (buf) {
memcpy(buf, s, len);
buf[len] = '\0';
}
return buf;
}
这个函数strnlen得到s的size,然后通过kmalloc_track_caller 申请一块新的memory,然后通过memcpy将s的内容copy到新申请的buf中,并且在buf中自动帮你添加'\0',将原本的四步操作变成了一步。
void *kmemdup(const void *src, size_t len, gfp_t gfp)
{
void *p;
p = kmalloc_track_caller(len, gfp);
if (p)
memcpy(p, src, len);
return p;
}
可以看到先通过kmalloc_track_caller 申请一块新的内从,让有将src中的内容通过memcpy copy到p中,然后返回p给你,这样可以将原本程序中的kmalloc和memcpy两部操作简化成一步操作。
类似的还有kstrndup。
char *kstrndup(const char *s, size_t max, gfp_t gfp)
{
size_t len;
char *buf;
if (!s)
return NULL;
len = strnlen(s, max);
buf = kmalloc_track_caller(len+1, gfp);
if (buf) {
memcpy(buf, s, len);
buf[len] = '\0';
}
return buf;
}
这个函数strnlen得到s的size,然后通过kmalloc_track_caller 申请一块新的memory,然后通过memcpy将s的内容copy到新申请的buf中,并且在buf中自动帮你添加'\0',将原本的四步操作变成了一步。