summaryrefslogtreecommitdiffstats
path: root/include/sys/kmem.h
diff options
context:
space:
mode:
authorbehlendo <behlendo@7e1ea52c-4ff2-0310-8f11-9dd32ca42a1c>2008-03-31 23:04:07 +0000
committerbehlendo <behlendo@7e1ea52c-4ff2-0310-8f11-9dd32ca42a1c>2008-03-31 23:04:07 +0000
commit4fd2f7eea565ee473ac433f28c1b309999abbd19 (patch)
tree2aad257d381f83a9cc85396ab8ad6fb1f4268905 /include/sys/kmem.h
parent8d0f1ee907d425e71e34e1aea9c1b5465f8cd4d1 (diff)
Add vmem_zalloc support.
git-svn-id: https://outreach.scidac.gov/svn/spl/trunk@60 7e1ea52c-4ff2-0310-8f11-9dd32ca42a1c
Diffstat (limited to 'include/sys/kmem.h')
-rw-r--r--include/sys/kmem.h29
1 files changed, 18 insertions, 11 deletions
diff --git a/include/sys/kmem.h b/include/sys/kmem.h
index 58ae07747..393775fab 100644
--- a/include/sys/kmem.h
+++ b/include/sys/kmem.h
@@ -35,14 +35,14 @@ extern int kmem_warning_flag;
\
/* Marked unlikely because we should never be doing this */ \
if (unlikely((size) > (PAGE_SIZE * 2)) && kmem_warning_flag) \
- printk("spl: Warning kmem_alloc(%d, 0x%x) large alloc at %s:%d " \
+ printk("spl: Warning kmem_alloc(%d, 0x%x) large alloc at %s:%d "\
"(%ld/%ld)\n", (int)(size), (int)(flags), \
__FILE__, __LINE__, \
atomic64_read(&kmem_alloc_used), kmem_alloc_max); \
\
_ptr_ = (void *)allocator((size), (flags)); \
if (_ptr_ == NULL) { \
- printk("spl: Warning kmem_alloc(%d, 0x%x) failed at %s:%d " \
+ printk("spl: Warning kmem_alloc(%d, 0x%x) failed at %s:%d " \
"(%ld/%ld)\n", (int)(size), (int)(flags), \
__FILE__, __LINE__, \
atomic64_read(&kmem_alloc_used), kmem_alloc_max); \
@@ -55,8 +55,8 @@ extern int kmem_warning_flag;
_ptr_; \
})
-#define kmem_alloc(size, flags) __kmem_alloc(size, flags, kmalloc)
-#define kmem_zalloc(size, flags) __kmem_alloc(size, flags, kzalloc)
+#define kmem_alloc(size, flags) __kmem_alloc((size), (flags), kmalloc)
+#define kmem_zalloc(size, flags) __kmem_alloc((size), (flags), kzalloc)
#define kmem_free(ptr, size) \
({ \
@@ -69,11 +69,12 @@ extern int kmem_warning_flag;
#define __vmem_alloc(size, flags) \
({ void *_ptr_; \
\
- BUG_ON(flags != KM_SLEEP); \
+ BUG_ON(!(flags & KM_SLEEP)); \
\
- _ptr_ = (void *)vmalloc((size)); \
+ _ptr_ = (void *)__vmalloc((size), ((flags) | \
+ __GFP_HIGHMEM), PAGE_KERNEL); \
if (_ptr_ == NULL) { \
- printk("spl: Warning vmem_alloc(%d, 0x%x) failed at %s:%d " \
+ printk("spl: Warning vmem_alloc(%d, 0x%x) failed at %s:%d " \
"(%ld/%ld)\n", (int)(size), (int)(flags), \
__FILE__, __LINE__, \
atomic64_read(&vmem_alloc_used), vmem_alloc_max); \
@@ -86,7 +87,9 @@ extern int kmem_warning_flag;
_ptr_; \
})
-#define vmem_alloc(size, flags) __vmem_alloc(size, flags)
+#define vmem_alloc(size, flags) __vmem_alloc((size), (flags))
+#define vmem_zalloc(size, flags) __vmem_alloc((size), ((flags) | \
+ __GFP_ZERO))
#define vmem_free(ptr, size) \
({ \
@@ -98,15 +101,19 @@ extern int kmem_warning_flag;
#else
-#define kmem_alloc(size, flags) kmalloc(size, flags)
-#define kmem_zalloc(size, flags) kzalloc(size, flags)
+#define kmem_alloc(size, flags) kmalloc((size), (flags))
+#define kmem_zalloc(size, flags) kzalloc((size), (flags))
#define kmem_free(ptr, size) \
({ \
BUG_ON(!(ptr) || (size) < 0); \
kfree(ptr); \
})
-#define vmem_alloc(size, flags) vmalloc(size)
+#define vmem_alloc(size, flags) __vmalloc((size), ((flags) | \
+ __GFP_HIGHMEM), PAGE_KERNEL)
+#define vmem_zalloc(size, flags) __vmalloc((size), ((flags) | \
+ __GFP_HIGHMEM | __GFP_ZERO) \
+ PAGE_KERNEL)
#define vmem_free(ptr, size) \
({ \
BUG_ON(!(ptr) || (size) < 0); \