diff options
author | Daniel Friesel <daniel.friesel@uos.de> | 2022-07-21 12:44:43 +0200 |
---|---|---|
committer | Daniel Friesel <daniel.friesel@uos.de> | 2022-07-21 12:44:43 +0200 |
commit | e2d191ebe69745fe658df8c56be2f8d3c4e7af47 (patch) | |
tree | 321fb7db3a557d4eb60e92932480466e707d3c66 /src/arch/infineon-tc1796-mock/driver | |
parent | 68f92431e5706b4bed64ad37f0f26e8eef57c11e (diff) |
tc1796: it's working!
Diffstat (limited to 'src/arch/infineon-tc1796-mock/driver')
-rw-r--r-- | src/arch/infineon-tc1796-mock/driver/counter.cc | 1 | ||||
-rw-r--r-- | src/arch/infineon-tc1796-mock/driver/stdout.cc | 58 |
2 files changed, 58 insertions, 1 deletions
diff --git a/src/arch/infineon-tc1796-mock/driver/counter.cc b/src/arch/infineon-tc1796-mock/driver/counter.cc index 7279806..0277d07 100644 --- a/src/arch/infineon-tc1796-mock/driver/counter.cc +++ b/src/arch/infineon-tc1796-mock/driver/counter.cc @@ -5,6 +5,5 @@ */ #include "arch.h" #include "driver/counter.h" -#include "driver/gpio.h" Counter counter; diff --git a/src/arch/infineon-tc1796-mock/driver/stdout.cc b/src/arch/infineon-tc1796-mock/driver/stdout.cc index ccdb7d5..499b2ab 100644 --- a/src/arch/infineon-tc1796-mock/driver/stdout.cc +++ b/src/arch/infineon-tc1796-mock/driver/stdout.cc @@ -4,13 +4,71 @@ * SPDX-License-Identifier: BSD-2-Clause */ #include "driver/stdout.h" +#include <machine/wdtcon.h> +#include <tc1796b/port5-struct.h> +#include <tc1796b/asc0-struct.h> + +#define OF_BYP 29 +#define OF_NDIV 16 +#define OF_PDIV 13 +#define OF_KDIV 8 +#define OF_VCOSEL 6 +#define OF_SYSFS 2 + +#define OF_RMC 8 +#define ASC0_CLC (*(volatile unsigned int*)0xf0000a00) +#define ASC0_PISEL (*(volatile unsigned int*)0xf0000a04) +#define ASC0_CON (*(volatile unsigned int*)0xf0000a10) +#define ASC0_BG (*(volatile unsigned int*)0xf0000a14) +#define ASC0_FDV (*(volatile unsigned int*)0xf0000a18) +#define ASC0_TBUF (*(volatile unsigned int*)0xf0000a20) +#define ASC0_TBSRC (*(volatile unsigned int*)0xf0000afc) + +#define SRC_SRE (1 << 12) +#define SRC_SRR (1 << 13) +#define SRC_CLRR (1 << 14) +#define SRC_SETR (1 << 15) void StandardOutput::setup() { + // P5_IOCR0.PC1 = OUT_PPALT1 + (*(volatile unsigned int*)0xf0001110) = 0x9 << 12; + // P5_IOMR.PS1 = 1 + (*(volatile unsigned int*)0xf0001104) = 0x00000001; + + /* Configure for 115200 Baud @ 75 MHz fSYS, see table 19-4 */ + unsigned int const reload_value = 0x17; + unsigned int const fdv = 0x12e; + + unlock_wdtcon(); + // ASC0_CLC: enable (DISR := 0), RMC := 1 (clock divider == 1 -> clock == system clock "fsys"?) + ASC0_CLC = 1 << OF_RMC; + lock_wdtcon(); + // ASC0_CON = 0 + ASC0_CON = 0; + // ASC0_BG = reload_value + ASC0_BG = reload_value; + // ASC0_FDV = fdv + ASC0_FDV = fdv; + // ASC0_CON := (M := ASCM_8ASYNC == 1; FDE := 1; R := 1 + ASC0_CON = (1 << 0) | (1 << 11) | (1 << 15); + + /* After initialization, the transmit buffer is ready to accept writes. */ + ASC0_TBSRC = SRC_SETR; } void StandardOutput::put(char c) { + while (!(ASC0_TBSRC & SRC_SRR)) ; + + /* Clear service request flag -- we're filling up TBUF */ + ASC0_TBSRC = SRC_CLRR; + + ASC0_TBUF = c; + + if (c == '\n') { + put('\r'); + } } StandardOutput kout; |