57 строки
1,7 КиБ
Go
57 строки
1,7 КиБ
Go
//go:build stm32l5x2
|
|
|
|
package machine
|
|
|
|
// Peripheral abstraction layer for the stm32f407
|
|
|
|
import (
|
|
"device/stm32"
|
|
)
|
|
|
|
func CPUFrequency() uint32 {
|
|
return 110000000
|
|
}
|
|
|
|
// Internal use: configured speed of the APB1 and APB2 timers, this should be kept
|
|
// in sync with any changes to runtime package which configures the oscillators
|
|
// and clock frequencies
|
|
const APB1_TIM_FREQ = 110e6 // 110MHz
|
|
const APB2_TIM_FREQ = 110e6 // 110MHz
|
|
|
|
//---------- UART related code
|
|
|
|
// Configure the UART.
|
|
func (uart *UART) configurePins(config UARTConfig) {
|
|
if config.RX.getPort() == stm32.GPIOG || config.TX.getPort() == stm32.GPIOG {
|
|
// Enable VDDIO2 power supply, which is an independant power supply for the PGx pins
|
|
stm32.PWR.CR2.SetBits(stm32.PWR_CR2_IOSV)
|
|
}
|
|
|
|
// enable the alternate functions on the TX and RX pins
|
|
config.TX.ConfigureAltFunc(PinConfig{Mode: PinModeUARTTX}, uart.TxAltFuncSelector)
|
|
config.RX.ConfigureAltFunc(PinConfig{Mode: PinModeUARTRX}, uart.RxAltFuncSelector)
|
|
}
|
|
|
|
// UART baudrate calc based on the bus and clockspeed
|
|
// NOTE: keep this in sync with the runtime/runtime_stm32l5x2.go clock init code
|
|
func (uart *UART) getBaudRateDivisor(baudRate uint32) uint32 {
|
|
return 256 * (CPUFrequency() / baudRate)
|
|
}
|
|
|
|
// Register names vary by ST processor, these are for STM L5
|
|
func (uart *UART) setRegisters() {
|
|
uart.rxReg = &uart.Bus.RDR
|
|
uart.txReg = &uart.Bus.TDR
|
|
uart.statusReg = &uart.Bus.ISR
|
|
uart.txEmptyFlag = stm32.USART_ISR_TXE
|
|
}
|
|
|
|
//---------- I2C related code
|
|
|
|
// Gets the value for TIMINGR register
|
|
func (i2c *I2C) getFreqRange() uint32 {
|
|
// This is a 'magic' value calculated by STM32CubeMX
|
|
// for 110MHz PCLK1.
|
|
// TODO: Do calculations based on PCLK1
|
|
return 0x40505681
|
|
}
|