Lines Matching +full:alert +full:- +full:config

4  * SPDX-License-Identifier: Apache-2.0
9 * doesn't provide any API itself. The feature-specific API should be provided
33 k_work_submit(&data->alert_worker); in rt1718s_alert_callback()
39 const struct device *const dev = data->dev; in rt1718s_alert_worker()
40 const struct rt1718s_config *const config = dev->config; in rt1718s_alert_worker() local
41 uint16_t alert, mask; in rt1718s_alert_worker() local
44 /* Read alert and mask */ in rt1718s_alert_worker()
45 k_sem_take(&data->lock_tcpci, K_FOREVER); in rt1718s_alert_worker()
46 if (rt1718s_reg_burst_read(dev, RT1718S_REG_ALERT, (uint8_t *)&alert, in rt1718s_alert_worker()
47 sizeof(alert)) || in rt1718s_alert_worker()
50 k_sem_give(&data->lock_tcpci); in rt1718s_alert_worker()
55 /* Content of the alert and alert mask registers are in rt1718s_alert_worker()
56 * defined by the TCPCI specification - "A masked in rt1718s_alert_worker()
57 * register will still indicate in the ALERT register, in rt1718s_alert_worker()
58 * but shall not set the Alert# pin low" in rt1718s_alert_worker()
60 alert &= mask; in rt1718s_alert_worker()
61 if (alert) { in rt1718s_alert_worker()
62 /* Clear all alert bits that causes the interrupt */ in rt1718s_alert_worker()
63 if (rt1718s_reg_burst_write(dev, RT1718S_REG_ALERT, (uint8_t *)&alert, in rt1718s_alert_worker()
64 sizeof(alert))) { in rt1718s_alert_worker()
65 k_sem_give(&data->lock_tcpci); in rt1718s_alert_worker()
70 k_sem_give(&data->lock_tcpci); in rt1718s_alert_worker()
73 * defined alert for the RT1718S, but handle in rt1718s_alert_worker()
76 if (alert & RT1718S_REG_ALERT_VENDOR_DEFINED_ALERT) { in rt1718s_alert_worker()
80 } while (gpio_pin_get_dt(&config->irq_gpio)); in rt1718s_alert_worker()
85 const struct rt1718s_config *const config = dev->config; in rt1718s_init() local
86 struct rt1718s_data *data = dev->data; in rt1718s_init()
90 if (!device_is_ready(config->i2c_dev.bus)) { in rt1718s_init()
91 LOG_ERR("%s device not ready", config->i2c_dev.bus->name); in rt1718s_init()
92 return -ENODEV; in rt1718s_init()
95 k_sem_init(&data->lock_tcpci, 1, 1); in rt1718s_init()
98 if (!gpio_is_ready_dt(&config->irq_gpio)) { in rt1718s_init()
99 LOG_ERR("%s device not ready", config->irq_gpio.port->name); in rt1718s_init()
100 return -ENODEV; in rt1718s_init()
103 /* Set the interrupt pin for handling the alert */ in rt1718s_init()
104 k_work_init(&data->alert_worker, rt1718s_alert_worker); in rt1718s_init()
106 gpio_pin_configure_dt(&config->irq_gpio, GPIO_INPUT); in rt1718s_init()
108 gpio_init_callback(&data->gpio_cb, rt1718s_alert_callback, in rt1718s_init()
109 BIT(config->irq_gpio.pin)); in rt1718s_init()
111 ret = gpio_add_callback(config->irq_gpio.port, &data->gpio_cb); in rt1718s_init()
116 gpio_pin_interrupt_configure_dt(&config->irq_gpio, GPIO_INT_EDGE_TO_ACTIVE); in rt1718s_init()