Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 1 | /* |
Yann Gautier | 0d5ca3d | 2022-12-09 14:30:55 +0100 | [diff] [blame] | 2 | * Copyright (c) 2013-2023, ARM Limited and Contributors. All rights reserved. |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 3 | * |
dp-arm | fa3cf0b | 2017-05-03 09:38:09 +0100 | [diff] [blame] | 4 | * SPDX-License-Identifier: BSD-3-Clause |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 5 | */ |
| 6 | |
Antonio Nino Diaz | 5eb8837 | 2018-11-08 10:20:19 +0000 | [diff] [blame] | 7 | #ifndef CONSOLE_H |
| 8 | #define CONSOLE_H |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 9 | |
Antonio Nino Diaz | e0f9063 | 2018-12-14 00:18:21 +0000 | [diff] [blame] | 10 | #include <lib/utils_def.h> |
Juan Castillo | 7f1f062 | 2014-09-09 09:49:23 +0100 | [diff] [blame] | 11 | |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 12 | #define CONSOLE_T_NEXT (U(0) * REGSZ) |
| 13 | #define CONSOLE_T_FLAGS (U(1) * REGSZ) |
| 14 | #define CONSOLE_T_PUTC (U(2) * REGSZ) |
Sandrine Bailleux | f57e203 | 2023-10-11 08:38:00 +0200 | [diff] [blame] | 15 | #if ENABLE_CONSOLE_GETC |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 16 | #define CONSOLE_T_GETC (U(3) * REGSZ) |
| 17 | #define CONSOLE_T_FLUSH (U(4) * REGSZ) |
Andre Przywara | c88f656 | 2020-01-25 00:54:38 +0000 | [diff] [blame] | 18 | #define CONSOLE_T_BASE (U(5) * REGSZ) |
| 19 | #define CONSOLE_T_DRVDATA (U(6) * REGSZ) |
Sandrine Bailleux | f57e203 | 2023-10-11 08:38:00 +0200 | [diff] [blame] | 20 | #else |
| 21 | #define CONSOLE_T_FLUSH (U(3) * REGSZ) |
| 22 | #define CONSOLE_T_BASE (U(4) * REGSZ) |
| 23 | #define CONSOLE_T_DRVDATA (U(5) * REGSZ) |
| 24 | #endif |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 25 | |
Antonio Nino Diaz | 23ede6a | 2018-06-19 09:29:36 +0100 | [diff] [blame] | 26 | #define CONSOLE_FLAG_BOOT (U(1) << 0) |
| 27 | #define CONSOLE_FLAG_RUNTIME (U(1) << 1) |
| 28 | #define CONSOLE_FLAG_CRASH (U(1) << 2) |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 29 | /* Bits 3 to 7 reserved for additional scopes in future expansion. */ |
| 30 | #define CONSOLE_FLAG_SCOPE_MASK ((U(1) << 8) - 1) |
Masahiro Yamada | 269a8ad | 2019-07-23 12:32:58 +0900 | [diff] [blame] | 31 | /* Bits 8 to 31 for non-scope use. */ |
| 32 | #define CONSOLE_FLAG_TRANSLATE_CRLF (U(1) << 8) |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 33 | |
| 34 | /* Returned by getc callbacks when receive FIFO is empty. */ |
| 35 | #define ERROR_NO_PENDING_CHAR (-1) |
| 36 | /* Returned by console_xxx() if no registered console implements xxx. */ |
| 37 | #define ERROR_NO_VALID_CONSOLE (-128) |
| 38 | |
Julius Werner | 53456fc | 2019-07-09 13:49:11 -0700 | [diff] [blame] | 39 | #ifndef __ASSEMBLER__ |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 40 | |
Antonio Nino Diaz | 4b32e62 | 2018-08-16 16:52:57 +0100 | [diff] [blame] | 41 | #include <stdint.h> |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 42 | |
| 43 | typedef struct console { |
| 44 | struct console *next; |
Daniel Boulby | 99e4a48 | 2018-05-16 16:04:35 +0100 | [diff] [blame] | 45 | /* |
| 46 | * Only the low 32 bits are used. The type is u_register_t to align the |
| 47 | * fields of the struct to 64 bits in AArch64 and 32 bits in AArch32 |
| 48 | */ |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 49 | u_register_t flags; |
Daniel Boulby | 9516df2 | 2018-06-07 14:15:15 +0100 | [diff] [blame] | 50 | int (*const putc)(int character, struct console *console); |
Sandrine Bailleux | f57e203 | 2023-10-11 08:38:00 +0200 | [diff] [blame] | 51 | #if ENABLE_CONSOLE_GETC |
Daniel Boulby | 9516df2 | 2018-06-07 14:15:15 +0100 | [diff] [blame] | 52 | int (*const getc)(struct console *console); |
Sandrine Bailleux | f57e203 | 2023-10-11 08:38:00 +0200 | [diff] [blame] | 53 | #endif |
Jimmy Brisson | 39f9eee | 2020-08-05 13:44:05 -0500 | [diff] [blame] | 54 | void (*const flush)(struct console *console); |
Andre Przywara | c88f656 | 2020-01-25 00:54:38 +0000 | [diff] [blame] | 55 | uintptr_t base; |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 56 | /* Additional private driver data may follow here. */ |
| 57 | } console_t; |
Antonio Nino Diaz | e0f9063 | 2018-12-14 00:18:21 +0000 | [diff] [blame] | 58 | |
Yann Gautier | 0d5ca3d | 2022-12-09 14:30:55 +0100 | [diff] [blame] | 59 | extern console_t *console_list; |
| 60 | |
Antonio Nino Diaz | e0f9063 | 2018-12-14 00:18:21 +0000 | [diff] [blame] | 61 | /* offset macro assertions for console_t */ |
| 62 | #include <drivers/console_assertions.h> |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 63 | |
| 64 | /* |
Ambroise Vincent | b237bca | 2019-02-13 15:58:00 +0000 | [diff] [blame] | 65 | * Add a console_t instance to the console list. This should only be called by |
| 66 | * console drivers after they have initialized all fields in the console |
| 67 | * structure. Platforms seeking to register a new console need to call the |
| 68 | * respective console__register() function instead. |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 69 | */ |
Ambroise Vincent | b237bca | 2019-02-13 15:58:00 +0000 | [diff] [blame] | 70 | int console_register(console_t *console); |
Julius Werner | 514ae84 | 2018-12-03 17:01:30 -0800 | [diff] [blame] | 71 | /* Remove a single console_t instance from the console list. Return a pointer to |
| 72 | * the console that was removed if it was found, or NULL if not. */ |
| 73 | console_t *console_unregister(console_t *console); |
Antonio Nino Diaz | 4f31ad5 | 2018-04-30 20:14:07 +0100 | [diff] [blame] | 74 | /* Returns 1 if this console is already registered, 0 if not */ |
| 75 | int console_is_registered(console_t *console); |
| 76 | /* |
| 77 | * Set scope mask of a console that determines in what states it is active. |
| 78 | * By default they are registered with (CONSOLE_FLAG_BOOT|CONSOLE_FLAG_CRASH). |
| 79 | */ |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 80 | void console_set_scope(console_t *console, unsigned int scope); |
| 81 | |
| 82 | /* Switch to a new global console state (CONSOLE_FLAG_BOOT/RUNTIME/CRASH). */ |
| 83 | void console_switch_state(unsigned int new_state); |
| 84 | /* Output a character on all consoles registered for the current state. */ |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 85 | int console_putc(int c); |
Sandrine Bailleux | f57e203 | 2023-10-11 08:38:00 +0200 | [diff] [blame] | 86 | #if ENABLE_CONSOLE_GETC |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 87 | /* Read a character (blocking) from any console registered for current state. */ |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 88 | int console_getc(void); |
Sandrine Bailleux | f57e203 | 2023-10-11 08:38:00 +0200 | [diff] [blame] | 89 | #endif |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 90 | /* Flush all consoles registered for the current state. */ |
Jimmy Brisson | 39f9eee | 2020-08-05 13:44:05 -0500 | [diff] [blame] | 91 | void console_flush(void); |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 92 | |
Julius Werner | 53456fc | 2019-07-09 13:49:11 -0700 | [diff] [blame] | 93 | #endif /* __ASSEMBLER__ */ |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 94 | |
Antonio Nino Diaz | 5eb8837 | 2018-11-08 10:20:19 +0000 | [diff] [blame] | 95 | #endif /* CONSOLE_H */ |