mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	Add cache enable/disable ops to the DM cache uclass driver Signed-off-by: Rick Chen <rick@andestech.com> Cc: KC Lin <kclin@andestech.com> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
		
			
				
	
	
		
			70 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// SPDX-License-Identifier: GPL-2.0
 | 
						|
/*
 | 
						|
 * Copyright (C) 2019 Intel Corporation <www.intel.com>
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef __CACHE_H
 | 
						|
#define __CACHE_H
 | 
						|
 | 
						|
/*
 | 
						|
 * Structure for the cache controller
 | 
						|
 */
 | 
						|
struct cache_info {
 | 
						|
	phys_addr_t base; /* Base physical address of cache device. */
 | 
						|
};
 | 
						|
 | 
						|
struct cache_ops {
 | 
						|
	/**
 | 
						|
	 * get_info() - Get basic cache info
 | 
						|
	 *
 | 
						|
	 * @dev:	Device to check (UCLASS_CACHE)
 | 
						|
	 * @info:	Place to put info
 | 
						|
	 * @return 0 if OK, -ve on error
 | 
						|
	 */
 | 
						|
	int (*get_info)(struct udevice *dev, struct cache_info *info);
 | 
						|
 | 
						|
	/**
 | 
						|
	 * enable() - Enable cache
 | 
						|
	 *
 | 
						|
	 * @dev:	Device to check (UCLASS_CACHE)
 | 
						|
	 * @return 0 if OK, -ve on error
 | 
						|
	 */
 | 
						|
	int (*enable)(struct udevice *dev);
 | 
						|
 | 
						|
	/**
 | 
						|
	 * disable() - Flush and disable cache
 | 
						|
	 *
 | 
						|
	 * @dev:	Device to check (UCLASS_CACHE)
 | 
						|
	 * @return 0 if OK, -ve on error
 | 
						|
	 */
 | 
						|
	int (*disable)(struct udevice *dev);
 | 
						|
};
 | 
						|
 | 
						|
#define cache_get_ops(dev)	((struct cache_ops *)(dev)->driver->ops)
 | 
						|
 | 
						|
/**
 | 
						|
 * cache_get_info() - Get information about a cache controller
 | 
						|
 *
 | 
						|
 * @dev:	Device to check (UCLASS_CACHE)
 | 
						|
 * @info:	Returns cache info
 | 
						|
 * @return 0 if OK, -ve on error
 | 
						|
 */
 | 
						|
int cache_get_info(struct udevice *dev, struct cache_info *info);
 | 
						|
 | 
						|
/**
 | 
						|
 * cache_enable() - Enable cache
 | 
						|
 *
 | 
						|
 * @dev:	Device to check (UCLASS_CACHE)
 | 
						|
 * @return 0 if OK, -ve on error
 | 
						|
 */
 | 
						|
int cache_enable(struct udevice *dev);
 | 
						|
 | 
						|
/**
 | 
						|
 * cache_disable() - Flush and disable cache
 | 
						|
 *
 | 
						|
 * @dev:	Device to check (UCLASS_CACHE)
 | 
						|
 * @return 0 if OK, -ve on error
 | 
						|
 */
 | 
						|
int cache_disable(struct udevice *dev);
 | 
						|
#endif
 |