diff options
Diffstat (limited to 'drivers/gpio/gpio-xilinx.c')
| -rw-r--r-- | drivers/gpio/gpio-xilinx.c | 51 | 
1 files changed, 25 insertions, 26 deletions
| diff --git a/drivers/gpio/gpio-xilinx.c b/drivers/gpio/gpio-xilinx.c index afcf432a1573..c6a8f2c82680 100644 --- a/drivers/gpio/gpio-xilinx.c +++ b/drivers/gpio/gpio-xilinx.c @@ -15,9 +15,9 @@  #include <linux/io.h>  #include <linux/irq.h>  #include <linux/module.h> -#include <linux/of.h>  #include <linux/platform_device.h>  #include <linux/pm_runtime.h> +#include <linux/property.h>  #include <linux/slab.h>  /* Register Offset Definitions */ @@ -561,9 +561,9 @@ static const struct irq_chip xgpio_irq_chip = {   */  static int xgpio_probe(struct platform_device *pdev)  { +	struct device *dev = &pdev->dev;  	struct xgpio_instance *chip;  	int status = 0; -	struct device_node *np = pdev->dev.of_node;  	u32 is_dual = 0;  	u32 width[2];  	u32 state[2]; @@ -571,14 +571,14 @@ static int xgpio_probe(struct platform_device *pdev)  	struct gpio_irq_chip *girq;  	u32 temp; -	chip = devm_kzalloc(&pdev->dev, sizeof(*chip), GFP_KERNEL); +	chip = devm_kzalloc(dev, sizeof(*chip), GFP_KERNEL);  	if (!chip)  		return -ENOMEM;  	platform_set_drvdata(pdev, chip);  	/* First, check if the device is dual-channel */ -	of_property_read_u32(np, "xlnx,is-dual", &is_dual); +	device_property_read_u32(dev, "xlnx,is-dual", &is_dual);  	/* Setup defaults */  	memset32(width, 0, ARRAY_SIZE(width)); @@ -586,14 +586,14 @@ static int xgpio_probe(struct platform_device *pdev)  	memset32(dir, 0xFFFFFFFF, ARRAY_SIZE(dir));  	/* Update GPIO state shadow register with default value */ -	of_property_read_u32(np, "xlnx,dout-default", &state[0]); -	of_property_read_u32(np, "xlnx,dout-default-2", &state[1]); +	device_property_read_u32(dev, "xlnx,dout-default", &state[0]); +	device_property_read_u32(dev, "xlnx,dout-default-2", &state[1]);  	bitmap_from_arr32(chip->state, state, 64);  	/* Update GPIO direction shadow register with default value */ -	of_property_read_u32(np, "xlnx,tri-default", &dir[0]); -	of_property_read_u32(np, "xlnx,tri-default-2", &dir[1]); +	device_property_read_u32(dev, "xlnx,tri-default", &dir[0]); +	device_property_read_u32(dev, "xlnx,tri-default-2", &dir[1]);  	bitmap_from_arr32(chip->dir, dir, 64); @@ -601,13 +601,13 @@ static int xgpio_probe(struct platform_device *pdev)  	 * Check device node and parent device node for device width  	 * and assume default width of 32  	 */ -	if (of_property_read_u32(np, "xlnx,gpio-width", &width[0])) +	if (device_property_read_u32(dev, "xlnx,gpio-width", &width[0]))  		width[0] = 32;  	if (width[0] > 32)  		return -EINVAL; -	if (is_dual && of_property_read_u32(np, "xlnx,gpio2-width", &width[1])) +	if (is_dual && device_property_read_u32(dev, "xlnx,gpio2-width", &width[1]))  		width[1] = 32;  	if (width[1] > 32) @@ -624,7 +624,7 @@ static int xgpio_probe(struct platform_device *pdev)  	chip->gc.base = -1;  	chip->gc.ngpio = bitmap_weight(chip->hw_map, 64); -	chip->gc.parent = &pdev->dev; +	chip->gc.parent = dev;  	chip->gc.direction_input = xgpio_dir_in;  	chip->gc.direction_output = xgpio_dir_out;  	chip->gc.get = xgpio_get; @@ -633,21 +633,21 @@ static int xgpio_probe(struct platform_device *pdev)  	chip->gc.free = xgpio_free;  	chip->gc.set_multiple = xgpio_set_multiple; -	chip->gc.label = dev_name(&pdev->dev); +	chip->gc.label = dev_name(dev);  	chip->regs = devm_platform_ioremap_resource(pdev, 0);  	if (IS_ERR(chip->regs)) { -		dev_err(&pdev->dev, "failed to ioremap memory resource\n"); +		dev_err(dev, "failed to ioremap memory resource\n");  		return PTR_ERR(chip->regs);  	} -	chip->clk = devm_clk_get_optional_enabled(&pdev->dev, NULL); +	chip->clk = devm_clk_get_optional_enabled(dev, NULL);  	if (IS_ERR(chip->clk)) -		return dev_err_probe(&pdev->dev, PTR_ERR(chip->clk), "input clock not found.\n"); +		return dev_err_probe(dev, PTR_ERR(chip->clk), "input clock not found.\n"); -	pm_runtime_get_noresume(&pdev->dev); -	pm_runtime_set_active(&pdev->dev); -	pm_runtime_enable(&pdev->dev); +	pm_runtime_get_noresume(dev); +	pm_runtime_set_active(dev); +	pm_runtime_enable(dev);  	xgpio_save_regs(chip); @@ -667,8 +667,7 @@ static int xgpio_probe(struct platform_device *pdev)  	gpio_irq_chip_set_chip(girq, &xgpio_irq_chip);  	girq->parent_handler = xgpio_irqhandler;  	girq->num_parents = 1; -	girq->parents = devm_kcalloc(&pdev->dev, 1, -				     sizeof(*girq->parents), +	girq->parents = devm_kcalloc(dev, 1, sizeof(*girq->parents),  				     GFP_KERNEL);  	if (!girq->parents) {  		status = -ENOMEM; @@ -679,18 +678,18 @@ static int xgpio_probe(struct platform_device *pdev)  	girq->handler = handle_bad_irq;  skip_irq: -	status = devm_gpiochip_add_data(&pdev->dev, &chip->gc, chip); +	status = devm_gpiochip_add_data(dev, &chip->gc, chip);  	if (status) { -		dev_err(&pdev->dev, "failed to add GPIO chip\n"); +		dev_err(dev, "failed to add GPIO chip\n");  		goto err_pm_put;  	} -	pm_runtime_put(&pdev->dev); +	pm_runtime_put(dev);  	return 0;  err_pm_put: -	pm_runtime_disable(&pdev->dev); -	pm_runtime_put_noidle(&pdev->dev); +	pm_runtime_disable(dev); +	pm_runtime_put_noidle(dev);  	return status;  } @@ -703,7 +702,7 @@ MODULE_DEVICE_TABLE(of, xgpio_of_match);  static struct platform_driver xgpio_plat_driver = {  	.probe		= xgpio_probe, -	.remove_new	= xgpio_remove, +	.remove		= xgpio_remove,  	.driver		= {  			.name = "gpio-xilinx",  			.of_match_table	= xgpio_of_match, | 
