summaryrefslogtreecommitdiff
path: root/src/superio/smsc/sch555x/sch555x.h
diff options
context:
space:
mode:
authorMate Kukri <kukri.mate@gmail.com>2021-06-06 14:00:57 +0100
committerFelix Held <felix-coreboot@felixheld.de>2023-12-01 17:40:11 +0000
commit62c25351c101a3d5c7104aa6fc34e71990478dde (patch)
tree16895ba4f9af99c1d5de2be49ee8cb7409023c9d /src/superio/smsc/sch555x/sch555x.h
parentb9523a4281a568afa62c4755f6b3e99b0924d64a (diff)
superio/smsc: Add support for the SCH555x series
Used by the OptiPlex 3020/7020/9020: - EMI and Runtime registers work - UART1 works (including IRQs) - PS/2 keyboard and mouse untested Signed-off-by: Mate Kukri <kukri.mate@gmail.com> Change-Id: I9323198f1139cd0c3dd37f977ae7693b721654f4 Reviewed-on: https://review.coreboot.org/c/coreboot/+/64359 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Martin L Roth <gaumless@gmail.com>
Diffstat (limited to 'src/superio/smsc/sch555x/sch555x.h')
-rw-r--r--src/superio/smsc/sch555x/sch555x.h68
1 files changed, 68 insertions, 0 deletions
diff --git a/src/superio/smsc/sch555x/sch555x.h b/src/superio/smsc/sch555x/sch555x.h
new file mode 100644
index 0000000000..4af95eca1c
--- /dev/null
+++ b/src/superio/smsc/sch555x/sch555x.h
@@ -0,0 +1,68 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+
+#ifndef SUPERIO_SCH555x_H
+#define SUPERIO_SCH555x_H
+
+#include <types.h>
+
+// Global registers
+#define SCH555x_DEVICE_ID 0x20
+#define SCH555x_DEVICE_REV 0x21
+#define SCH555x_DEVICE_MODE 0x24
+
+// Logical device numbers
+#define SCH555x_LDN_EMI 0x00
+#define SCH555x_LDN_8042 0x01
+#define SCH555x_LDN_UART1 0x07
+#define SCH555x_LDN_UART2 0x08
+#define SCH555x_LDN_RUNTIME 0x0a
+#define SCH555x_LDN_FDC 0x0b
+#define SCH555x_LDN_LPCI 0x0c
+#define SCH555x_LDN_PP 0x11
+#define SCH555x_LDN_GLOBAL 0x3f
+
+// LPC interface registers
+#define SCH555x_LPCI_IRQ(i) (0x40 + (i))
+// DMA channel register is 2 bytes, we care about the second byte
+#define SCH555x_LPCI_DMA(i) (0x50 + (i) * 2 + 1)
+// BAR offset (inside LPCI) for each LDN
+#define SCH555x_LPCI_LPCI_BAR 0x60
+#define SCH555x_LPCI_EMI_BAR 0x64
+#define SCH555x_LPCI_UART1_BAR 0x68
+#define SCH555x_LPCI_UART2_BAR 0x6c
+#define SCH555x_LPCI_RUNTIME_BAR 0x70
+#define SCH555x_LPCI_8042_BAR 0x78
+#define SCH555x_LPCI_FDC_BAR 0x7c
+#define SCH555x_LPCI_PP_BAR 0x80
+
+// Runtime registers (in I/O space)
+#define SCH555x_RUNTIME_PME_STS 0x00
+#define SCH555x_RUNTIME_PME_EN 0x01
+#define SCH555x_RUNTIME_PME_EN1 0x05
+#define SCH555x_RUNTIME_LED 0x25
+// NOTE: not in the SCH5627P datasheet but Dell's firmware writes to it
+#define SCH555x_RUNTIME_UNK1 0x35
+
+// Needed in the bootblock, thus we map them at a fixed address
+#define SCH555x_EMI_IOBASE 0xa00
+#define SCH555x_RUNTIME_IOBASE 0xa40
+
+/*
+ * EMI access
+ */
+
+uint8_t sch555x_emi_read8(uint16_t addr);
+uint16_t sch555x_emi_read16(uint16_t addr);
+uint32_t sch555x_emi_read32(uint16_t addr);
+void sch555x_emi_write8(uint16_t addr, uint8_t val);
+void sch555x_emi_write16(uint16_t addr, uint16_t val);
+void sch555x_emi_write32(uint16_t addr, uint32_t val);
+
+/*
+ * Bootblock entry points
+ */
+
+void sch555x_early_init(pnp_devfn_t global_dev);
+void sch555x_enable_serial(pnp_devfn_t uart_dev, uint16_t serial_iobase);
+
+#endif