]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/commitdiff
[media] media: adv7604: improve usage of gpiod API
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Mon, 2 Mar 2015 07:00:44 +0000 (04:00 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Tue, 3 Mar 2015 14:26:40 +0000 (11:26 -0300)
Since 39b2bbe3d715 (gpio: add flags argument to gpiod_get*() functions)
which appeared in v3.17-rc1, the gpiod_get* functions take an additional
parameter that allows to specify direction and initial value for output.
Simplify accordingly.

Moreover use devm_gpiod_get_index_optional instead of
devm_gpiod_get_index with ignoring all errors.

Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/i2c/adv7604.c

index b7a4e32683e43451c031a9d6b4b1e512bad8fe6c..aaab9c9cebee6b57d0ac8ef0b9e8e4bd683ee541 100644 (file)
@@ -538,12 +538,8 @@ static void adv76xx_set_hpd(struct adv76xx_state *state, unsigned int hpd)
 {
        unsigned int i;
 
-       for (i = 0; i < state->info->num_dv_ports; ++i) {
-               if (IS_ERR(state->hpd_gpio[i]))
-                       continue;
-
+       for (i = 0; i < state->info->num_dv_ports; ++i)
                gpiod_set_value_cansleep(state->hpd_gpio[i], hpd & BIT(i));
-       }
 
        v4l2_subdev_notify(&state->sd, ADV76XX_HOTPLUG, &hpd);
 }
@@ -2729,13 +2725,13 @@ static int adv76xx_probe(struct i2c_client *client,
        /* Request GPIOs. */
        for (i = 0; i < state->info->num_dv_ports; ++i) {
                state->hpd_gpio[i] =
-                       devm_gpiod_get_index(&client->dev, "hpd", i);
+                       devm_gpiod_get_index_optional(&client->dev, "hpd", i,
+                                                     GPIOD_OUT_LOW);
                if (IS_ERR(state->hpd_gpio[i]))
-                       continue;
-
-               gpiod_direction_output(state->hpd_gpio[i], 0);
+                       return PTR_ERR(state->hpd_gpio[i]);
 
-               v4l_info(client, "Handling HPD %u GPIO\n", i);
+               if (state->hpd_gpio[i])
+                       v4l_info(client, "Handling HPD %u GPIO\n", i);
        }
 
        state->timings = cea640x480;