blob: 3053c7495159dc0fef4ec9ae8075b0d5e8f75900 [file] [log] [blame]
/*
* Copyright (c) 2016 Open-RnD Sp. z o.o.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @brief Driver for UART port on STM32F10x family processor.
*
* Based on reference manual:
* STM32F101xx, STM32F102xx, STM32F103xx, STM32F105xx and STM32F107xx
* advanced ARM ® -based 32-bit MCUs
*
* Chapter 27: Universal synchronous asynchronous receiver
* transmitter (USART)
*/
#ifndef _STM32_UART_H_
#define _STM32_UART_H_
/* 27.6.1 Status register (USART_SR) */
union __sr {
uint32_t val;
struct {
uint32_t pe :1 __packed;
uint32_t fe :1 __packed;
uint32_t ne :1 __packed;
uint32_t ore :1 __packed;
uint32_t idle :1 __packed;
uint32_t rxne :1 __packed;
uint32_t tc :1 __packed;
uint32_t txe :1 __packed;
uint32_t lbd :1 __packed;
uint32_t cts :1 __packed;
uint32_t rsvd__10_15 : 6 __packed;
uint32_t rsvd__16_31 : 16 __packed;
} bit;
};
/* 27.6.2 Data register (USART_DR) */
union __dr {
uint32_t val;
struct {
uint32_t dr :8 __packed;
uint32_t rsvd__9_31 :24 __packed;
} bit;
};
/* 27.6.3 Baud rate register (USART_BRR) */
union __brr {
uint32_t val;
struct {
uint32_t fraction :4 __packed;
uint32_t mantissa :12 __packed;
uint32_t rsvd__16_31 :16 __packed;
} bit;
};
/* 27.6.4 Control register 1 (USART_CR1) */
union __cr1 {
uint32_t val;
struct {
uint32_t sbk :1 __packed;
uint32_t rwu :1 __packed;
uint32_t re :1 __packed;
uint32_t te :1 __packed;
uint32_t idleie :1 __packed;
uint32_t rxneie :1 __packed;
uint32_t tcie :1 __packed;
uint32_t txeie :1 __packed;
uint32_t peie :1 __packed;
uint32_t ps :1 __packed;
uint32_t pce :1 __packed;
uint32_t wake :1 __packed;
uint32_t m :1 __packed;
uint32_t ue :1 __packed;
uint32_t rsvd__14_15 :2 __packed;
uint32_t rsvd__16_31 :16 __packed;
} bit;
};
/* 27.6.5 Control register 2 (USART_CR2) */
union __cr2 {
uint32_t val;
struct {
uint32_t addr :4 __packed;
uint32_t rsvd__4 :1 __packed;
uint32_t lbdl :1 __packed;
uint32_t lbdie :1 __packed;
uint32_t rsvd__7 :1 __packed;
uint32_t lbcl :1 __packed;
uint32_t cpha :1 __packed;
uint32_t cpol :1 __packed;
uint32_t clken :1 __packed;
uint32_t stop :2 __packed;
uint32_t linen :1 __packed;
uint32_t rsvd__15_31 :17 __packed;
} bit;
};
/* 27.6.6 Control register 3 (USART_CR3) */
union __cr3 {
uint32_t val;
struct {
uint32_t eie :1 __packed;
uint32_t iren :1 __packed;
uint32_t irlp :1 __packed;
uint32_t hdsel :1 __packed;
uint32_t nack :1 __packed;
uint32_t scen :1 __packed;
uint32_t dmar :1 __packed;
uint32_t dmat :1 __packed;
uint32_t rtse :1 __packed;
uint32_t ctse :1 __packed;
uint32_t ctsie :1 __packed;
uint32_t rsvd__11_31 :21 __packed;
} bit;
};
/* 27.6.7 Guard time and prescaler register (USART_GTPR) */
union __gtpr {
uint32_t val;
struct {
uint32_t psc :8 __packed;
uint32_t gt :8 __packed;
uint32_t rsvd__16_31 :16 __packed;
} bit;
};
/* 27.6.8 USART register map */
struct uart_stm32 {
union __sr sr;
union __dr dr;
union __brr brr;
union __cr1 cr1;
union __cr2 cr2;
union __cr3 cr3;
union __gtpr gtpr;
};
/* device config */
struct uart_stm32_config {
struct uart_device_config uconf;
/* clock subsystem driving this peripheral */
clock_control_subsys_t clock_subsys;
};
/* driver data */
struct uart_stm32_data {
/* current baud rate */
uint32_t baud_rate;
/* clock device */
struct device *clock;
#ifdef CONFIG_UART_INTERRUPT_DRIVEN
uart_irq_callback_t user_cb;
#endif
};
#endif /* _STM32_UART_H_ */