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