123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325 |
- #ifndef __INTERFACE_H
- #define __INTERFACE_H
- #include "includes.h"
- #include "stm32f4xx_rcc.h"
- #include <stm32f4xx.h>
- typedef enum
- {
- kI2C0 = 0,
- kI2C1,
- kI2C2,
- kADC0,
- kADC3,
- kSPI1,
- kUart1,
- kUart3,
- kUart6,
- kCAN1,
- kCAN2,
- kEthernet_dm9101,
- kFSMC,
- kInput,
- kOutput,
- kPMU,
- kDMA1,
- kAM2303,
- kUSB,
- kSDIO,
-
- kInterfaceEnd,
- } interface_type;
- typedef enum
- {
- RCC_APB1Periph,
- RCC_APB2Periph,
- RCC_AHB1Periph,
- RCC_AHB2Periph,
- RCC_AHB3Periph,
- } enum_clock_type;
- typedef struct
- {
- interface_type type;
- enum_clock_type RCC_AXBPeriph;
- uint32_t AF_Clock;
- } Gpio_Clock;
- typedef enum
- {
- kTFTLCD,
- kRunLed,
- kAd7606,
- kPRelayCtr,
- kNRelayCtr,
- kPreRelayCtr,
- kFanCtr,
- kOut1Ctr,
- kOut2Ctr,
- kExtWatchDog,
- kExtRelayLed,
- kExtFaultLed,
- kISOPRelayCtr,
- kISONRelayCtr,
- kSoftI2C3_SDA,
- kSoftI2C3_SCL,
- kSoftI2C4_SDA,
- kSoftI2C4_SCL,
- kOutputEnd,
- } Output_Type;
- typedef enum
- {
- DM9K_INIT,
- NOR_FLASH_STATE,
- NAND_FLASH_STATE,
- kInputEnd,
- kKey,
- } Input_type;
- typedef struct
- {
- GPIO_TypeDef *GPIOx;
- INT16U GPIO_PinSource;
- INT8U GPIO_AF;
- } GPIO_AF_Info;
- typedef struct
- {
- interface_type type;
- Output_Type Out_Type;
- Input_type In_Type;
- GPIO_TypeDef *GPIOx;
- INT32U GPIO_Pin;
- GPIOMode_TypeDef GPIO_Mode;
- GPIO_AF_Info AF_Info;
- GPIOOType_TypeDef GPIO_OType;
- GPIOSpeed_TypeDef GPIO_Speed;
- GPIOPuPd_TypeDef GPIO_PuPd;
- } Interface_struct;
- #define UART3_ENABLE_PORT GPIOB
- #define UART3_ENABLE_PIN GPIO_Pin_2
- #define UART3_TX_ENABLE GPIO_SetBits(UART3_ENABLE_PORT, UART3_ENABLE_PIN)
- #define UART3_RX_ENABLE GPIO_ResetBits(UART3_ENABLE_PORT, UART3_ENABLE_PIN)
- #define SPI1_CS_PORT GPIOF
- #define SPI1_CS_PIN GPIO_Pin_8
- #define SPI1_CS_HIGH GPIO_SetBits(SPI2_CS_PORT, SPI2_CS_PIN)
- #define SPI1_CS_LOW GPIO_ResetBits(SPI2_CS_PORT, SPI2_CS_PIN)
- #define ETH_RESET_PORT GPIOH
- #define ETH_RESET_PIN GPIO_Pin_6
- #define ETH_RESET_ON GPIO_ResetBits(ETH_RESET_PORT, ETH_RESET_PIN)
- #define ETH_RESET_OFF GPIO_SetBits(ETH_RESET_PORT, ETH_RESET_PIN)
- #define DM9K_RESET_PORT GPIOA
- #define DM9K_RESET_PIN GPIO_Pin_15
- #define DM9K_RESET_ON GPIO_ResetBits(DM9K_RESET_PORT, DM9K_RESET_PIN)
- #define DM9K_RESET_OFF GPIO_SetBits(DM9K_RESET_PORT, DM9K_RESET_PIN)
- #define NOR_FLASH_STATE_PORT GPIOD
- #define NOR_FLASH_STATE_PIN GPIO_Pin_6
- #define NOR_FLASH_STATE_ON GPIO_ResetBits(NOR_FLASH_STATE_PORT, NOR_FLASH_STATE_PIN)
- #define NOR_FLASH_STATE_OFF GPIO_SetBits(NOR_FLASH_STATE_PORT, NOR_FLASH_STATE_PIN)
- #define NAND_FLASH_STATE_PORT GPIOG
- #define NAND_FLASH_STATE_PIN GPIO_Pin_6
- #define NAND_FLASH_STATE_ON GPIO_ResetBits(NAND_FLASH_STATE_PORT, NAND_FLASH_STATE_PIN)
- #define NAND_FLASH_STATE_OFF GPIO_SetBits(NAND_FLASH_STATE_PORT, NAND_FLASH_STATE_PIN)
- #define GPIO_PORT_K1 GPIOI
- #define GPIO_PIN_K1 GPIO_Pin_8
- #define GPIO_PORT_K2 GPIOC
- #define GPIO_PIN_K2 GPIO_Pin_13
- #define GPIO_PORT_K3 GPIOI
- #define GPIO_PIN_K3 GPIO_Pin_11
- #define GPIO_PORT_K4 GPIOH
- #define GPIO_PIN_K4 GPIO_Pin_2
- #define GPIO_PORT_K5 GPIOH
- #define GPIO_PIN_K5 GPIO_Pin_3
- #define GPIO_PORT_K6 GPIOF
- #define GPIO_PIN_K6 GPIO_Pin_11
- #define GPIO_PORT_K7 GPIOG
- #define GPIO_PIN_K7 GPIO_Pin_7
- #define GPIO_PORT_K8 GPIOH
- #define GPIO_PIN_K8 GPIO_Pin_15
- #define LED0_RUN_PORT GPIOC
- #define LED0_RUN_PIN GPIO_Pin_2
- #define LED1_RUN_PORT GPIOF
- #define LED1_RUN_PIN GPIO_Pin_7
- #define LED2_RUN_PORT GPIOF
- #define LED2_RUN_PIN GPIO_Pin_8
- #define LED3_RUN_PORT GPIOI
- #define LED3_RUN_PIN GPIO_Pin_10
- #define LCD_PWM_PORT GPIOF
- #define LCD_PWM_PIN GPIO_Pin_6
- #define LCD_BUSY_PORT GPIOD
- #define LCD_BUSY_PIN GPIO_Pin_3
- #define AD7606_OS0_PORT GPIOH
- #define AD7606_OS0_PIN GPIO_Pin_9
- #define AD7606_OS1_PORT GPIOH
- #define AD7606_OS1_PIN GPIO_Pin_10
- #define AD7606_OS2_PORT GPIOH
- #define AD7606_OS2_PIN GPIO_Pin_11
- #define AD7606_CONVST_PORT GPIOH
- #define AD7606_CONVST_PIN GPIO_Pin_12
- #define AD7606_RAGE_PORT GPIOH
- #define AD7606_RAGE_PIN GPIO_Pin_14
- #define AD7606_RESET_PORT GPIOI
- #define AD7606_RESET_PIN GPIO_Pin_4
- #define AD7606_BUSY_PORT GPIOI
- #define AD7606_BUSY_PIN GPIO_Pin_6
- #define AM2303_PORT GPIOB
- #define AM2303_PIN GPIO_Pin_1
- #define LED0_RUN_ON GPIO_SetBits(LED0_RUN_PORT, LED0_RUN_PIN)
- #define LED0_RUN_OFF GPIO_ResetBits(LED0_RUN_PORT, LED0_RUN_PIN)
- #define LED0_RUN_TOGGLE GPIO_ToggleBits(LED0_RUN_PORT, LED0_RUN_PIN)
- #define LED1_RUN_ON GPIO_SetBits(LED1_RUN_PORT, LED1_RUN_PIN)
- #define LED1_RUN_OFF GPIO_ResetBits(LED1_RUN_PORT, LED1_RUN_PIN)
- #define LED1_RUN_TOGGLE GPIO_ToggleBits(LED1_RUN_PORT, LED1_RUN_PIN)
- #define LED2_RUN_ON GPIO_SetBits(LED2_RUN_PORT, LED2_RUN_PIN)
- #define LED2_RUN_OFF GPIO_ResetBits(LED2_RUN_PORT, LED2_RUN_PIN)
- #define LED2_RUN_TOGGLE GPIO_ToggleBits(LED2_RUN_PORT, LED2_RUN_PIN)
- #define LCD_PWM_HIGH GPIO_SetBits(LCD_PWM_PORT, LCD_PWM_PIN)
- #define LCD_PWM_LOW GPIO_ResetBits(LCD_PWM_PORT, LCD_PWM_PIN)
- #define AM2303_DO_HIGH GPIO_SetBits(AM2303_PORT, AM2303_PIN)
- #define AM2303_DO_LOW GPIO_ResetBits(AM2303_PORT, AM2303_PIN)
- #define AM2303_TOGGLE GPIO_ToggleBits(AM2303_PORT, AM2303_PIN)
- #define AM2303_IO_IN \
- { \
- GPIOB->MODER &= ~(3 << (1 * 2)); \
- GPIOB->MODER |= 0 << (1 * 2); \
- }
- #define AM2303_IO_OUT \
- { \
- GPIOB->MODER &= ~(3 << (1 * 2)); \
- GPIOB->MODER |= 1 << (1 * 2); \
- }
- #define DQ_IS_LOW() ((AM2303_PORT->IDR & AM2303_PIN) == 0)
- void interface_init(void);
- void gpio_clock_init(void);
- #endif
|