lmb: add versions of the lmb API with flags
The LMB module is to be used as a backend for allocating and freeing up memory requested from other modules like EFI. These memory requests are different from the typical LMB reservations in that memory required by the EFI module cannot be overwritten, or re-requested. Add versions of the LMB API functions with flags for allocating and freeing up memory. The caller can then use these API's for specifying the type of memory that is required. For now, these functions will be used by the EFI memory module. Signed-off-by: Sughosh Ganu <sughosh.ganu@linaro.org> Reviewed-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
@@ -90,6 +90,50 @@ phys_addr_t lmb_alloc_base(phys_size_t size, ulong align, phys_addr_t max_addr);
|
||||
phys_addr_t lmb_alloc_addr(phys_addr_t base, phys_size_t size);
|
||||
phys_size_t lmb_get_free_size(phys_addr_t addr);
|
||||
|
||||
/**
|
||||
* lmb_alloc_flags() - Allocate memory region with specified attributes
|
||||
* @size: Size of the region requested
|
||||
* @align: Alignment of the memory region requested
|
||||
* @flags: Memory region attributes to be set
|
||||
*
|
||||
* Allocate a region of memory with the attributes specified through the
|
||||
* parameter.
|
||||
*
|
||||
* Return: base address on success, 0 on error
|
||||
*/
|
||||
phys_addr_t lmb_alloc_flags(phys_size_t size, ulong align, uint flags);
|
||||
|
||||
/**
|
||||
* lmb_alloc_base_flags() - Allocate specified memory region with specified attributes
|
||||
* @size: Size of the region requested
|
||||
* @align: Alignment of the memory region requested
|
||||
* @max_addr: Maximum address of the requested region
|
||||
* @flags: Memory region attributes to be set
|
||||
*
|
||||
* Allocate a region of memory with the attributes specified through the
|
||||
* parameter. The max_addr parameter is used to specify the maximum address
|
||||
* below which the requested region should be allocated.
|
||||
*
|
||||
* Return: base address on success, 0 on error
|
||||
*/
|
||||
phys_addr_t lmb_alloc_base_flags(phys_size_t size, ulong align,
|
||||
phys_addr_t max_addr, uint flags);
|
||||
|
||||
/**
|
||||
* lmb_alloc_addr_flags() - Allocate specified memory address with specified attributes
|
||||
* @base: Base Address requested
|
||||
* @size: Size of the region requested
|
||||
* @flags: Memory region attributes to be set
|
||||
*
|
||||
* Allocate a region of memory with the attributes specified through the
|
||||
* parameter. The base parameter is used to specify the base address
|
||||
* of the requested region.
|
||||
*
|
||||
* Return: base address on success, 0 on error
|
||||
*/
|
||||
phys_addr_t lmb_alloc_addr_flags(phys_addr_t base, phys_size_t size,
|
||||
uint flags);
|
||||
|
||||
/**
|
||||
* lmb_is_reserved_flags() - test if address is in reserved region with flag bits set
|
||||
*
|
||||
@@ -102,6 +146,18 @@ phys_size_t lmb_get_free_size(phys_addr_t addr);
|
||||
*/
|
||||
int lmb_is_reserved_flags(phys_addr_t addr, int flags);
|
||||
|
||||
/**
|
||||
* lmb_free_flags() - Free up a region of memory
|
||||
* @base: Base Address of region to be freed
|
||||
* @size: Size of the region to be freed
|
||||
* @flags: Memory region attributes
|
||||
*
|
||||
* Free up a region of memory.
|
||||
*
|
||||
* Return: 0 if successful, -1 on failure
|
||||
*/
|
||||
long lmb_free_flags(phys_addr_t base, phys_size_t size, uint flags);
|
||||
|
||||
long lmb_free(phys_addr_t base, phys_size_t size);
|
||||
|
||||
void lmb_dump_all(void);
|
||||
|
Reference in New Issue
Block a user