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