/* * Copyright (c) 2023 Grinn * SPDX-License-Identifier: Apache-2.0 */ #define DT_DRV_COMPAT adi_ad559x #include #include #include #include #include "mfd_ad559x.h" bool mfd_ad559x_has_pointer_byte_map(const struct device *dev) { const struct mfd_ad559x_config *config = dev->config; return config->has_pointer_byte_map; } int mfd_ad559x_read_raw(const struct device *dev, uint8_t *val, size_t len) { struct mfd_ad559x_data *data = dev->data; return data->transfer_function->read_raw(dev, val, len); } int mfd_ad559x_write_raw(const struct device *dev, uint8_t *val, size_t len) { struct mfd_ad559x_data *data = dev->data; return data->transfer_function->write_raw(dev, val, len); } int mfd_ad559x_read_reg(const struct device *dev, uint8_t reg, uint8_t reg_data, uint16_t *val) { struct mfd_ad559x_data *data = dev->data; return data->transfer_function->read_reg(dev, reg, reg_data, val); } int mfd_ad559x_write_reg(const struct device *dev, uint8_t reg, uint16_t val) { struct mfd_ad559x_data *data = dev->data; return data->transfer_function->write_reg(dev, reg, val); } static int mfd_add559x_software_reset(const struct device *dev) { return mfd_ad559x_write_reg(dev, AD559X_REG_SOFTWARE_RESET, AD559X_SOFTWARE_RESET_MAGIC_VAL); } static int mfd_ad559x_init(const struct device *dev) { const struct mfd_ad559x_config *config = dev->config; int ret; ret = config->bus_init(dev); if (ret < 0) { return ret; } if (!gpio_is_ready_dt(&config->reset_gpio)) { return -ENODEV; } ret = gpio_pin_configure_dt(&config->reset_gpio, GPIO_OUTPUT_INACTIVE); if (ret < 0) { return ret; } ret = mfd_add559x_software_reset(dev); if (ret < 0) { return ret; } return 0; } #define MDF_AD559X_DEFINE_I2C_BUS(inst) \ .i2c = I2C_DT_SPEC_INST_GET(inst), .bus_init = mfd_ad559x_i2c_init, \ .has_pointer_byte_map = true #define MDF_AD559X_DEFINE_SPI_BUS_FLAGS \ (SPI_WORD_SET(8) | SPI_TRANSFER_MSB | SPI_OP_MODE_MASTER | SPI_MODE_CPOL) #define MDF_AD559X_DEFINE_SPI_BUS(inst) \ .spi = SPI_DT_SPEC_INST_GET(inst, MDF_AD559X_DEFINE_SPI_BUS_FLAGS, 0), \ .bus_init = mfd_ad559x_spi_init, .has_pointer_byte_map = false #define MFD_AD559X_DEFINE_BUS(inst) \ COND_CODE_1(DT_INST_ON_BUS(inst, i2c), (MDF_AD559X_DEFINE_I2C_BUS(inst)), \ (MDF_AD559X_DEFINE_SPI_BUS(inst))) #define MFD_AD559X_DEFINE(inst) \ static struct mfd_ad559x_data mfd_ad559x_data_##inst; \ static const struct mfd_ad559x_config mfd_ad559x_config_##inst = { \ .reset_gpio = GPIO_DT_SPEC_INST_GET(inst, reset_gpios), \ MFD_AD559X_DEFINE_BUS(inst), \ }; \ \ DEVICE_DT_INST_DEFINE(inst, mfd_ad559x_init, NULL, &mfd_ad559x_data_##inst, \ &mfd_ad559x_config_##inst, POST_KERNEL, CONFIG_MFD_INIT_PRIORITY, \ NULL); DT_INST_FOREACH_STATUS_OKAY(MFD_AD559X_DEFINE);