64 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _MEMREGION_H_
 | |
| #define _MEMREGION_H_
 | |
| #include <linux/types.h>
 | |
| #include <linux/errno.h>
 | |
| #include <linux/range.h>
 | |
| #include <linux/bug.h>
 | |
| 
 | |
| struct memregion_info {
 | |
| 	int target_node;
 | |
| 	struct range range;
 | |
| };
 | |
| 
 | |
| #ifdef CONFIG_MEMREGION
 | |
| int memregion_alloc(gfp_t gfp);
 | |
| void memregion_free(int id);
 | |
| #else
 | |
| static inline int memregion_alloc(gfp_t gfp)
 | |
| {
 | |
| 	return -ENOMEM;
 | |
| }
 | |
| static inline void memregion_free(int id)
 | |
| {
 | |
| }
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * cpu_cache_invalidate_memregion - drop any CPU cached data for
 | |
|  *     memregions described by @res_desc
 | |
|  * @res_desc: one of the IORES_DESC_* types
 | |
|  *
 | |
|  * Perform cache maintenance after a memory event / operation that
 | |
|  * changes the contents of physical memory in a cache-incoherent manner.
 | |
|  * For example, device memory technologies like NVDIMM and CXL have
 | |
|  * device secure erase, and dynamic region provision that can replace
 | |
|  * the memory mapped to a given physical address.
 | |
|  *
 | |
|  * Limit the functionality to architectures that have an efficient way
 | |
|  * to writeback and invalidate potentially terabytes of address space at
 | |
|  * once.  Note that this routine may or may not write back any dirty
 | |
|  * contents while performing the invalidation. It is only exported for
 | |
|  * the explicit usage of the NVDIMM and CXL modules in the 'DEVMEM'
 | |
|  * symbol namespace on bare platforms.
 | |
|  *
 | |
|  * Returns 0 on success or negative error code on a failure to perform
 | |
|  * the cache maintenance.
 | |
|  */
 | |
| #ifdef CONFIG_ARCH_HAS_CPU_CACHE_INVALIDATE_MEMREGION
 | |
| int cpu_cache_invalidate_memregion(int res_desc);
 | |
| bool cpu_cache_has_invalidate_memregion(void);
 | |
| #else
 | |
| static inline bool cpu_cache_has_invalidate_memregion(void)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| static inline int cpu_cache_invalidate_memregion(int res_desc)
 | |
| {
 | |
| 	WARN_ON_ONCE("CPU cache invalidation required");
 | |
| 	return -ENXIO;
 | |
| }
 | |
| #endif
 | |
| #endif /* _MEMREGION_H_ */
 |