gpio: dwapb_gpio: Enable get_function support
Enabled get_function support for dwapb where the function will return the state of GPIO port. Signed-off-by: Chin Liang See <chin.liang.see@intel.com> Signed-off-by: Ley Foon Tan <ley.foon.tan@intel.com>
This commit is contained in:
		
							parent
							
								
									ecb10a41c9
								
							
						
					
					
						commit
						71f2700b92
					
				|  | @ -78,11 +78,25 @@ static int dwapb_gpio_set_value(struct udevice *dev, unsigned pin, int val) | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static int dwapb_gpio_get_function(struct udevice *dev, unsigned offset) | ||||||
|  | { | ||||||
|  | 	struct gpio_dwapb_platdata *plat = dev_get_platdata(dev); | ||||||
|  | 	u32 gpio; | ||||||
|  | 
 | ||||||
|  | 	gpio = readl(plat->base + GPIO_SWPORT_DDR(plat->bank)); | ||||||
|  | 
 | ||||||
|  | 	if (gpio & BIT(offset)) | ||||||
|  | 		return GPIOF_OUTPUT; | ||||||
|  | 	else | ||||||
|  | 		return GPIOF_INPUT; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static const struct dm_gpio_ops gpio_dwapb_ops = { | static const struct dm_gpio_ops gpio_dwapb_ops = { | ||||||
| 	.direction_input	= dwapb_gpio_direction_input, | 	.direction_input	= dwapb_gpio_direction_input, | ||||||
| 	.direction_output	= dwapb_gpio_direction_output, | 	.direction_output	= dwapb_gpio_direction_output, | ||||||
| 	.get_value		= dwapb_gpio_get_value, | 	.get_value		= dwapb_gpio_get_value, | ||||||
| 	.set_value		= dwapb_gpio_set_value, | 	.set_value		= dwapb_gpio_set_value, | ||||||
|  | 	.get_function		= dwapb_gpio_get_function, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static int gpio_dwapb_probe(struct udevice *dev) | static int gpio_dwapb_probe(struct udevice *dev) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue