diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-13 01:45:43 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-13 01:45:43 -0500 |
commit | 5cbb3d216e2041700231bcfc383ee5f8b7fc8b74 (patch) | |
tree | a738fa82dbcefa9bd283c08bc67f38827be63937 /lib/genalloc.c | |
parent | 9bc9ccd7db1c9f043f75380b5a5b94912046a60e (diff) | |
parent | 4e9b45a19241354daec281d7a785739829b52359 (diff) |
Merge branch 'akpm' (patches from Andrew Morton)
Merge first patch-bomb from Andrew Morton:
"Quite a lot of other stuff is banked up awaiting further
next->mainline merging, but this batch contains:
- Lots of random misc patches
- OCFS2
- Most of MM
- backlight updates
- lib/ updates
- printk updates
- checkpatch updates
- epoll tweaking
- rtc updates
- hfs
- hfsplus
- documentation
- procfs
- update gcov to gcc-4.7 format
- IPC"
* emailed patches from Andrew Morton <akpm@linux-foundation.org>: (269 commits)
ipc, msg: fix message length check for negative values
ipc/util.c: remove unnecessary work pending test
devpts: plug the memory leak in kill_sb
./Makefile: export initial ramdisk compression config option
init/Kconfig: add option to disable kernel compression
drivers: w1: make w1_slave::flags long to avoid memory corruption
drivers/w1/masters/ds1wm.cuse dev_get_platdata()
drivers/memstick/core/ms_block.c: fix unreachable state in h_msb_read_page()
drivers/memstick/core/mspro_block.c: fix attributes array allocation
drivers/pps/clients/pps-gpio.c: remove redundant of_match_ptr
kernel/panic.c: reduce 1 byte usage for print tainted buffer
gcov: reuse kbasename helper
kernel/gcov/fs.c: use pr_warn()
kernel/module.c: use pr_foo()
gcov: compile specific gcov implementation based on gcc version
gcov: add support for gcc 4.7 gcov format
gcov: move gcov structs definitions to a gcc version specific file
kernel/taskstats.c: return -ENOMEM when alloc memory fails in add_del_listener()
kernel/taskstats.c: add nla_nest_cancel() for failure processing between nla_nest_start() and nla_nest_end()
kernel/sysctl_binary.c: use scnprintf() instead of snprintf()
...
Diffstat (limited to 'lib/genalloc.c')
-rw-r--r-- | lib/genalloc.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/genalloc.c b/lib/genalloc.c index 26cf20be72b7..dda31168844f 100644 --- a/lib/genalloc.c +++ b/lib/genalloc.c | |||
@@ -313,6 +313,34 @@ retry: | |||
313 | EXPORT_SYMBOL(gen_pool_alloc); | 313 | EXPORT_SYMBOL(gen_pool_alloc); |
314 | 314 | ||
315 | /** | 315 | /** |
316 | * gen_pool_dma_alloc - allocate special memory from the pool for DMA usage | ||
317 | * @pool: pool to allocate from | ||
318 | * @size: number of bytes to allocate from the pool | ||
319 | * @dma: dma-view physical address | ||
320 | * | ||
321 | * Allocate the requested number of bytes from the specified pool. | ||
322 | * Uses the pool allocation function (with first-fit algorithm by default). | ||
323 | * Can not be used in NMI handler on architectures without | ||
324 | * NMI-safe cmpxchg implementation. | ||
325 | */ | ||
326 | void *gen_pool_dma_alloc(struct gen_pool *pool, size_t size, dma_addr_t *dma) | ||
327 | { | ||
328 | unsigned long vaddr; | ||
329 | |||
330 | if (!pool) | ||
331 | return NULL; | ||
332 | |||
333 | vaddr = gen_pool_alloc(pool, size); | ||
334 | if (!vaddr) | ||
335 | return NULL; | ||
336 | |||
337 | *dma = gen_pool_virt_to_phys(pool, vaddr); | ||
338 | |||
339 | return (void *)vaddr; | ||
340 | } | ||
341 | EXPORT_SYMBOL(gen_pool_dma_alloc); | ||
342 | |||
343 | /** | ||
316 | * gen_pool_free - free allocated special memory back to the pool | 344 | * gen_pool_free - free allocated special memory back to the pool |
317 | * @pool: pool to free to | 345 | * @pool: pool to free to |
318 | * @addr: starting address of memory to free back to pool | 346 | * @addr: starting address of memory to free back to pool |