error = goodix_irq_direction_output(ts, 0);
        if (error)
-               return error;
+               goto error;
 
        msleep(50);                             /* T5: 50ms */
 
        error = goodix_irq_direction_input(ts);
        if (error)
-               return error;
+               goto error;
 
        return 0;
+
+error:
+       dev_err(&ts->client->dev, "Controller irq sync failed.\n");
+       return error;
 }
 
 /**
- * goodix_reset - Reset device during power on
+ * goodix_reset_no_int_sync - Reset device, leaving interrupt line in output mode
  *
  * @ts: goodix_ts_data pointer
  */
-static int goodix_reset(struct goodix_ts_data *ts)
+int goodix_reset_no_int_sync(struct goodix_ts_data *ts)
 {
        int error;
 
        /* begin select I2C slave addr */
        error = gpiod_direction_output(ts->gpiod_rst, 0);
        if (error)
-               return error;
+               goto error;
 
        msleep(20);                             /* T2: > 10ms */
 
        /* HIGH: 0x28/0x29, LOW: 0xBA/0xBB */
        error = goodix_irq_direction_output(ts, ts->client->addr == 0x14);
        if (error)
-               return error;
+               goto error;
 
        usleep_range(100, 2000);                /* T3: > 100us */
 
        error = gpiod_direction_output(ts->gpiod_rst, 1);
        if (error)
-               return error;
+               goto error;
 
        usleep_range(6000, 10000);              /* T4: > 5ms */
 
        /* end select I2C slave addr */
        error = gpiod_direction_input(ts->gpiod_rst);
        if (error)
-               return error;
+               goto error;
 
-       error = goodix_int_sync(ts);
+       return 0;
+
+error:
+       dev_err(&ts->client->dev, "Controller reset failed.\n");
+       return error;
+}
+
+/**
+ * goodix_reset - Reset device during power on
+ *
+ * @ts: goodix_ts_data pointer
+ */
+static int goodix_reset(struct goodix_ts_data *ts)
+{
+       int error;
+
+       error = goodix_reset_no_int_sync(ts);
        if (error)
                return error;
 
-       return 0;
+       return goodix_int_sync(ts);
 }
 
 #ifdef ACPI_GPIO_SUPPORT
        if (ts->reset_controller_at_probe) {
                /* reset the controller */
                error = goodix_reset(ts);
-               if (error) {
-                       dev_err(&client->dev, "Controller reset failed.\n");
+               if (error)
                        return error;
-               }
        }
 
        error = goodix_i2c_test(client);
 
        if (error != 0 || config_ver != ts->config[0]) {
                error = goodix_reset(ts);
-               if (error) {
-                       dev_err(dev, "Controller reset failed.\n");
+               if (error)
                        return error;
-               }
 
                error = goodix_send_cfg(ts, ts->config, ts->chip->config_len);
                if (error)