Commit 567716c5 authored by Sakari Ailus's avatar Sakari Ailus Committed by Mauro Carvalho Chehab

[media] smiapp: Switch to gpiod API for GPIO control

Switch from the old gpio API to the new descriptor based gpiod API.
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Reviewed-by: default avatarSebastian Reichel <sre@kernel.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent 73743001
...@@ -24,8 +24,8 @@ ...@@ -24,8 +24,8 @@
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/device.h> #include <linux/device.h>
#include <linux/gpio.h> #include <linux/gpio.h>
#include <linux/gpio/consumer.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of_gpio.h>
#include <linux/regulator/consumer.h> #include <linux/regulator/consumer.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/smiapp.h> #include <linux/smiapp.h>
...@@ -1212,8 +1212,7 @@ static int smiapp_power_on(struct smiapp_sensor *sensor) ...@@ -1212,8 +1212,7 @@ static int smiapp_power_on(struct smiapp_sensor *sensor)
} }
usleep_range(1000, 1000); usleep_range(1000, 1000);
if (gpio_is_valid(sensor->hwcfg->xshutdown)) gpiod_set_value(sensor->xshutdown, 1);
gpio_set_value(sensor->hwcfg->xshutdown, 1);
sleep = SMIAPP_RESET_DELAY(sensor->hwcfg->ext_clk); sleep = SMIAPP_RESET_DELAY(sensor->hwcfg->ext_clk);
usleep_range(sleep, sleep); usleep_range(sleep, sleep);
...@@ -1322,8 +1321,7 @@ static int smiapp_power_on(struct smiapp_sensor *sensor) ...@@ -1322,8 +1321,7 @@ static int smiapp_power_on(struct smiapp_sensor *sensor)
return 0; return 0;
out_cci_addr_fail: out_cci_addr_fail:
if (gpio_is_valid(sensor->hwcfg->xshutdown)) gpiod_set_value(sensor->xshutdown, 0);
gpio_set_value(sensor->hwcfg->xshutdown, 0);
if (sensor->hwcfg->set_xclk) if (sensor->hwcfg->set_xclk)
sensor->hwcfg->set_xclk(&sensor->src->sd, 0); sensor->hwcfg->set_xclk(&sensor->src->sd, 0);
else else
...@@ -1348,8 +1346,7 @@ static void smiapp_power_off(struct smiapp_sensor *sensor) ...@@ -1348,8 +1346,7 @@ static void smiapp_power_off(struct smiapp_sensor *sensor)
SMIAPP_REG_U8_SOFTWARE_RESET, SMIAPP_REG_U8_SOFTWARE_RESET,
SMIAPP_SOFTWARE_RESET); SMIAPP_SOFTWARE_RESET);
if (gpio_is_valid(sensor->hwcfg->xshutdown)) gpiod_set_value(sensor->xshutdown, 0);
gpio_set_value(sensor->hwcfg->xshutdown, 0);
if (sensor->hwcfg->set_xclk) if (sensor->hwcfg->set_xclk)
sensor->hwcfg->set_xclk(&sensor->src->sd, 0); sensor->hwcfg->set_xclk(&sensor->src->sd, 0);
else else
...@@ -2572,17 +2569,10 @@ static int smiapp_init(struct smiapp_sensor *sensor) ...@@ -2572,17 +2569,10 @@ static int smiapp_init(struct smiapp_sensor *sensor)
} }
} }
if (gpio_is_valid(sensor->hwcfg->xshutdown)) { sensor->xshutdown = devm_gpiod_get_optional(&client->dev, "xshutdown",
rval = devm_gpio_request_one( GPIOD_OUT_LOW);
&client->dev, sensor->hwcfg->xshutdown, 0, if (IS_ERR(sensor->xshutdown))
"SMIA++ xshutdown"); return PTR_ERR(sensor->xshutdown);
if (rval < 0) {
dev_err(&client->dev,
"unable to acquire reset gpio %d\n",
sensor->hwcfg->xshutdown);
return rval;
}
}
rval = smiapp_power_on(sensor); rval = smiapp_power_on(sensor);
if (rval) if (rval)
...@@ -3020,9 +3010,6 @@ static struct smiapp_hwconfig *smiapp_get_hwconfig(struct device *dev) ...@@ -3020,9 +3010,6 @@ static struct smiapp_hwconfig *smiapp_get_hwconfig(struct device *dev)
hwcfg->lanes = bus_cfg->bus.mipi_csi2.num_data_lanes; hwcfg->lanes = bus_cfg->bus.mipi_csi2.num_data_lanes;
dev_dbg(dev, "lanes %u\n", hwcfg->lanes); dev_dbg(dev, "lanes %u\n", hwcfg->lanes);
/* xshutdown GPIO is optional */
hwcfg->xshutdown = of_get_named_gpio(dev->of_node, "reset-gpios", 0);
/* NVM size is not mandatory */ /* NVM size is not mandatory */
of_property_read_u32(dev->of_node, "nokia,nvm-size", of_property_read_u32(dev->of_node, "nokia,nvm-size",
&hwcfg->nvm_size); &hwcfg->nvm_size);
...@@ -3034,8 +3021,8 @@ static struct smiapp_hwconfig *smiapp_get_hwconfig(struct device *dev) ...@@ -3034,8 +3021,8 @@ static struct smiapp_hwconfig *smiapp_get_hwconfig(struct device *dev)
goto out_err; goto out_err;
} }
dev_dbg(dev, "reset %d, nvm %d, clk %d, csi %d\n", hwcfg->xshutdown, dev_dbg(dev, "nvm %d, clk %d, csi %d\n", hwcfg->nvm_size,
hwcfg->nvm_size, hwcfg->ext_clk, hwcfg->csi_signalling_mode); hwcfg->ext_clk, hwcfg->csi_signalling_mode);
if (!bus_cfg->nr_of_link_frequencies) { if (!bus_cfg->nr_of_link_frequencies) {
dev_warn(dev, "no link frequencies defined\n"); dev_warn(dev, "no link frequencies defined\n");
...@@ -3120,8 +3107,7 @@ static int smiapp_remove(struct i2c_client *client) ...@@ -3120,8 +3107,7 @@ static int smiapp_remove(struct i2c_client *client)
v4l2_async_unregister_subdev(subdev); v4l2_async_unregister_subdev(subdev);
if (sensor->power_count) { if (sensor->power_count) {
if (gpio_is_valid(sensor->hwcfg->xshutdown)) gpiod_set_value(sensor->xshutdown, 0);
gpio_set_value(sensor->hwcfg->xshutdown, 0);
if (sensor->hwcfg->set_xclk) if (sensor->hwcfg->set_xclk)
sensor->hwcfg->set_xclk(&sensor->src->sd, 0); sensor->hwcfg->set_xclk(&sensor->src->sd, 0);
else else
......
...@@ -200,6 +200,7 @@ struct smiapp_sensor { ...@@ -200,6 +200,7 @@ struct smiapp_sensor {
struct smiapp_hwconfig *hwcfg; struct smiapp_hwconfig *hwcfg;
struct regulator *vana; struct regulator *vana;
struct clk *ext_clk; struct clk *ext_clk;
struct gpio_desc *xshutdown;
u32 limits[SMIAPP_LIMIT_LAST]; u32 limits[SMIAPP_LIMIT_LAST];
u8 nbinning_subtypes; u8 nbinning_subtypes;
struct smiapp_binning_subtype binning_subtypes[SMIAPP_BINNING_SUBTYPES]; struct smiapp_binning_subtype binning_subtypes[SMIAPP_BINNING_SUBTYPES];
......
...@@ -36,8 +36,6 @@ ...@@ -36,8 +36,6 @@
#define SMIAPP_CSI_SIGNALLING_MODE_CCP2_DATA_STROBE 1 #define SMIAPP_CSI_SIGNALLING_MODE_CCP2_DATA_STROBE 1
#define SMIAPP_CSI_SIGNALLING_MODE_CSI2 2 #define SMIAPP_CSI_SIGNALLING_MODE_CSI2 2
#define SMIAPP_NO_XSHUTDOWN -1
/* /*
* Sometimes due to board layout considerations the camera module can be * Sometimes due to board layout considerations the camera module can be
* mounted rotated. The typical rotation used is 180 degrees which can be * mounted rotated. The typical rotation used is 180 degrees which can be
...@@ -77,7 +75,6 @@ struct smiapp_hwconfig { ...@@ -77,7 +75,6 @@ struct smiapp_hwconfig {
struct smiapp_flash_strobe_parms *strobe_setup; struct smiapp_flash_strobe_parms *strobe_setup;
int (*set_xclk)(struct v4l2_subdev *sd, int hz); int (*set_xclk)(struct v4l2_subdev *sd, int hz);
int32_t xshutdown; /* gpio or SMIAPP_NO_XSHUTDOWN */
}; };
#endif /* __SMIAPP_H_ */ #endif /* __SMIAPP_H_ */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment