2019-07-29 06:15:54 +03:00
|
|
|
#ifndef __STM32_INTERNAL_H
|
|
|
|
#define __STM32_INTERNAL_H
|
|
|
|
// Local definitions for STM32 code
|
2019-07-24 06:51:31 +03:00
|
|
|
|
2019-07-29 06:15:54 +03:00
|
|
|
#include "autoconf.h" // CONFIG_MACH_STM32F1
|
2019-07-28 21:40:41 +03:00
|
|
|
|
2019-09-16 18:45:36 +03:00
|
|
|
#if CONFIG_MACH_STM32F0
|
|
|
|
#include "stm32f0xx.h"
|
|
|
|
#elif CONFIG_MACH_STM32F1
|
2019-07-28 21:40:41 +03:00
|
|
|
#include "stm32f1xx.h"
|
2019-09-16 18:45:36 +03:00
|
|
|
#elif CONFIG_MACH_STM32F4
|
2019-07-24 06:51:31 +03:00
|
|
|
#include "stm32f4xx.h"
|
2019-07-28 21:40:41 +03:00
|
|
|
#endif
|
2019-07-24 06:51:31 +03:00
|
|
|
|
2019-07-28 18:53:28 +03:00
|
|
|
extern GPIO_TypeDef * const digital_regs[];
|
|
|
|
|
2019-07-24 06:51:31 +03:00
|
|
|
#define GPIO(PORT, NUM) (((PORT)-'A') * 16 + (NUM))
|
|
|
|
#define GPIO2PORT(PIN) ((PIN) / 16)
|
|
|
|
#define GPIO2BIT(PIN) (1<<((PIN) % 16))
|
|
|
|
|
|
|
|
#define GPIO_INPUT 0
|
|
|
|
#define GPIO_OUTPUT 1
|
2019-08-20 20:32:14 +03:00
|
|
|
#define GPIO_OPEN_DRAIN 0x100
|
2019-07-28 18:32:56 +03:00
|
|
|
#define GPIO_FUNCTION(fn) (2 | ((fn) << 4))
|
2019-07-24 06:51:31 +03:00
|
|
|
#define GPIO_ANALOG 3
|
|
|
|
|
|
|
|
void enable_pclock(uint32_t periph_base);
|
2019-07-29 00:55:57 +03:00
|
|
|
int is_enabled_pclock(uint32_t periph_base);
|
2019-07-24 06:51:31 +03:00
|
|
|
uint32_t get_pclock_frequency(uint32_t periph_base);
|
2019-08-20 08:04:20 +03:00
|
|
|
void gpio_clock_enable(GPIO_TypeDef *regs);
|
2019-07-28 18:32:56 +03:00
|
|
|
void gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup);
|
2019-07-24 06:51:31 +03:00
|
|
|
|
|
|
|
#endif // internal.h
|