|
@@ -1,5 +1,11 @@
|
|
|
#include "amd64_edac.h"
|
|
|
|
|
|
+static ssize_t amd64_inject_section_show(struct mem_ctl_info *mci, char *buf)
|
|
|
+{
|
|
|
+ struct amd64_pvt *pvt = mci->pvt_info;
|
|
|
+ return sprintf(buf, "0x%x\n", pvt->injection.section);
|
|
|
+}
|
|
|
+
|
|
|
/*
|
|
|
* store error injection section value which refers to one of 4 16-byte sections
|
|
|
* within a 64-byte cacheline
|
|
@@ -15,12 +21,26 @@ static ssize_t amd64_inject_section_store(struct mem_ctl_info *mci,
|
|
|
|
|
|
ret = strict_strtoul(data, 10, &value);
|
|
|
if (ret != -EINVAL) {
|
|
|
+
|
|
|
+ if (value > 3) {
|
|
|
+ amd64_printk(KERN_WARNING,
|
|
|
+ "%s: invalid section 0x%lx\n",
|
|
|
+ __func__, value);
|
|
|
+ return -EINVAL;
|
|
|
+ }
|
|
|
+
|
|
|
pvt->injection.section = (u32) value;
|
|
|
return count;
|
|
|
}
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
+static ssize_t amd64_inject_word_show(struct mem_ctl_info *mci, char *buf)
|
|
|
+{
|
|
|
+ struct amd64_pvt *pvt = mci->pvt_info;
|
|
|
+ return sprintf(buf, "0x%x\n", pvt->injection.word);
|
|
|
+}
|
|
|
+
|
|
|
/*
|
|
|
* store error injection word value which refers to one of 9 16-bit word of the
|
|
|
* 16-byte (128-bit + ECC bits) section
|
|
@@ -37,14 +57,25 @@ static ssize_t amd64_inject_word_store(struct mem_ctl_info *mci,
|
|
|
ret = strict_strtoul(data, 10, &value);
|
|
|
if (ret != -EINVAL) {
|
|
|
|
|
|
- value = (value <= 8) ? value : 0;
|
|
|
- pvt->injection.word = (u32) value;
|
|
|
+ if (value > 8) {
|
|
|
+ amd64_printk(KERN_WARNING,
|
|
|
+ "%s: invalid word 0x%lx\n",
|
|
|
+ __func__, value);
|
|
|
+ return -EINVAL;
|
|
|
+ }
|
|
|
|
|
|
+ pvt->injection.word = (u32) value;
|
|
|
return count;
|
|
|
}
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
+static ssize_t amd64_inject_ecc_vector_show(struct mem_ctl_info *mci, char *buf)
|
|
|
+{
|
|
|
+ struct amd64_pvt *pvt = mci->pvt_info;
|
|
|
+ return sprintf(buf, "0x%x\n", pvt->injection.bit_map);
|
|
|
+}
|
|
|
+
|
|
|
/*
|
|
|
* store 16 bit error injection vector which enables injecting errors to the
|
|
|
* corresponding bit within the error injection word above. When used during a
|
|
@@ -60,8 +91,14 @@ static ssize_t amd64_inject_ecc_vector_store(struct mem_ctl_info *mci,
|
|
|
ret = strict_strtoul(data, 16, &value);
|
|
|
if (ret != -EINVAL) {
|
|
|
|
|
|
- pvt->injection.bit_map = (u32) value & 0xFFFF;
|
|
|
+ if (value & 0xFFFF0000) {
|
|
|
+ amd64_printk(KERN_WARNING,
|
|
|
+ "%s: invalid EccVector: 0x%lx\n",
|
|
|
+ __func__, value);
|
|
|
+ return -EINVAL;
|
|
|
+ }
|
|
|
|
|
|
+ pvt->injection.bit_map = (u32) value;
|
|
|
return count;
|
|
|
}
|
|
|
return ret;
|
|
@@ -147,7 +184,7 @@ struct mcidev_sysfs_attribute amd64_inj_attrs[] = {
|
|
|
.name = "inject_section",
|
|
|
.mode = (S_IRUGO | S_IWUSR)
|
|
|
},
|
|
|
- .show = NULL,
|
|
|
+ .show = amd64_inject_section_show,
|
|
|
.store = amd64_inject_section_store,
|
|
|
},
|
|
|
{
|
|
@@ -155,7 +192,7 @@ struct mcidev_sysfs_attribute amd64_inj_attrs[] = {
|
|
|
.name = "inject_word",
|
|
|
.mode = (S_IRUGO | S_IWUSR)
|
|
|
},
|
|
|
- .show = NULL,
|
|
|
+ .show = amd64_inject_word_show,
|
|
|
.store = amd64_inject_word_store,
|
|
|
},
|
|
|
{
|
|
@@ -163,7 +200,7 @@ struct mcidev_sysfs_attribute amd64_inj_attrs[] = {
|
|
|
.name = "inject_ecc_vector",
|
|
|
.mode = (S_IRUGO | S_IWUSR)
|
|
|
},
|
|
|
- .show = NULL,
|
|
|
+ .show = amd64_inject_ecc_vector_show,
|
|
|
.store = amd64_inject_ecc_vector_store,
|
|
|
},
|
|
|
{
|