Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/acpi Handle more plcom-style console types
details: https://anonhg.NetBSD.org/src/rev/a7c8e067fcf1
branches: trunk
changeset: 994025:a7c8e067fcf1
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Mon Oct 15 20:09:06 2018 +0000
description:
Handle more plcom-style console types
diffstat:
sys/arch/arm/acpi/acpi_platform.c | 60 +++++++++++++++++++++++++++++++-------
1 files changed, 48 insertions(+), 12 deletions(-)
diffs (95 lines):
diff -r ef1589e504cf -r a7c8e067fcf1 sys/arch/arm/acpi/acpi_platform.c
--- a/sys/arch/arm/acpi/acpi_platform.c Mon Oct 15 19:32:48 2018 +0000
+++ b/sys/arch/arm/acpi/acpi_platform.c Mon Oct 15 20:09:06 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_platform.c,v 1.2 2018/10/13 00:08:29 jmcneill Exp $ */
+/* $NetBSD: acpi_platform.c,v 1.3 2018/10/15 20:09:06 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_platform.c,v 1.2 2018/10/13 00:08:29 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_platform.c,v 1.3 2018/10/15 20:09:06 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -63,7 +63,16 @@
#include <dev/acpi/acpivar.h>
#include <arch/arm/acpi/acpi_table.h>
-#define SPCR_INTERFACE_TYPE_PL011 0x0003
+#define SPCR_INTERFACE_TYPE_PL011 0x0003
+#define SPCR_INTERFACE_TYPE_SBSA_32BIT 0x000d
+#define SPCR_INTERFACE_TYPE_SBSA_GENERIC 0x000e
+#define SPCR_INTERFACE_TYPE_BCM2835 0x0010
+
+#define SPCR_BAUD_UNKNOWN 0
+#define SPCR_BAUD_9600 3
+#define SPCR_BAUD_19200 4
+#define SPCR_BAUD_57600 6
+#define SPCR_BAUD_115200 7
extern struct bus_space arm_generic_bs_tag;
@@ -90,22 +99,49 @@
ACPI_TABLE_SPCR *spcr;
ACPI_TABLE_FADT *fadt;
ACPI_TABLE_MADT *madt;
+ int baud_rate;
/*
* Setup serial console device
*/
if (ACPI_SUCCESS(acpi_table_find(ACPI_SIG_SPCR, (void **)&spcr))) {
- if (spcr->InterfaceType == SPCR_INTERFACE_TYPE_PL011 &&
- spcr->SerialPort.SpaceId == ACPI_ADR_SPACE_SYSTEM_MEMORY &&
+ if (spcr->SerialPort.SpaceId == ACPI_ADR_SPACE_SYSTEM_MEMORY &&
spcr->SerialPort.Address != 0) {
+ switch (spcr->InterfaceType) {
+ case SPCR_INTERFACE_TYPE_PL011:
+ case SPCR_INTERFACE_TYPE_SBSA_32BIT:
+ case SPCR_INTERFACE_TYPE_SBSA_GENERIC:
+ case SPCR_INTERFACE_TYPE_BCM2835:
+ plcom_console.pi_type = PLCOM_TYPE_PL011;
+ plcom_console.pi_iot = &arm_generic_bs_tag;
+ plcom_console.pi_iobase = spcr->SerialPort.Address;
+ plcom_console.pi_size = PL011COM_UART_SIZE;
+ if (spcr->InterfaceType == SPCR_INTERFACE_TYPE_SBSA_32BIT) {
+ plcom_console.pi_flags = PLC_FLAG_32BIT_ACCESS;
+ } else {
+ plcom_console.pi_flags = ACPI_ACCESS_BIT_WIDTH(spcr->SerialPort.AccessWidth) == 8 ?
+ 0 : PLC_FLAG_32BIT_ACCESS;
+ }
+ switch (spcr->BaudRate) {
+ case SPCR_BAUD_9600:
+ baud_rate = 9600;
+ break;
+ case SPCR_BAUD_19200:
+ baud_rate = 19200;
+ break;
+ case SPCR_BAUD_57600:
+ baud_rate = 57600;
+ break;
+ case SPCR_BAUD_115200:
+ case SPCR_BAUD_UNKNOWN:
+ default:
+ baud_rate = 115200;
+ break;
+ }
- plcom_console.pi_type = PLCOM_TYPE_PL011;
- plcom_console.pi_flags = PLC_FLAG_32BIT_ACCESS;
- plcom_console.pi_iot = &arm_generic_bs_tag;
- plcom_console.pi_iobase = spcr->SerialPort.Address;
- plcom_console.pi_size = PL011COM_UART_SIZE;
-
- plcomcnattach(&plcom_console, 115200 /* XXX */, 0, TTYDEF_CFLAG, -1);
+ plcomcnattach(&plcom_console, baud_rate, 0, TTYDEF_CFLAG, -1);
+ break;
+ }
}
acpi_table_unmap((ACPI_TABLE_HEADER *)spcr);
}
Home |
Main Index |
Thread Index |
Old Index