Fixes for UART2 on Metro M4 Airlift Lite (#739)
* machine/samd51: Fixes for UART2
Этот коммит содержится в:
родитель
c09724bfc5
коммит
ea5df0f214
4 изменённых файлов: 74 добавлений и 21 удалений
|
@ -53,6 +53,12 @@ const (
|
|||
UART_RX_PIN = D0
|
||||
)
|
||||
|
||||
// UART2 pins
|
||||
const (
|
||||
UART2_TX_PIN = A4
|
||||
UART2_RX_PIN = A5
|
||||
)
|
||||
|
||||
// I2C pins
|
||||
const (
|
||||
SDA_PIN = D22 // SDA: SERCOM2/PAD[0]
|
||||
|
|
|
@ -51,10 +51,20 @@ const (
|
|||
UART_RX_PIN = D0
|
||||
)
|
||||
|
||||
// UART1 var is on SERCOM3, defined in atsamd51.go
|
||||
|
||||
// UART2 pins
|
||||
const (
|
||||
UART2_TX_PIN = A4
|
||||
UART2_RX_PIN = D2
|
||||
)
|
||||
|
||||
// UART2 var is on SERCOM0, defined in atsamd51.go
|
||||
|
||||
// I2C pins
|
||||
const (
|
||||
SDA_PIN = PA12 // SDA: SERCOM3/PAD[0]
|
||||
SCL_PIN = PA13 // SCL: SERCOM3/PAD[1]
|
||||
SDA_PIN = PA12 // SDA: SERCOM2/PAD[0]
|
||||
SCL_PIN = PA13 // SCL: SERCOM2/PAD[1]
|
||||
)
|
||||
|
||||
// I2C on the ItsyBitsy M4.
|
||||
|
|
|
@ -66,20 +66,8 @@ const (
|
|||
NINA_RTS = PB23
|
||||
)
|
||||
|
||||
// UART2 on the Metro M4 Airlift Lite connects to the onboard ESP32-WROOM chip.
|
||||
var (
|
||||
UART2 = UART{
|
||||
Buffer: NewRingBuffer(),
|
||||
Bus: sam.SERCOM0_USART_INT,
|
||||
Mode: PinSERCOMAlt,
|
||||
}
|
||||
)
|
||||
|
||||
//go:export SERCOM0_IRQHandler
|
||||
func handleUART2() {
|
||||
UART2.Receive(byte((UART2.Bus.DATA.Get() & 0xFF)))
|
||||
UART2.Bus.INTFLAG.SetBits(sam.SERCOM_USART_INT_INTFLAG_RXC)
|
||||
}
|
||||
// UART2 is on SERCOM0, defined in machine_atsamd51.go, and connects to the
|
||||
// onboard ESP32-WROOM chip.
|
||||
|
||||
// I2C pins
|
||||
const (
|
||||
|
@ -100,6 +88,10 @@ const (
|
|||
SPI0_SCK_PIN = PA13 // SCK: SERCOM2/PAD[1]
|
||||
SPI0_MOSI_PIN = PA12 // MOSI: SERCOM2/PAD[0]
|
||||
SPI0_MISO_PIN = PA14 // MISO: SERCOM2/PAD[2]
|
||||
|
||||
NINA_MOSI = SPI0_MOSI_PIN
|
||||
NINA_MISO = SPI0_MISO_PIN
|
||||
NINA_SCK = SPI0_SCK_PIN
|
||||
)
|
||||
|
||||
// SPI on the Metro M4.
|
||||
|
@ -115,6 +107,7 @@ var (
|
|||
MOSIPinMode: PinSERCOM,
|
||||
SCKPinMode: PinSERCOM,
|
||||
}
|
||||
NINA_SPI = SPI0
|
||||
)
|
||||
|
||||
const (
|
||||
|
|
|
@ -473,6 +473,13 @@ var (
|
|||
Buffer: NewRingBuffer(),
|
||||
Mode: PinSERCOMAlt,
|
||||
}
|
||||
|
||||
// The second hardware serial port on the SAMD51. Uses the SERCOM0 interface.
|
||||
UART2 = UART{
|
||||
Buffer: NewRingBuffer(),
|
||||
Bus: sam.SERCOM0_USART_INT,
|
||||
Mode: PinSERCOMAlt,
|
||||
}
|
||||
)
|
||||
|
||||
const (
|
||||
|
@ -522,6 +529,8 @@ func (uart UART) Configure(config UARTConfig) {
|
|||
}
|
||||
|
||||
switch config.RX {
|
||||
case PA06:
|
||||
rxpad = sercomRXPad2
|
||||
case PA07:
|
||||
rxpad = sercomRXPad3
|
||||
case PA11:
|
||||
|
@ -591,11 +600,20 @@ func (uart UART) Configure(config UARTConfig) {
|
|||
// setup interrupt on receive
|
||||
uart.Bus.INTENSET.Set(sam.SERCOM_USART_INT_INTENSET_RXC)
|
||||
|
||||
// Enable RX IRQ. Currently assumes SERCOM3.
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_0)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_1)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_2)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_OTHER)
|
||||
// Enable RX IRQ.
|
||||
switch uart.Bus {
|
||||
case sam.SERCOM0_USART_INT:
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM0_0)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM0_1)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM0_2)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM0_OTHER)
|
||||
default:
|
||||
// Currently assumes SERCOM3
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_0)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_1)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_2)
|
||||
arm.EnableIRQ(sam.IRQ_SERCOM3_OTHER)
|
||||
}
|
||||
}
|
||||
|
||||
// SetBaudRate sets the communication speed for the UART.
|
||||
|
@ -647,6 +665,32 @@ func handleUART1() {
|
|||
UART1.Bus.INTFLAG.SetBits(sam.SERCOM_USART_INT_INTFLAG_RXC)
|
||||
}
|
||||
|
||||
//go:export SERCOM0_0_IRQHandler
|
||||
func handleSERCOM0_0() {
|
||||
handleUART2()
|
||||
}
|
||||
|
||||
//go:export SERCOM0_1_IRQHandler
|
||||
func handleSERCOM0_1() {
|
||||
handleUART2()
|
||||
}
|
||||
|
||||
//go:export SERCOM0_2_IRQHandler
|
||||
func handleSERCOM0_2() {
|
||||
handleUART2()
|
||||
}
|
||||
|
||||
//go:export SERCOM0_OTHER_IRQHandler
|
||||
func handleSERCOM0_OTHER() {
|
||||
handleUART2()
|
||||
}
|
||||
|
||||
func handleUART2() {
|
||||
// should reset IRQ
|
||||
UART2.Receive(byte((UART2.Bus.DATA.Get() & 0xFF)))
|
||||
UART2.Bus.INTFLAG.SetBits(sam.SERCOM_USART_INT_INTFLAG_RXC)
|
||||
}
|
||||
|
||||
// I2C on the SAMD51.
|
||||
type I2C struct {
|
||||
Bus *sam.SERCOM_I2CM_Type
|
||||
|
|
Загрузка…
Создание таблицы
Сослаться в новой задаче