stm32: Add comments to configuration of OSPEEDR gpio speed
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
9d9fe3cb1b
commit
1b801508ba
|
@ -64,6 +64,8 @@ gpio_clock_enable(GPIO_TypeDef *regs)
|
||||||
RCC->AHBENR;
|
RCC->AHBENR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define STM_OSPEED 0x2 // ~2Mhz at 50pF
|
||||||
|
|
||||||
// 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)
|
||||||
|
@ -84,7 +86,7 @@ gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
regs->MODER = (regs->MODER & ~m_msk) | (mode_bits << m_shift);
|
regs->MODER = (regs->MODER & ~m_msk) | (mode_bits << m_shift);
|
||||||
regs->PUPDR = (regs->PUPDR & ~m_msk) | (pup << m_shift);
|
regs->PUPDR = (regs->PUPDR & ~m_msk) | (pup << m_shift);
|
||||||
regs->OTYPER = (regs->OTYPER & ~(1 << pos)) | (od << pos);
|
regs->OTYPER = (regs->OTYPER & ~(1 << pos)) | (od << pos);
|
||||||
regs->OSPEEDR = (regs->OSPEEDR & ~m_msk) | (0x02 << m_shift);
|
regs->OSPEEDR = (regs->OSPEEDR & ~m_msk) | (STM_OSPEED << m_shift);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define USB_BOOT_FLAG_ADDR (CONFIG_RAM_START + CONFIG_RAM_SIZE - 1024)
|
#define USB_BOOT_FLAG_ADDR (CONFIG_RAM_START + CONFIG_RAM_SIZE - 1024)
|
||||||
|
|
|
@ -68,7 +68,6 @@ gpio_clock_enable(GPIO_TypeDef *regs)
|
||||||
RCC->APB2ENR;
|
RCC->APB2ENR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void stm32f1_alternative_remap(uint32_t mapr_mask, uint32_t mapr_value)
|
static void stm32f1_alternative_remap(uint32_t mapr_mask, uint32_t mapr_value)
|
||||||
{
|
{
|
||||||
// The MAPR register is a mix of write only and r/w bits
|
// The MAPR register is a mix of write only and r/w bits
|
||||||
|
@ -80,6 +79,8 @@ static void stm32f1_alternative_remap(uint32_t mapr_mask, uint32_t mapr_value)
|
||||||
AFIO->MAPR = mapr;
|
AFIO->MAPR = mapr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define STM_OSPEED 0x1 // ~10Mhz at 50pF
|
||||||
|
|
||||||
// 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)
|
||||||
|
@ -94,20 +95,20 @@ gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
if (mode == GPIO_INPUT) {
|
if (mode == GPIO_INPUT) {
|
||||||
cfg = pullup ? 0x8 : 0x4;
|
cfg = pullup ? 0x8 : 0x4;
|
||||||
} else if (mode == GPIO_OUTPUT) {
|
} else if (mode == GPIO_OUTPUT) {
|
||||||
cfg = 0x1;
|
cfg = STM_OSPEED;
|
||||||
} else if (mode == (GPIO_OUTPUT | GPIO_OPEN_DRAIN)) {
|
} else if (mode == (GPIO_OUTPUT | GPIO_OPEN_DRAIN)) {
|
||||||
cfg = 0x5;
|
cfg = 0x4 | STM_OSPEED;
|
||||||
} else if (mode == GPIO_ANALOG) {
|
} else if (mode == GPIO_ANALOG) {
|
||||||
cfg = 0x0;
|
cfg = 0x0;
|
||||||
} else {
|
} else {
|
||||||
if (mode & GPIO_OPEN_DRAIN)
|
if (mode & GPIO_OPEN_DRAIN)
|
||||||
// Alternate function with open-drain mode
|
// Alternate function with open-drain mode
|
||||||
cfg = 0xd;
|
cfg = 0xc | STM_OSPEED;
|
||||||
else if (pullup > 0)
|
else if (pullup > 0)
|
||||||
// Alternate function input pins use GPIO_INPUT mode on the stm32f1
|
// Alternate function input pins use GPIO_INPUT mode on the stm32f1
|
||||||
cfg = 0x8;
|
cfg = 0x8;
|
||||||
else
|
else
|
||||||
cfg = 0x9;
|
cfg = 0x8 | STM_OSPEED;
|
||||||
}
|
}
|
||||||
if (pos & 0x8)
|
if (pos & 0x8)
|
||||||
regs->CRH = (regs->CRH & ~msk) | (cfg << shift);
|
regs->CRH = (regs->CRH & ~msk) | (cfg << shift);
|
||||||
|
|
|
@ -68,6 +68,8 @@ gpio_clock_enable(GPIO_TypeDef *regs)
|
||||||
RCC->AHB1ENR;
|
RCC->AHB1ENR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define STM_OSPEED 0x2 // ~50Mhz at 40pF on STM32F4 (~25Mhz at 40pF on STM32F2)
|
||||||
|
|
||||||
// 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)
|
||||||
|
@ -88,7 +90,7 @@ gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
regs->MODER = (regs->MODER & ~m_msk) | (mode_bits << m_shift);
|
regs->MODER = (regs->MODER & ~m_msk) | (mode_bits << m_shift);
|
||||||
regs->PUPDR = (regs->PUPDR & ~m_msk) | (pup << m_shift);
|
regs->PUPDR = (regs->PUPDR & ~m_msk) | (pup << m_shift);
|
||||||
regs->OTYPER = (regs->OTYPER & ~(1 << pos)) | (od << pos);
|
regs->OTYPER = (regs->OTYPER & ~(1 << pos)) | (od << pos);
|
||||||
regs->OSPEEDR = (regs->OSPEEDR & ~m_msk) | (0x02 << m_shift);
|
regs->OSPEEDR = (regs->OSPEEDR & ~m_msk) | (STM_OSPEED << m_shift);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define USB_BOOT_FLAG_ADDR (CONFIG_RAM_START + CONFIG_RAM_SIZE - 4096)
|
#define USB_BOOT_FLAG_ADDR (CONFIG_RAM_START + CONFIG_RAM_SIZE - 4096)
|
||||||
|
|
|
@ -102,6 +102,8 @@ gpio_clock_enable(GPIO_TypeDef *regs)
|
||||||
enable_pclock((uint32_t)regs);
|
enable_pclock((uint32_t)regs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define STM_OSPEED 0x2 // ~85Mhz at 50pF
|
||||||
|
|
||||||
// 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)
|
||||||
|
@ -122,7 +124,7 @@ gpio_peripheral(uint32_t gpio, uint32_t mode, int pullup)
|
||||||
regs->MODER = (regs->MODER & ~m_msk) | (mode_bits << m_shift);
|
regs->MODER = (regs->MODER & ~m_msk) | (mode_bits << m_shift);
|
||||||
regs->PUPDR = (regs->PUPDR & ~m_msk) | (pup << m_shift);
|
regs->PUPDR = (regs->PUPDR & ~m_msk) | (pup << m_shift);
|
||||||
regs->OTYPER = (regs->OTYPER & ~(1 << pos)) | (od << pos);
|
regs->OTYPER = (regs->OTYPER & ~(1 << pos)) | (od << pos);
|
||||||
regs->OSPEEDR = (regs->OSPEEDR & ~m_msk) | (0x02 << m_shift);
|
regs->OSPEEDR = (regs->OSPEEDR & ~m_msk) | (STM_OSPEED << m_shift);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !CONFIG_STM32_CLOCK_REF_INTERNAL
|
#if !CONFIG_STM32_CLOCK_REF_INTERNAL
|
||||||
|
|
Loading…
Reference in New Issue