|
|
99c779 |
From 0ea2e95b3ccdeb3834bec6fe22d0794a65e8c37a Mon Sep 17 00:00:00 2001
|
|
|
99c779 |
From: Jeremy Kerr <jk@ozlabs.org>
|
|
|
99c779 |
Date: Tue, 6 Sep 2016 14:57:21 +0800
|
|
|
99c779 |
Subject: [PATCH 40/43] devtree: Add support for DDR4 SPD
|
|
|
99c779 |
|
|
|
99c779 |
This patch adds support for DDR4 SPD.
|
|
|
99c779 |
|
|
|
99c779 |
Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
|
|
|
99c779 |
Signed-off-by: Vasant Hegde <hegdevasant@linux.vnet.ibm.com>
|
|
|
99c779 |
---
|
|
|
99c779 |
src/core/device-tree.cc | 51 ++++++++++++++++++++++++++++++++++++-------------
|
|
|
99c779 |
1 file changed, 38 insertions(+), 13 deletions(-)
|
|
|
99c779 |
|
|
|
99c779 |
diff --git a/src/core/device-tree.cc b/src/core/device-tree.cc
|
|
|
99c779 |
index 2672b53..48aac94 100644
|
|
|
99c779 |
--- a/src/core/device-tree.cc
|
|
|
99c779 |
+++ b/src/core/device-tree.cc
|
|
|
99c779 |
@@ -815,6 +815,7 @@ static void add_memory_bank_spd(string path, hwNode & bank)
|
|
|
99c779 |
uint16_t partno_offset;
|
|
|
99c779 |
uint16_t ver_offset;
|
|
|
99c779 |
uint16_t serial_offset;
|
|
|
99c779 |
+ uint16_t bus_width_offset;
|
|
|
99c779 |
int fd;
|
|
|
99c779 |
size_t len = 0;
|
|
|
99c779 |
dimminfo_buf dimminfo;
|
|
|
99c779 |
@@ -847,16 +848,47 @@ static void add_memory_bank_spd(string path, hwNode & bank)
|
|
|
99c779 |
close(fd);
|
|
|
99c779 |
|
|
|
99c779 |
if (dimminfo[2] >= 9) {
|
|
|
99c779 |
- mfg_loc_offset = 0x77;
|
|
|
99c779 |
+ double ns;
|
|
|
99c779 |
+ char vendor[5];
|
|
|
99c779 |
+ const char *type, *mod_type;
|
|
|
99c779 |
+
|
|
|
99c779 |
rev_offset1 = 0x92;
|
|
|
99c779 |
rev_offset2 = 0x93;
|
|
|
99c779 |
- year_offset = 0x78;
|
|
|
99c779 |
- week_offset = 0x79;
|
|
|
99c779 |
- partno_offset = 0x80;
|
|
|
99c779 |
ver_offset = 0x01;
|
|
|
99c779 |
- serial_offset = 0x7a;
|
|
|
99c779 |
|
|
|
99c779 |
- switch ((dimminfo[0x8] >> 3) & 0x3) // DDR3 error detection and correction scheme
|
|
|
99c779 |
+ if (dimminfo[0x2] >= 0xc) {
|
|
|
99c779 |
+ type = "DDR4";
|
|
|
99c779 |
+ mfg_loc_offset = 0x142;
|
|
|
99c779 |
+ year_offset = 0x143;
|
|
|
99c779 |
+ week_offset = 0x144;
|
|
|
99c779 |
+ partno_offset = 0x149;
|
|
|
99c779 |
+ bus_width_offset = 0x0d;
|
|
|
99c779 |
+ serial_offset = 0x145;
|
|
|
99c779 |
+
|
|
|
99c779 |
+ /*
|
|
|
99c779 |
+ * There is no other valid values for the medium- and fine- timebase
|
|
|
99c779 |
+ * other than (125ps, 1ps), so we hard-code those here. The fine
|
|
|
99c779 |
+ * t_{ckavg}_{min} value is signed. Divide by 2 to get from raw clock
|
|
|
99c779 |
+ * to expected data rate
|
|
|
99c779 |
+ */
|
|
|
99c779 |
+ ns = (((float)dimminfo[0x12] * 0.125) +
|
|
|
99c779 |
+ (((signed char) dimminfo[0x7d]) * 0.001)) / 2;
|
|
|
99c779 |
+ snprintf(vendor, sizeof(vendor), "%x%x", dimminfo[0x141], dimminfo[0x140]);
|
|
|
99c779 |
+ } else {
|
|
|
99c779 |
+ type = "DDR3";
|
|
|
99c779 |
+ mfg_loc_offset = 0x77;
|
|
|
99c779 |
+ year_offset = 0x78;
|
|
|
99c779 |
+ week_offset = 0x79;
|
|
|
99c779 |
+ partno_offset = 0x80;
|
|
|
99c779 |
+ serial_offset = 0x7a;
|
|
|
99c779 |
+ bus_width_offset = 0x08;
|
|
|
99c779 |
+
|
|
|
99c779 |
+ ns = (dimminfo[0xc] / 2) * (dimminfo[0xa] / (float) dimminfo[0xb]);
|
|
|
99c779 |
+ snprintf(vendor, sizeof(vendor), "%x%x", dimminfo[0x76], dimminfo[0x75]);
|
|
|
99c779 |
+ }
|
|
|
99c779 |
+
|
|
|
99c779 |
+ /* DDR3 & DDR4 error detection and correction scheme */
|
|
|
99c779 |
+ switch ((dimminfo[bus_width_offset] >> 3) & 0x3)
|
|
|
99c779 |
{
|
|
|
99c779 |
case 0x00:
|
|
|
99c779 |
bank.setConfig("errordetection", "none");
|
|
|
99c779 |
@@ -867,17 +899,10 @@ static void add_memory_bank_spd(string path, hwNode & bank)
|
|
|
99c779 |
break;
|
|
|
99c779 |
}
|
|
|
99c779 |
|
|
|
99c779 |
- double ns = (dimminfo[0xc] / 2) * (dimminfo[0xa] / (float) dimminfo[0xb]);
|
|
|
99c779 |
bank.setClock(1000000000 / ns);
|
|
|
99c779 |
-
|
|
|
99c779 |
- char vendor[3];
|
|
|
99c779 |
- snprintf(vendor, sizeof(vendor), "%x%x", dimminfo[0x76], dimminfo[0x75]);
|
|
|
99c779 |
bank.setVendor(jedec_resolve(vendor));
|
|
|
99c779 |
|
|
|
99c779 |
char description[100];
|
|
|
99c779 |
- const char *type, *mod_type;
|
|
|
99c779 |
-
|
|
|
99c779 |
- type = "DDR3";
|
|
|
99c779 |
switch(dimminfo[0x3])
|
|
|
99c779 |
{
|
|
|
99c779 |
case 0x1:
|
|
|
99c779 |
--
|
|
|
99c779 |
2.10.2
|
|
|
99c779 |
|