IRQ_PIN_ACCESS_NONE,
        IRQ_PIN_ACCESS_GPIO,
        IRQ_PIN_ACCESS_ACPI_GPIO,
+       IRQ_PIN_ACCESS_ACPI_METHOD,
 };
 
 struct goodix_chip_data {
 static int goodix_irq_direction_output(struct goodix_ts_data *ts,
                                       int value)
 {
+       struct device *dev = &ts->client->dev;
+       acpi_status status;
+
        switch (ts->irq_pin_access_method) {
        case IRQ_PIN_ACCESS_NONE:
                dev_err(&ts->client->dev,
                 * as active-low, use output_raw to avoid the value inversion.
                 */
                return gpiod_direction_output_raw(ts->gpiod_int, value);
+       case IRQ_PIN_ACCESS_ACPI_METHOD:
+               status = acpi_execute_simple_method(ACPI_HANDLE(dev),
+                                                   "INTO", value);
+               return ACPI_SUCCESS(status) ? 0 : -EIO;
        }
 
        return -EINVAL; /* Never reached */
 
 static int goodix_irq_direction_input(struct goodix_ts_data *ts)
 {
+       struct device *dev = &ts->client->dev;
+       acpi_status status;
+
        switch (ts->irq_pin_access_method) {
        case IRQ_PIN_ACCESS_NONE:
                dev_err(&ts->client->dev,
        case IRQ_PIN_ACCESS_GPIO:
        case IRQ_PIN_ACCESS_ACPI_GPIO:
                return gpiod_direction_input(ts->gpiod_int);
+       case IRQ_PIN_ACCESS_ACPI_METHOD:
+               status = acpi_evaluate_object(ACPI_HANDLE(dev), "INTI",
+                                             NULL, NULL);
+               return ACPI_SUCCESS(status) ? 0 : -EIO;
        }
 
        return -EINVAL; /* Never reached */
        { },
 };
 
+static const struct acpi_gpio_mapping acpi_goodix_reset_only_gpios[] = {
+       { GOODIX_GPIO_RST_NAME "-gpios", &first_gpio, 1 },
+       { },
+};
+
 static int goodix_resource(struct acpi_resource *ares, void *data)
 {
        struct goodix_ts_data *ts = data;
        } else if (ts->gpio_count == 2 && ts->gpio_int_idx == 1) {
                ts->irq_pin_access_method = IRQ_PIN_ACCESS_ACPI_GPIO;
                gpio_mapping = acpi_goodix_int_last_gpios;
+       } else if (ts->gpio_count == 1 && ts->gpio_int_idx == -1 &&
+                  acpi_has_method(ACPI_HANDLE(dev), "INTI") &&
+                  acpi_has_method(ACPI_HANDLE(dev), "INTO")) {
+               dev_info(dev, "Using ACPI INTI and INTO methods for IRQ pin access\n");
+               ts->irq_pin_access_method = IRQ_PIN_ACCESS_ACPI_METHOD;
+               gpio_mapping = acpi_goodix_reset_only_gpios;
        } else if (is_byt() && ts->gpio_count == 2 && ts->gpio_int_idx == -1) {
                dev_info(dev, "No ACPI GpioInt resource, assuming that the GPIO order is reset, int\n");
                ts->irq_pin_access_method = IRQ_PIN_ACCESS_ACPI_GPIO;
                if (!ts->gpiod_int || !ts->gpiod_rst)
                        ts->irq_pin_access_method = IRQ_PIN_ACCESS_NONE;
                break;
+       case IRQ_PIN_ACCESS_ACPI_METHOD:
+               if (!ts->gpiod_rst)
+                       ts->irq_pin_access_method = IRQ_PIN_ACCESS_NONE;
+               break;
        default:
                if (ts->gpiod_int && ts->gpiod_rst) {
                        ts->reset_controller_at_probe = true;