summaryrefslogtreecommitdiffstats
path: root/util/inteltool/ahci.c
diff options
context:
space:
mode:
authorMichael Niewöhner <foss@mniewoehner.de>2020-03-13 21:18:04 +0100
committerFelix Held <felix-coreboot@felixheld.de>2020-03-16 22:41:33 +0000
commitfe8170f909dc682e529c8fe8d9dadf3b13acdef6 (patch)
tree8975a15a1e27447b0819402afdcac3bb08d5022a /util/inteltool/ahci.c
parente6cff0d8304b650f0371938fdb9f545032c8ce16 (diff)
downloadcoreboot-fe8170f909dc682e529c8fe8d9dadf3b13acdef6.tar.gz
coreboot-fe8170f909dc682e529c8fe8d9dadf3b13acdef6.tar.bz2
coreboot-fe8170f909dc682e529c8fe8d9dadf3b13acdef6.zip
util/inteltool: ahci: add Sunrise Point config and SIR registers
This adds the Sunrise Point AHCI config and SIR registers from doc#332691-003EN. Change-Id: Id4a462d625194a6ccfdb88fb415d5eb278f2900a Signed-off-by: Michael Niewöhner <foss@mniewoehner.de> Reviewed-on: https://review.coreboot.org/c/coreboot/+/39506 Reviewed-by: Felix Held <felix-coreboot@felixheld.de> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Diffstat (limited to 'util/inteltool/ahci.c')
-rw-r--r--util/inteltool/ahci.c52
1 files changed, 52 insertions, 0 deletions
diff --git a/util/inteltool/ahci.c b/util/inteltool/ahci.c
index 3a18993e013a..90a1617f8f1d 100644
--- a/util/inteltool/ahci.c
+++ b/util/inteltool/ahci.c
@@ -34,6 +34,53 @@ static const char *port_ctl_regs[] = {
"PxFBS", "PxDEVSLP", "Reserved"
};
+static const io_register_t sunrise_ahci_cfg_registers[] = {
+ {0x0, 4, "ID"},
+ {0x4, 2, "CMD"},
+ {0x6, 2, "STS"},
+ {0x8, 1, "RID"},
+ {0x9, 1, "PI"},
+ {0xa, 2, "CC"},
+ {0xc, 1, "CLS"},
+ {0xd, 1, "MLT"},
+ {0xe, 1, "HTYPE"},
+ {0x10, 4, "MXTBA"},
+ {0x14, 4, "MXPBA"},
+ {0x20, 4, "AIDPBA"},
+ {0x24, 4, "ABAR"},
+ {0x2c, 4, "SS"},
+ {0x34, 1, "CAP"},
+ {0x3c, 2, "INTR"},
+ {0x70, 2, "PID"},
+ {0x72, 2, "PC"},
+ {0x74, 2, "PMCS"},
+ {0x80, 2, "MID"},
+ {0x82, 2, "MC"},
+ {0x84, 4, "MA"},
+ {0x88, 2, "MD"},
+ {0x90, 4, "MAP"},
+ {0x94, 4, "PCS"},
+ {0x9c, 4, "SATAGC"},
+ {0xa0, 1, "SIRI"},
+ {0xa4, 4, "SIRD"},
+ {0xa8, 4, "SATACR0"},
+ {0xac, 4, "SATACR1"},
+ {0xc0, 4, "SP"},
+ {0xd0, 2, "MXID"},
+ {0xd2, 2, "MXC"},
+ {0xd4, 4, "MXT"},
+ {0xd8, 4, "MXP"},
+ {0xe0, 4, "BFCS"},
+ {0xe4, 4, "BFTD1"},
+ {0xe8, 4, "BFTD2"},
+};
+
+static const io_register_t sunrise_ahci_sir_registers[] = {
+ {0x80, 4, "SQUELCH"},
+ {0x90, 4, "SATA_MPHY_PG"},
+ {0xa4, 4, "OOBRETR"},
+};
+
#define NUM_GHC (sizeof(ghc_regs)/sizeof(ghc_regs[0]))
#define NUM_PORTCTL (sizeof(port_ctl_regs)/sizeof(port_ctl_regs[0]))
@@ -76,6 +123,11 @@ int print_ahci(struct pci_dev *ahci)
case PCI_DEVICE_ID_INTEL_SUNRISEPOINT_SATA:
case PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_SATA:
ahci_registers_size = 0x800;
+ ahci_sir_offset = 0xa0;
+ ahci_cfg_registers = sunrise_ahci_cfg_registers;
+ ahci_cfg_registers_size = ARRAY_SIZE(sunrise_ahci_cfg_registers);
+ ahci_sir_registers = sunrise_ahci_sir_registers;
+ ahci_sir_registers_size = ARRAY_SIZE(sunrise_ahci_sir_registers);
break;
default:
ahci_registers_size = 0x400;