aboutsummaryrefslogtreecommitdiff
path: root/payloads/libpayload/drivers/serial/qcom_qupv3_serial.c
diff options
context:
space:
mode:
authorNico Huber <nico.h@gmx.de>2020-07-18 14:54:47 +0200
committerPatrick Georgi <pgeorgi@google.com>2020-08-24 09:13:09 +0000
commitbe842cb72d83b347bbc1c3308909f4eac286b47a (patch)
treee682a6fad4ad45d5764815b2f4754513be0c2c0d /payloads/libpayload/drivers/serial/qcom_qupv3_serial.c
parentb2eafa666cb7f5318daa61962bae62859f4e4e88 (diff)
libpayload: Cache physical location of serial-console struct
In the presence of self-relocating payloads, it's safer to keep physical addresses in `libsysinfo`. Change-Id: Icd30e95c6b8115d16dd793914fb01a1a9da1854f Signed-off-by: Nico Huber <nico.h@gmx.de> Reviewed-on: https://review.coreboot.org/c/coreboot/+/43577 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Angel Pons <th3fanbus@gmail.com> Reviewed-by: Julius Werner <jwerner@chromium.org>
Diffstat (limited to 'payloads/libpayload/drivers/serial/qcom_qupv3_serial.c')
-rw-r--r--payloads/libpayload/drivers/serial/qcom_qupv3_serial.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/payloads/libpayload/drivers/serial/qcom_qupv3_serial.c b/payloads/libpayload/drivers/serial/qcom_qupv3_serial.c
index 3d0e6de335..321ff46b42 100644
--- a/payloads/libpayload/drivers/serial/qcom_qupv3_serial.c
+++ b/payloads/libpayload/drivers/serial/qcom_qupv3_serial.c
@@ -275,7 +275,8 @@ static struct console_output_driver consout = {
static struct qup_regs *uart_base_address(void)
{
- return (void *)(uintptr_t)lib_sysinfo.serial->baseaddr;
+ const struct cb_serial *const serial = phys_to_virt(lib_sysinfo.cb_serial);
+ return phys_to_virt(serial->baseaddr);
}
static void uart_qupv3_tx_flush(void)
@@ -332,7 +333,7 @@ int serial_getchar(void)
void serial_console_init(void)
{
- if (!lib_sysinfo.serial)
+ if (!lib_sysinfo.cb_serial)
return;
console_add_output_driver(&consout);