stm32: Make sure to enable the gpio clock prior to setting the first value
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
a67451fa36
commit
c930fc392b
|
@ -52,6 +52,7 @@ gpio_out_setup(uint32_t pin, uint32_t val)
|
||||||
if (GPIO2PORT(pin) >= ARRAY_SIZE(digital_regs))
|
if (GPIO2PORT(pin) >= ARRAY_SIZE(digital_regs))
|
||||||
goto fail;
|
goto fail;
|
||||||
GPIO_TypeDef *regs = digital_regs[GPIO2PORT(pin)];
|
GPIO_TypeDef *regs = digital_regs[GPIO2PORT(pin)];
|
||||||
|
gpio_clock_enable(regs);
|
||||||
struct gpio_out g = { .regs=regs, .bit=GPIO2BIT(pin) };
|
struct gpio_out g = { .regs=regs, .bit=GPIO2BIT(pin) };
|
||||||
gpio_out_reset(g, val);
|
gpio_out_reset(g, val);
|
||||||
return g;
|
return g;
|
||||||
|
|
|
@ -25,6 +25,7 @@ void enable_pclock(uint32_t periph_base);
|
||||||
int is_enabled_pclock(uint32_t periph_base);
|
int is_enabled_pclock(uint32_t periph_base);
|
||||||
uint32_t get_pclock_frequency(uint32_t periph_base);
|
uint32_t get_pclock_frequency(uint32_t periph_base);
|
||||||
void clock_setup(void);
|
void clock_setup(void);
|
||||||
|
void gpio_clock_enable(GPIO_TypeDef *regs);
|
||||||
void gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup);
|
void gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup);
|
||||||
|
|
||||||
#endif // internal.h
|
#endif // internal.h
|
||||||
|
|
|
@ -51,6 +51,15 @@ get_pclock_frequency(uint32_t periph_base)
|
||||||
return FREQ_PERIPH;
|
return FREQ_PERIPH;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Enable a GPIO peripheral clock
|
||||||
|
void
|
||||||
|
gpio_clock_enable(GPIO_TypeDef *regs)
|
||||||
|
{
|
||||||
|
uint32_t rcc_pos = ((uint32_t)regs - APB2PERIPH_BASE) / 0x400;
|
||||||
|
RCC->APB2ENR |= 1 << rcc_pos;
|
||||||
|
RCC->APB2ENR;
|
||||||
|
}
|
||||||
|
|
||||||
// Set the mode and extended function of a pin
|
// Set the mode and extended function of a pin
|
||||||
void
|
void
|
||||||
gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
|
@ -58,8 +67,7 @@ gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
GPIO_TypeDef *regs = digital_regs[GPIO2PORT(gpio)];
|
GPIO_TypeDef *regs = digital_regs[GPIO2PORT(gpio)];
|
||||||
|
|
||||||
// Enable GPIO clock
|
// Enable GPIO clock
|
||||||
uint32_t rcc_pos = ((uint32_t)regs - APB2PERIPH_BASE) / 0x400;
|
gpio_clock_enable(regs);
|
||||||
RCC->APB2ENR |= 1 << rcc_pos;
|
|
||||||
|
|
||||||
// Configure GPIO
|
// Configure GPIO
|
||||||
uint32_t pos = gpio % 16, shift = (pos % 8) * 4, msk = 0xf << shift, cfg;
|
uint32_t pos = gpio % 16, shift = (pos % 8) * 4, msk = 0xf << shift, cfg;
|
||||||
|
|
|
@ -53,6 +53,15 @@ get_pclock_frequency(uint32_t periph_base)
|
||||||
return FREQ_PERIPH;
|
return FREQ_PERIPH;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Enable a GPIO peripheral clock
|
||||||
|
void
|
||||||
|
gpio_clock_enable(GPIO_TypeDef *regs)
|
||||||
|
{
|
||||||
|
uint32_t rcc_pos = ((uint32_t)regs - AHB1PERIPH_BASE) / 0x400;
|
||||||
|
RCC->AHB1ENR |= 1 << rcc_pos;
|
||||||
|
RCC->AHB1ENR;
|
||||||
|
}
|
||||||
|
|
||||||
// Set the mode and extended function of a pin
|
// Set the mode and extended function of a pin
|
||||||
void
|
void
|
||||||
gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
|
@ -60,8 +69,7 @@ gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
GPIO_TypeDef *regs = digital_regs[GPIO2PORT(gpio)];
|
GPIO_TypeDef *regs = digital_regs[GPIO2PORT(gpio)];
|
||||||
|
|
||||||
// Enable GPIO clock
|
// Enable GPIO clock
|
||||||
uint32_t rcc_pos = ((uint32_t)regs - AHB1PERIPH_BASE) / 0x400;
|
gpio_clock_enable(regs);
|
||||||
RCC->AHB1ENR |= (1<<rcc_pos);
|
|
||||||
|
|
||||||
// Configure GPIO
|
// Configure GPIO
|
||||||
uint32_t mode_bits = mode & 0x0f, func = mode >> 4;
|
uint32_t mode_bits = mode & 0x0f, func = mode >> 4;
|
||||||
|
|
Loading…
Reference in New Issue