rusefi-full/firmware/hw_layer/smart_gpio.h

36 lines
1001 B
C
Raw Normal View History

2019-04-13 07:58:52 -07:00
/*
* @file smart_gpio.h
*
* @date Apr 13, 2019
2020-01-07 21:02:40 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
2019-04-13 07:58:52 -07:00
*/
2020-04-01 16:00:56 -07:00
#pragma once
2019-04-13 07:58:52 -07:00
2020-04-06 10:05:30 -07:00
#if EFI_PROD_CODE
#include "drivers/gpio/mc33810.h"
#include "drivers/gpio/tle6240.h"
#include "drivers/gpio/mc33972.h"
#include "drivers/gpio/tle8888.h"
2020-04-06 11:28:08 -07:00
#define BOARD_EXT_PINREPOPINS (BOARD_TLE6240_COUNT * TLE6240_OUTPUTS + BOARD_MC33972_COUNT * MC33972_INPUTS + BOARD_TLE8888_COUNT * TLE8888_OUTPUTS)
2020-04-06 10:05:30 -07:00
#else /* EFI_PROD_CODE */
2020-04-06 11:28:08 -07:00
#define BOARD_EXT_PINREPOPINS 0
2020-04-06 10:05:30 -07:00
#endif /* EFI_PROD_CODE */
2020-04-06 11:13:29 -07:00
#if EFI_UNIT_TEST
#define BOARD_EXT_GPIOCHIPS 3
#else
#define BOARD_EXT_GPIOCHIPS (BOARD_TLE6240_COUNT + BOARD_MC33972_COUNT + BOARD_TLE8888_COUNT)
#endif
2019-04-13 07:58:52 -07:00
/* TLE6240 pins go right after on chips */
#define TLE6240_PIN(n) ((brain_pin_e)((int)BRAIN_PIN_LAST_ONCHIP + 1 + (n)))
/* MC33972 pins go right after TLE6240 */
#define MC33972_PIN(n) ((brain_pin_e)((int)BRAIN_PIN_LAST_ONCHIP + 1 + 16 + (n)))
void initSmartGpio(void);
2020-04-06 11:13:29 -07:00
void startSmartCsPins(void);
void stopSmartCsPins(void);
2019-04-13 07:58:52 -07:00