diff options
author | Birte Kristina Friesel <derf@finalrewind.org> | 2024-01-26 20:38:50 +0100 |
---|---|---|
committer | Birte Kristina Friesel <derf@finalrewind.org> | 2024-01-26 20:38:50 +0100 |
commit | 218166456b68ca2266c8e7c77c1085ad4fc16e86 (patch) | |
tree | d83ca341c6706dcbac806c960d8f8baaadfc0421 /src/arch/atmega2560/driver/stdout1.cc | |
parent | fc4a1906ff3fa4ce355c3a058b15ed243d8ce7a8 (diff) |
ATMega2560: Add stdin and stdout on UART1, UART2, UART3
Diffstat (limited to 'src/arch/atmega2560/driver/stdout1.cc')
-rw-r--r-- | src/arch/atmega2560/driver/stdout1.cc | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/arch/atmega2560/driver/stdout1.cc b/src/arch/atmega2560/driver/stdout1.cc new file mode 100644 index 0000000..e686237 --- /dev/null +++ b/src/arch/atmega2560/driver/stdout1.cc @@ -0,0 +1,39 @@ +/* + * Copyright 2024 Birte Kristina Friesel + * + * SPDX-License-Identifier: BSD-2-Clause + */ +#include "driver/stdout1.h" +#include <avr/io.h> +#include <avr/interrupt.h> + +#undef BAUD +#define BAUD CONFIG_arch_atmega2560_uart1_baud + +#include <util/setbaud.h> + +void StandardOutput1::setup() +{ + UBRR1H = UBRRH_VALUE; + UBRR1L = UBRRL_VALUE; + +#if USE_2X + UCSR1A |= _BV(U2X1); +#else + UCSR1A &= ~_BV(U2X1); +#endif + + UCSR1B |= _BV(RXEN1) | _BV(TXEN1); + UCSR1C = _BV(UCSZ11) | _BV(UCSZ10); +} + +void StandardOutput1::put(char c) +{ + while (!(UCSR1A & _BV(UDRE1))); + UDR1 = c; + if (c == '\n') { + put('\r'); + } +} + +StandardOutput1 kout1; |