mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-14 16:23:51 +08:00
c1ce6c2bee
Add dummies for dma{,m}_pool_{create,destroy,alloc,free}(), to allow compile-testing if NO_DMA=y. This prevents the following from showing up later: ERROR: "dma_pool_destroy" [drivers/usb/mtu3/mtu3.ko] undefined! ERROR: "dma_pool_free" [drivers/usb/mtu3/mtu3.ko] undefined! ERROR: "dma_pool_alloc" [drivers/usb/mtu3/mtu3.ko] undefined! ERROR: "dma_pool_create" [drivers/usb/mtu3/mtu3.ko] undefined! ERROR: "dma_pool_destroy" [drivers/scsi/hisi_sas/hisi_sas_main.ko] undefined! ERROR: "dma_pool_free" [drivers/scsi/hisi_sas/hisi_sas_main.ko] undefined! ERROR: "dma_pool_alloc" [drivers/scsi/hisi_sas/hisi_sas_main.ko] undefined! ERROR: "dma_pool_create" [drivers/scsi/hisi_sas/hisi_sas_main.ko] undefined! ERROR: "dma_pool_alloc" [drivers/mailbox/bcm-pdc-mailbox.ko] undefined! ERROR: "dma_pool_free" [drivers/mailbox/bcm-pdc-mailbox.ko] undefined! ERROR: "dma_pool_create" [drivers/mailbox/bcm-pdc-mailbox.ko] undefined! ERROR: "dma_pool_destroy" [drivers/mailbox/bcm-pdc-mailbox.ko] undefined! Signed-off-by: Geert Uytterhoeven <geert@linux-m68k.org> Reviewed-by: Mark Brown <broonie@kernel.org> Acked-by: Robin Murphy <robin.murphy@arm.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
60 lines
1.8 KiB
C
60 lines
1.8 KiB
C
/*
|
|
* include/linux/dmapool.h
|
|
*
|
|
* Allocation pools for DMAable (coherent) memory.
|
|
*
|
|
* This file is licensed under the terms of the GNU General Public
|
|
* License version 2. This program is licensed "as is" without any
|
|
* warranty of any kind, whether express or implied.
|
|
*/
|
|
|
|
#ifndef LINUX_DMAPOOL_H
|
|
#define LINUX_DMAPOOL_H
|
|
|
|
#include <linux/scatterlist.h>
|
|
#include <asm/io.h>
|
|
|
|
struct device;
|
|
|
|
#ifdef CONFIG_HAS_DMA
|
|
|
|
struct dma_pool *dma_pool_create(const char *name, struct device *dev,
|
|
size_t size, size_t align, size_t allocation);
|
|
|
|
void dma_pool_destroy(struct dma_pool *pool);
|
|
|
|
void *dma_pool_alloc(struct dma_pool *pool, gfp_t mem_flags,
|
|
dma_addr_t *handle);
|
|
void dma_pool_free(struct dma_pool *pool, void *vaddr, dma_addr_t addr);
|
|
|
|
/*
|
|
* Managed DMA pool
|
|
*/
|
|
struct dma_pool *dmam_pool_create(const char *name, struct device *dev,
|
|
size_t size, size_t align, size_t allocation);
|
|
void dmam_pool_destroy(struct dma_pool *pool);
|
|
|
|
#else /* !CONFIG_HAS_DMA */
|
|
static inline struct dma_pool *dma_pool_create(const char *name,
|
|
struct device *dev, size_t size, size_t align, size_t allocation)
|
|
{ return NULL; }
|
|
static inline void dma_pool_destroy(struct dma_pool *pool) { }
|
|
static inline void *dma_pool_alloc(struct dma_pool *pool, gfp_t mem_flags,
|
|
dma_addr_t *handle) { return NULL; }
|
|
static inline void dma_pool_free(struct dma_pool *pool, void *vaddr,
|
|
dma_addr_t addr) { }
|
|
static inline struct dma_pool *dmam_pool_create(const char *name,
|
|
struct device *dev, size_t size, size_t align, size_t allocation)
|
|
{ return NULL; }
|
|
static inline void dmam_pool_destroy(struct dma_pool *pool) { }
|
|
#endif /* !CONFIG_HAS_DMA */
|
|
|
|
static inline void *dma_pool_zalloc(struct dma_pool *pool, gfp_t mem_flags,
|
|
dma_addr_t *handle)
|
|
{
|
|
return dma_pool_alloc(pool, mem_flags | __GFP_ZERO, handle);
|
|
}
|
|
|
|
#endif
|
|
|