forked from mirrors/linux
		
	 67d6c76fc8
			
		
	
	
		67d6c76fc8
		
	
	
	
	
		
			
			We used to assume 0x2010xxxx address. Now that we need to access 0x2011xxxx address, we need to support read/write the whole 32-bit address space. Also defined RSMU_MAX_WRITE_COUNT and RSMU_MAX_READ_COUNT for readability Signed-off-by: Min Li <min.li.xe@renesas.com> Signed-off-by: Lee Jones <lee@kernel.org> Link: https://lore.kernel.org/r/MW5PR03MB693295AF31ABCAF6AE52EE74A08B9@MW5PR03MB6932.namprd03.prod.outlook.com
		
			
				
	
	
		
			39 lines
		
	
	
	
		
			967 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
	
		
			967 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * Core interface for Renesas Synchronization Management Unit (SMU) devices.
 | |
|  *
 | |
|  * Copyright (C) 2021 Integrated Device Technology, Inc., a Renesas Company.
 | |
|  */
 | |
| 
 | |
| #ifndef __LINUX_MFD_RSMU_H
 | |
| #define __LINUX_MFD_RSMU_H
 | |
| 
 | |
| #define RSMU_MAX_WRITE_COUNT	(255)
 | |
| #define RSMU_MAX_READ_COUNT	(255)
 | |
| 
 | |
| /* The supported devices are ClockMatrix, Sabre and SnowLotus */
 | |
| enum rsmu_type {
 | |
| 	RSMU_CM		= 0x34000,
 | |
| 	RSMU_SABRE	= 0x33810,
 | |
| 	RSMU_SL		= 0x19850,
 | |
| };
 | |
| 
 | |
| /**
 | |
|  *
 | |
|  * struct rsmu_ddata - device data structure for sub devices.
 | |
|  *
 | |
|  * @dev:    i2c/spi device.
 | |
|  * @regmap: i2c/spi bus access.
 | |
|  * @lock:   mutex used by sub devices to make sure a series of
 | |
|  *          bus access requests are not interrupted.
 | |
|  * @type:   RSMU device type.
 | |
|  * @page:   i2c/spi bus driver internal use only.
 | |
|  */
 | |
| struct rsmu_ddata {
 | |
| 	struct device *dev;
 | |
| 	struct regmap *regmap;
 | |
| 	struct mutex lock;
 | |
| 	enum rsmu_type type;
 | |
| 	u32 page;
 | |
| };
 | |
| #endif /*  __LINUX_MFD_RSMU_H */
 |