]>
Commit | Line | Data |
---|---|---|
0c06db59 | 1 | |
336d4615 | 2 | #include <malloc.h> |
e3332e1a | 3 | #include <memalign.h> |
90526e9f | 4 | #include <asm/cache.h> |
0c06db59 HS |
5 | #include <linux/compat.h> |
6 | ||
7 | struct p_current cur = { | |
8 | .pid = 1, | |
9 | }; | |
10 | __maybe_unused struct p_current *current = &cur; | |
11 | ||
12 | unsigned long copy_from_user(void *dest, const void *src, | |
13 | unsigned long count) | |
14 | { | |
15 | memcpy((void *)dest, (void *)src, count); | |
16 | return 0; | |
17 | } | |
18 | ||
19 | void *kmalloc(size_t size, int flags) | |
20 | { | |
6b9f9ead | 21 | void *p; |
0c06db59 | 22 | |
e3332e1a | 23 | p = malloc_cache_aligned(size); |
2ad98ab8 | 24 | if (p && flags & __GFP_ZERO) |
6b9f9ead MY |
25 | memset(p, 0, size); |
26 | ||
27 | return p; | |
0c06db59 HS |
28 | } |
29 | ||
0c06db59 HS |
30 | struct kmem_cache *get_mem(int element_sz) |
31 | { | |
32 | struct kmem_cache *ret; | |
33 | ||
34 | ret = memalign(ARCH_DMA_MINALIGN, sizeof(struct kmem_cache)); | |
35 | ret->sz = element_sz; | |
36 | ||
37 | return ret; | |
38 | } | |
39 | ||
40 | void *kmem_cache_alloc(struct kmem_cache *obj, int flag) | |
41 | { | |
e3332e1a | 42 | return malloc_cache_aligned(obj->sz); |
0c06db59 | 43 | } |
4839e868 AT |
44 | |
45 | /** | |
46 | * kmemdup - duplicate region of memory | |
47 | * | |
48 | * @src: memory region to duplicate | |
49 | * @len: memory region length | |
50 | * @gfp: GFP mask to use | |
51 | * | |
52 | * Return: newly allocated copy of @src or %NULL in case of error | |
53 | */ | |
54 | void *kmemdup(const void *src, size_t len, gfp_t gfp) | |
55 | { | |
56 | void *p; | |
57 | ||
58 | p = kmalloc(len, gfp); | |
59 | if (p) | |
60 | memcpy(p, src, len); | |
61 | return p; | |
62 | } |