/* * tle8888.h * * Created on: Mar 25, 2019 * Author: garage */ #ifndef HW_LAYER_DRIVERS_GPIO_TLE8888_H_ #define HW_LAYER_DRIVERS_GPIO_TLE8888_H_ #include "global.h" #include #define TLE8888_OUTPUTS 20 /* ? */ /* 4 misc channels */ #define TLE8888_DIRECT_MISC 4 /* 4 IGN channels - INJ1..4 - IN1..4 * 4 INJ channels - OUT1..4 - IN5..8 */ #define TLE8888_DIRECT_OUTPUTS (4 + 4 + TLE8888_DIRECT_MISC) /* DOTO: add irq support */ #define TLE8888_POLL_INTERVAL_MS 100 /* note that spi transfer should be LSB first */ struct tle8888_config { SPIDriver *spi_bus; const SPIConfig spi_config; /* bidirectional, check DS */ struct { ioportid_t port; uint_fast8_t pad; } reset; /* currently not used. * TODO: update as it is done in TLE6240 */ struct { ioportid_t port; uint_fast8_t pad; } direct_io[TLE8888_DIRECT_MISC]; /* maping array for IN9..12, output numbers starts from 1, as in DS */ uint8_t direct_map[TLE8888_DIRECT_MISC]; }; #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /* cleanup !!!! */ void initTle8888(DECLARE_ENGINE_PARAMETER_SIGNATURE); int tle8888_add(unsigned int index, const struct tle8888_config *cfg); #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* HW_LAYER_DRIVERS_GPIO_TLE8888_H_ */