Lines Matching +full:host +full:- +full:int +full:- +full:gpios
2 * Copyright (c) 2018-2019 Intel Corporation
4 * SPDX-License-Identifier: Apache-2.0
14 * both GPIOs and Pinmuxing function. This driver provides
17 * Due to GPIO callback only allowing 32 pins (as a 32-bit mask) at once,
18 * each set is further sub-divided into multiple devices, so
30 #include <zephyr/dt-bindings/interrupt-controller/intel-ioapic.h>
92 ((const struct gpio_intel_config *)(_dev)->config)
93 #define DEV_DATA(_dev) ((struct gpio_intel_data *)(_dev)->data)
130 #define REG_GPI_INT_STS_BASE_GET(data) (data)->intr_stat_reg
132 #define REG_GPI_INT_EN_BASE_GET(data) (data)->intr_stat_reg + 0x20
136 #define GPIO_PAD_OWNERSHIP_GET(data, pin, offset) (data)->pad_owner_reg + (((pin) / 8) * 0x4)
138 #define REG_PAD_HOST_SW_OWNER_GET(data) (data)->host_owner_reg
144 #define GPIO_GET_PIN_MAX(dev) ((struct gpio_intel_data *)(dev)->data)->num_pins
145 #else /* Non-ACPI */
152 #define PIN_OFFSET_GET(dev) ((const struct gpio_intel_config *)(dev)->config)->pin_offset
158 #define GPIO_BASE_GET(cdf) GPIO_BASE(((const struct gpio_intel_config *)(dev)->config))
162 #define GPIO_GET_PIN_MAX(dev) ((const struct gpio_intel_config *)(dev)->config)->num_pins
179 * @brief Check if host has permission to alter this GPIO pin.
184 * @return true if host owns the GPIO pin, false otherwise
188 struct gpio_intel_data *data = dev->data; in check_perm()
192 /* First is to establish that host software owns the pin */ in check_perm()
208 offset = data->pad_base + (raw_pin << 4); in check_perm()
235 cfg = dev->config; in gpio_intel_isr()
236 data = dev->data; in gpio_intel_isr()
242 SYS_SLIST_FOR_EACH_CONTAINER_SAFE(&data->cb, cb, tmp, node) { in gpio_intel_isr()
243 cur_mask = int_sts & cb->pin_mask; in gpio_intel_isr()
246 __ASSERT(cb->handler, "No callback handler!"); in gpio_intel_isr()
247 cb->handler(dev, cb, cur_mask); in gpio_intel_isr()
255 static int gpio_intel_config(const struct device *dev, in gpio_intel_config()
258 struct gpio_intel_data *data = dev->data; in gpio_intel_config()
261 /* Only support push-pull mode */ in gpio_intel_config()
263 return -ENOTSUP; in gpio_intel_config()
271 return -EINVAL; in gpio_intel_config()
275 reg = regs(dev) + data->pad_base + (raw_pin * PIN_OFFSET); in gpio_intel_config()
308 /* pull-up or pull-down */ in gpio_intel_config()
328 static int gpio_intel_pin_interrupt_configure(const struct device *dev, in gpio_intel_pin_interrupt_configure()
333 struct gpio_intel_data *data = dev->data; in gpio_intel_pin_interrupt_configure()
337 /* no double-edge triggering according to data sheet */ in gpio_intel_pin_interrupt_configure()
339 return -ENOTSUP; in gpio_intel_pin_interrupt_configure()
347 return -EINVAL; in gpio_intel_pin_interrupt_configure()
356 reg = regs(dev) + data->pad_base + (raw_pin * PIN_OFFSET); in gpio_intel_pin_interrupt_configure()
379 return -ENOTSUP; in gpio_intel_pin_interrupt_configure()
390 return -ENOTSUP; in gpio_intel_pin_interrupt_configure()
421 static int gpio_intel_manage_callback(const struct device *dev, in gpio_intel_manage_callback()
425 struct gpio_intel_data *data = dev->data; in gpio_intel_manage_callback()
427 return gpio_manage_callback(&data->cb, callback, set); in gpio_intel_manage_callback()
430 static int port_get_raw(const struct device *dev, uint32_t mask, in port_get_raw()
434 struct gpio_intel_data *data = dev->data; in port_get_raw()
445 pin = find_lsb_set(mask) - 1; in port_get_raw()
459 reg_addr = regs(dev) + data->pad_base + (raw_pin * PIN_OFFSET); in port_get_raw()
470 static int port_set_raw(const struct device *dev, uint32_t mask, in port_set_raw()
473 struct gpio_intel_data *data = dev->data; in port_set_raw()
477 pin = find_lsb_set(mask) - 1; in port_set_raw()
491 reg_addr = regs(dev) + data->pad_base + (raw_pin * PIN_OFFSET); in port_set_raw()
506 static int gpio_intel_port_set_masked_raw(const struct device *dev, in gpio_intel_port_set_masked_raw()
521 static int gpio_intel_port_set_bits_raw(const struct device *dev, in gpio_intel_port_set_bits_raw()
527 static int gpio_intel_port_clear_bits_raw(const struct device *dev, in gpio_intel_port_clear_bits_raw()
533 static int gpio_intel_port_toggle_bits(const struct device *dev, in gpio_intel_port_toggle_bits()
547 static int gpio_intel_port_get_raw(const struct device *dev, in gpio_intel_port_get_raw()
567 static int gpio_intel_acpi_enum(const struct device *dev, int bank_idx, char *hid, char *uid) in gpio_intel_acpi_enum()
569 int ret; in gpio_intel_acpi_enum()
571 struct gpio_intel_data *data = dev->data; in gpio_intel_acpi_enum()
578 device_map(&data->reg_base, res.reg_base, res.len, K_MEM_CACHE_NONE); in gpio_intel_acpi_enum()
580 data->num_pins = res.num_pins; in gpio_intel_acpi_enum()
581 data->pad_owner_reg = res.pad_owner_reg; in gpio_intel_acpi_enum()
582 data->host_owner_reg = res.host_owner_reg; in gpio_intel_acpi_enum()
583 data->intr_stat_reg = res.intr_stat_reg; in gpio_intel_acpi_enum()
584 data->base_num = res.base_num; in gpio_intel_acpi_enum()
585 data->pad_base = res.pad_base; in gpio_intel_acpi_enum()
606 static int gpio_intel_init##n(const struct device *dev) \
623 static int gpio_intel_dts_init(const struct device *dev) in gpio_intel_dts_init()
625 struct gpio_intel_data *data = dev->data; in gpio_intel_dts_init()
632 * into 32-pin blocks so each block has a GPIO driver instance. in gpio_intel_dts_init()
636 * So when mapping the address, the lowest 8-bit needs to be in gpio_intel_dts_init()
641 const struct gpio_intel_config *cfg = dev->config; in gpio_intel_dts_init()
643 device_map(&data->reg_base, in gpio_intel_dts_init()
644 cfg->reg_base.phys_addr & ~0xFFU, in gpio_intel_dts_init()
645 cfg->reg_base.size, in gpio_intel_dts_init()
650 data->pad_base = pad_base(dev); in gpio_intel_dts_init()
675 static int gpio_intel_init##n(const struct device *dev) \