Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 1 | /* |
Dan Handley | 6fa89a2 | 2018-02-27 16:03:58 +0000 | [diff] [blame] | 2 | * Copyright (c) 2013-2018, 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) |
| 24 | /* Bits 8 to 31 reserved for non-scope use in future expansion. */ |
| 25 | |
| 26 | /* Returned by getc callbacks when receive FIFO is empty. */ |
| 27 | #define ERROR_NO_PENDING_CHAR (-1) |
| 28 | /* Returned by console_xxx() if no registered console implements xxx. */ |
| 29 | #define ERROR_NO_VALID_CONSOLE (-128) |
| 30 | |
| 31 | #ifndef __ASSEMBLY__ |
| 32 | |
Antonio Nino Diaz | 4b32e62 | 2018-08-16 16:52:57 +0100 | [diff] [blame] | 33 | #include <stdint.h> |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 34 | |
| 35 | typedef struct console { |
| 36 | struct console *next; |
Daniel Boulby | 99e4a48 | 2018-05-16 16:04:35 +0100 | [diff] [blame] | 37 | /* |
| 38 | * Only the low 32 bits are used. The type is u_register_t to align the |
| 39 | * fields of the struct to 64 bits in AArch64 and 32 bits in AArch32 |
| 40 | */ |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 41 | u_register_t flags; |
Daniel Boulby | 9516df2 | 2018-06-07 14:15:15 +0100 | [diff] [blame] | 42 | int (*const putc)(int character, struct console *console); |
| 43 | int (*const getc)(struct console *console); |
| 44 | int (*const flush)(struct console *console); |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 45 | /* Additional private driver data may follow here. */ |
| 46 | } console_t; |
Antonio Nino Diaz | e0f9063 | 2018-12-14 00:18:21 +0000 | [diff] [blame] | 47 | |
| 48 | /* offset macro assertions for console_t */ |
| 49 | #include <drivers/console_assertions.h> |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 50 | |
| 51 | /* |
| 52 | * NOTE: There is no publicly accessible console_register() function. Consoles |
| 53 | * are registered by directly calling the register function of a specific |
| 54 | * implementation, e.g. console_16550_register() from <uart_16550.h>. Consoles |
| 55 | * registered that way can be unregistered/reconfigured with below functions. |
| 56 | */ |
Julius Werner | 514ae84 | 2018-12-03 17:01:30 -0800 | [diff] [blame] | 57 | /* Remove a single console_t instance from the console list. Return a pointer to |
| 58 | * the console that was removed if it was found, or NULL if not. */ |
| 59 | console_t *console_unregister(console_t *console); |
Antonio Nino Diaz | 4f31ad5 | 2018-04-30 20:14:07 +0100 | [diff] [blame] | 60 | /* Returns 1 if this console is already registered, 0 if not */ |
| 61 | int console_is_registered(console_t *console); |
| 62 | /* |
| 63 | * Set scope mask of a console that determines in what states it is active. |
| 64 | * By default they are registered with (CONSOLE_FLAG_BOOT|CONSOLE_FLAG_CRASH). |
| 65 | */ |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 66 | void console_set_scope(console_t *console, unsigned int scope); |
| 67 | |
| 68 | /* Switch to a new global console state (CONSOLE_FLAG_BOOT/RUNTIME/CRASH). */ |
| 69 | void console_switch_state(unsigned int new_state); |
| 70 | /* Output a character on all consoles registered for the current state. */ |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 71 | int console_putc(int c); |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 72 | /* Read a character (blocking) from any console registered for current state. */ |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 73 | int console_getc(void); |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 74 | /* Flush all consoles registered for the current state. */ |
Antonio Nino Diaz | 8377ae4 | 2017-02-06 16:03:41 +0000 | [diff] [blame] | 75 | int console_flush(void); |
Achin Gupta | 4f6ad66 | 2013-10-25 09:08:21 +0100 | [diff] [blame] | 76 | |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 77 | #if !MULTI_CONSOLE_API |
Dan Handley | 6fa89a2 | 2018-02-27 16:03:58 +0000 | [diff] [blame] | 78 | /* REMOVED on AArch64 -- use console_<driver>_register() instead! */ |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 79 | int console_init(uintptr_t base_addr, |
Dan Handley | 6fa89a2 | 2018-02-27 16:03:58 +0000 | [diff] [blame] | 80 | unsigned int uart_clk, unsigned int baud_rate); |
| 81 | void console_uninit(void); |
Julius Werner | 94f8907 | 2017-07-31 18:15:11 -0700 | [diff] [blame] | 82 | #endif |
| 83 | |
| 84 | #endif /* __ASSEMBLY__ */ |
| 85 | |
Antonio Nino Diaz | 5eb8837 | 2018-11-08 10:20:19 +0000 | [diff] [blame] | 86 | #endif /* CONSOLE_H */ |