summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--util/inteltool/memory.c83
1 files changed, 3 insertions, 80 deletions
diff --git a/util/inteltool/memory.c b/util/inteltool/memory.c
index 43f621e84e..a1c7dab10b 100644
--- a/util/inteltool/memory.c
+++ b/util/inteltool/memory.c
@@ -23,47 +23,6 @@
#include <inttypes.h>
#include "inteltool.h"
-static const io_register_t sandybridge_mch_registers[] = {
-/* Channel 0 */
- { 0x4000, 4, "TC_DBP_C0" }, // Timing of DDR Bin Parameters
- { 0x4004, 4, "TC_RAP_C0" }, // Timing of DDR Regular Access Parameters
- { 0x4028, 4, "SC_IO_LATENCY_C0" }, // IO Latency Configuration
- { 0x42A4, 4, "TC_SRFTP_C0" }, // Self-Refresh Timing Parameters
- { 0x40B0, 4, "PM_PDWN_config_C0" }, // Power-down Configuration
- { 0x4294, 4, "TC_RFP_C0" }, // Refresh Parameters
- { 0x4298, 4, "TC_RFTP_C0" }, // Refresh Timing Parameters
-/* Channel 1 */
- { 0x4400, 4, "TC_DBP_C1" }, // Timing of DDR Bin Parameters
- { 0x4404, 4, "TC_RAP_C1" }, // Timing of DDR Regular Access Parameters
- { 0x4428, 4, "SC_IO_LATENCY_C1" }, // IO Latency Configuration
- { 0x46A4, 4, "TC_SRFTP_C1" }, // Self-Refresh Timing Parameters
- { 0x44B0, 4, "PM_PDWN_config_C1" }, // Power-down Configuration
- { 0x4694, 4, "TC_RFP_C1" }, // Refresh Parameters
- { 0x4698, 4, "TC_RFTP_C1" }, // Refresh Timing Parameters
-/* Integrated Memory Peripheral Hub (IMPH) */
- { 0x740C, 4, "CRDTCTL3" }, // Credit Control 3
-/* Common Registers */
- { 0x5000, 4, "MAD_CHNL" }, // Address decoder Channel Configuration
- { 0x5004, 4, "MAD_DIMM_ch0" }, // Address Decode Channel 0
- { 0x5008, 4, "MAD_DIMM_ch1" }, // Address Decode Channel 1
- { 0x5060, 4, "PM_SREF_config" }, // Self Refresh Configuration
-/* MMIO Registers Broadcast Group */
- { 0x4CB0, 4, "PM_PDWN_config" }, // Power-down Configuration
- { 0x4F84, 4, "PM_CMD_PWR" }, // Power Management Command Power
- { 0x4F88, 4, "PM_BW_LIMIT_config" }, // BW Limit Configuration
- { 0x4F8C, 4, "RESERVED" }, // Reserved, default value - 0xFF1D1519
-/* PCU MCHBAR Registers */
- { 0x5880, 4, "MEM_TRML_ESTIMATION_CONFIG" }, // Memory Thermal Estimation Configuration
- { 0x5884, 4, "RESERVED" }, // Reserved
- { 0x5888, 4, "MEM_TRML_THRESHOLDS_CONFIG" }, // Memory Thermal Thresholds Configuration
- { 0x58A0, 4, "MEM_TRML_STATUS_REPORT" }, // Memory Thermal Status Report
- { 0x58A4, 4, "MEM_TRML_TEMPERATURE_REPORT" }, // Memory Thermal Temperature Report
- { 0x58A8, 4, "MEM_TRML_INTERRUPT" }, // Memory Thermal Interrupt
- { 0x5948, 4, "GT_PERF_STATUS" }, // GT Performance Status
- { 0x5998, 4, "RP_STATE_CAP" }, // RP State Capability
- { 0x5D10, 8, "SSKPD" }, // Sticky Scratchpad Data
-};
-
volatile uint8_t *mchbar;
static void write_mchbar32 (uint32_t addr, uint32_t val)
@@ -156,7 +115,6 @@ int print_mchbar(struct pci_dev *nb, struct pci_access *pacc)
{
int i, size = (16 * 1024);
uint64_t mchbar_phys;
- const io_register_t *mch_registers = NULL;
struct pci_dev *nb_device6; /* "overflow device" on i865 */
uint16_t pcicmd6;
@@ -246,11 +204,8 @@ int print_mchbar(struct pci_dev *nb, struct pci_access *pacc)
mchbar_phys = pci_read_long(nb, 0x48);
mchbar_phys |= ((uint64_t)pci_read_long(nb, 0x4c)) << 32;
mchbar_phys &= 0x0000000fffffc000UL; /* 35:14 */
- mch_registers = NULL; /* TODO: 322812 */
break;
case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN:
- mch_registers = sandybridge_mch_registers;
- size = ARRAY_SIZE(sandybridge_mch_registers);
case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_A: /* pretty printing not implemented yet */
case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_B:
case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_C:
@@ -280,41 +235,9 @@ int print_mchbar(struct pci_dev *nb, struct pci_access *pacc)
else
printf("MCHBAR = 0x%08" PRIx64 " (MEM)\n\n", mchbar_phys);
- if (mch_registers != NULL) {
- printf("%d registers:\n", size);
- for (i = 0; i < size; i++) {
- switch (mch_registers[i].size) {
- case 8:
- printf("mchbase+0x%04x: 0x%016"PRIx64" (%s)\n",
- mch_registers[i].addr,
- *(uint64_t *)(mchbar+mch_registers[i].addr),
- mch_registers[i].name);
- break;
- case 4:
- printf("mchbase+0x%04x: 0x%08"PRIx32" (%s)\n",
- mch_registers[i].addr,
- *(uint32_t *)(mchbar+mch_registers[i].addr),
- mch_registers[i].name);
- break;
- case 2:
- printf("mchbase+0x%04x: 0x%04"PRIx16" (%s)\n",
- mch_registers[i].addr,
- *(uint16_t *)(mchbar+mch_registers[i].addr),
- mch_registers[i].name);
- break;
- case 1:
- printf("mchbase+0x%04x: 0x%02"PRIx8" (%s)\n",
- mch_registers[i].addr,
- *(uint8_t *)(mchbar+mch_registers[i].addr),
- mch_registers[i].name);
- break;
- }
- }
- } else {
- for (i = 0; i < size; i += 4) {
- if (*(uint32_t *)(mchbar + i))
- printf("0x%04x: 0x%08"PRIx32"\n", i, *(uint32_t *)(mchbar+i));
- }
+ for (i = 0; i < size; i += 4) {
+ if (*(uint32_t *)(mchbar + i))
+ printf("0x%04x: 0x%08"PRIx32"\n", i, *(uint32_t *)(mchbar+i));
}
if (nb->device_id == PCI_DEVICE_ID_INTEL_CORE_1ST_GEN) {