diff options
| author | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
|---|---|---|
| committer | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
| commit | fcdcc79628a1919bde9acf239e364f65bab6327c (patch) | |
| tree | 5499be387cf3028c90ac083b1cf866ebed7bf7e0 /include/linux/genalloc.h | |
| parent | 7a8d44bc89e5cddcd5c0704a11a90484d36ba6ba (diff) | |
| parent | a0a90718f18264dc904d34a580f332006f5561e9 (diff) | |
| download | linux-fcdcc79628a1919bde9acf239e364f65bab6327c.tar.xz | |
Merge branch 'topic/acpi' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi into spi-pxa2xx
Diffstat (limited to 'include/linux/genalloc.h')
| -rw-r--r-- | include/linux/genalloc.h | 38 | 
1 files changed, 34 insertions, 4 deletions
| diff --git a/include/linux/genalloc.h b/include/linux/genalloc.h index 7ff168d06967..29d4385903d4 100644 --- a/include/linux/genalloc.h +++ b/include/linux/genalloc.h @@ -30,10 +30,12 @@  #ifndef __GENALLOC_H__  #define __GENALLOC_H__ +#include <linux/types.h>  #include <linux/spinlock_types.h>  struct device;  struct device_node; +struct gen_pool;  /**   * Allocation callback function type definition @@ -47,7 +49,7 @@ typedef unsigned long (*genpool_algo_t)(unsigned long *map,  			unsigned long size,  			unsigned long start,  			unsigned int nr, -			void *data); +			void *data, struct gen_pool *pool);  /*   *  General purpose special memory pool descriptor. @@ -75,6 +77,20 @@ struct gen_pool_chunk {  	unsigned long bits[0];		/* bitmap for allocating memory chunk */  }; +/* + *  gen_pool data descriptor for gen_pool_first_fit_align. + */ +struct genpool_data_align { +	int align;		/* alignment by bytes for starting address */ +}; + +/* + *  gen_pool data descriptor for gen_pool_fixed_alloc. + */ +struct genpool_data_fixed { +	unsigned long offset;		/* The offset of the specific region */ +}; +  extern struct gen_pool *gen_pool_create(int, int);  extern phys_addr_t gen_pool_virt_to_phys(struct gen_pool *pool, unsigned long);  extern int gen_pool_add_virt(struct gen_pool *, unsigned long, phys_addr_t, @@ -98,6 +114,8 @@ static inline int gen_pool_add(struct gen_pool *pool, unsigned long addr,  }  extern void gen_pool_destroy(struct gen_pool *);  extern unsigned long gen_pool_alloc(struct gen_pool *, size_t); +extern unsigned long gen_pool_alloc_algo(struct gen_pool *, size_t, +		genpool_algo_t algo, void *data);  extern void *gen_pool_dma_alloc(struct gen_pool *pool, size_t size,  		dma_addr_t *dma);  extern void gen_pool_free(struct gen_pool *, unsigned long, size_t); @@ -110,14 +128,26 @@ extern void gen_pool_set_algo(struct gen_pool *pool, genpool_algo_t algo,  		void *data);  extern unsigned long gen_pool_first_fit(unsigned long *map, unsigned long size, -		unsigned long start, unsigned int nr, void *data); +		unsigned long start, unsigned int nr, void *data, +		struct gen_pool *pool); + +extern unsigned long gen_pool_fixed_alloc(unsigned long *map, +		unsigned long size, unsigned long start, unsigned int nr, +		void *data, struct gen_pool *pool); + +extern unsigned long gen_pool_first_fit_align(unsigned long *map, +		unsigned long size, unsigned long start, unsigned int nr, +		void *data, struct gen_pool *pool); +  extern unsigned long gen_pool_first_fit_order_align(unsigned long *map,  		unsigned long size, unsigned long start, unsigned int nr, -		void *data); +		void *data, struct gen_pool *pool);  extern unsigned long gen_pool_best_fit(unsigned long *map, unsigned long size, -		unsigned long start, unsigned int nr, void *data); +		unsigned long start, unsigned int nr, void *data, +		struct gen_pool *pool); +  extern struct gen_pool *devm_gen_pool_create(struct device *dev,  		int min_alloc_order, int nid, const char *name); | 
