File: uart.c

package info (click to toggle)
crust-firmware 0.6-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,900 kB
  • sloc: ansic: 19,341; yacc: 596; lex: 479; makefile: 334; asm: 215; sh: 136; python: 42
file content (44 lines) | stat: -rw-r--r-- 1,031 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/*
 * Copyright © 2017-2022 The Crust Firmware Authors.
 * SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0-only
 */

#include <division.h>
#include <error.h>
#include <mmio.h>

#include "uart.h"

static int
uart_probe(const struct device *dev)
{
	const struct simple_device *self = to_simple_device(dev);
	int err;

	if ((err = simple_device_probe(dev)))
		return err;

	if (CONFIG_SERIAL_BAUD) {
		uint32_t  rate    = clock_get_rate(&self->clock);
		uint32_t  divisor = udiv_round(rate, 16 * CONFIG_SERIAL_BAUD);
		uintptr_t regs    = self->regs;

		/* Set the clock divisor. */
		mmio_write_32(regs + UART_LCR, UART_LCR_DLAB);
		mmio_write_32(regs + UART_DLH, divisor >> 8);
		mmio_write_32(regs + UART_DLL, divisor);

		/* Set the UART to 8 data bits, no parity, 1 stop bit. */
		mmio_write_32(regs + UART_LCR, UART_LCR_DLS8);

		/* Enable the FIFOs. */
		mmio_write_32(regs + UART_FCR, UART_FCR_FIFOE);
	}

	return SUCCESS;
}

const struct driver uart_driver = {
	.probe   = uart_probe,
	.release = simple_device_release,
};