]> git.kernelconcepts.de Git - karo-tx-linux.git/blobdiff - drivers/input/touchscreen/elants_i2c.c
Input: elants_i2c - fix for devm_gpiod_get API change
[karo-tx-linux.git] / drivers / input / touchscreen / elants_i2c.c
index 19122652e71b10833905e0e62dd9aab7d17e44ca..ddac134b25b108841e7e7797003fe9a6725e4576 100644 (file)
@@ -1173,7 +1173,7 @@ static int elants_i2c_probe(struct i2c_client *client,
                return error;
        }
 
-       ts->reset_gpio = devm_gpiod_get(&client->dev, "reset");
+       ts->reset_gpio = devm_gpiod_get(&client->dev, "reset", GPIOD_OUT_LOW);
        if (IS_ERR(ts->reset_gpio)) {
                error = PTR_ERR(ts->reset_gpio);
 
@@ -1188,14 +1188,6 @@ static int elants_i2c_probe(struct i2c_client *client,
                }
 
                ts->keep_power_in_suspend = true;
-       } else {
-               error = gpiod_direction_output(ts->reset_gpio, 0);
-               if (error) {
-                       dev_err(&client->dev,
-                               "failed to configure reset gpio as output: %d\n",
-                               error);
-                       return error;
-               }
        }
 
        error = elants_i2c_power_on(ts);
@@ -1410,6 +1402,7 @@ static struct i2c_driver elants_i2c_driver = {
                .pm = &elants_i2c_pm_ops,
                .acpi_match_table = ACPI_PTR(elants_acpi_id),
                .of_match_table = of_match_ptr(elants_of_match),
+               .probe_type = PROBE_PREFER_ASYNCHRONOUS,
        },
 };
 module_i2c_driver(elants_i2c_driver);