With the implementation of Intel NVDIMM DSM overwrite, we are adding unit
test to nfit_test for testing of overwrite operation.

Signed-off-by: Dave Jiang <dave.ji...@intel.com>
---
 drivers/acpi/nfit/intel.h        |    1 +
 tools/testing/nvdimm/test/nfit.c |   55 ++++++++++++++++++++++++++++++++++++++
 2 files changed, 56 insertions(+)

diff --git a/drivers/acpi/nfit/intel.h b/drivers/acpi/nfit/intel.h
index 943ee993e31e..3402be12f21e 100644
--- a/drivers/acpi/nfit/intel.h
+++ b/drivers/acpi/nfit/intel.h
@@ -19,6 +19,7 @@ extern const struct nvdimm_security_ops intel_security_ops;
 #define ND_INTEL_STATUS_INVALID_PASS   11
 #define ND_INTEL_STATUS_OVERWRITE_UNSUPPORTED  0x10007
 #define ND_INTEL_STATUS_OQUERY_INPROGRESS      0x10007
+#define ND_INTEL_STATUS_OQUERY_SEQUENCE_ERR    0x20007
 
 #define ND_INTEL_SEC_STATE_ENABLED     0x02
 #define ND_INTEL_SEC_STATE_LOCKED      0x04
diff --git a/tools/testing/nvdimm/test/nfit.c b/tools/testing/nvdimm/test/nfit.c
index 61ad16beef6d..71f53e38d3ce 100644
--- a/tools/testing/nvdimm/test/nfit.c
+++ b/tools/testing/nvdimm/test/nfit.c
@@ -181,6 +181,7 @@ struct nfit_dimm_dev {
 struct nfit_test_sec {
        u8 state;
        u8 passphrase[32];
+       u64 overwrite_end_time;
 };
 
 struct nfit_test {
@@ -1075,6 +1076,50 @@ static int nd_intel_test_cmd_secure_erase(struct 
nfit_test *t,
        return 0;
 }
 
+static int nd_intel_test_cmd_overwrite(struct nfit_test *t,
+               struct nd_intel_overwrite *nd_cmd,
+               unsigned int buf_len, int idx)
+{
+       struct device *dev = &t->pdev.dev;
+       struct nfit_test_sec *sec = &t->sec[idx];
+
+       if ((sec->state & ND_INTEL_SEC_STATE_ENABLED) &&
+                       memcmp(nd_cmd->passphrase, sec->passphrase,
+                               ND_INTEL_PASSPHRASE_SIZE) != 0) {
+               nd_cmd->status = ND_INTEL_STATUS_INVALID_PASS;
+               dev_dbg(dev, "overwrite: wrong passphrase\n");
+               return 0;
+       }
+
+       memset(sec->passphrase, 0, ND_INTEL_PASSPHRASE_SIZE);
+       sec->state = ND_INTEL_SEC_STATE_OVERWRITE;
+       dev_dbg(dev, "overwrite progressing.\n");
+       sec->overwrite_end_time = get_jiffies_64() + 5 * HZ;
+
+       return 0;
+}
+
+static int nd_intel_test_cmd_query_overwrite(struct nfit_test *t,
+               struct nd_intel_query_overwrite *nd_cmd,
+               unsigned int buf_len, int idx)
+{
+       struct device *dev = &t->pdev.dev;
+       struct nfit_test_sec *sec = &t->sec[idx];
+
+       if (!(sec->state & ND_INTEL_SEC_STATE_OVERWRITE)) {
+               nd_cmd->status = ND_INTEL_STATUS_OQUERY_SEQUENCE_ERR;
+               return 0;
+       }
+
+       if (time_is_before_jiffies64(sec->overwrite_end_time)) {
+               sec->overwrite_end_time = 0;
+               sec->state = 0;
+               dev_dbg(dev, "overwrite is complete\n");
+       } else
+               nd_cmd->status = ND_INTEL_STATUS_OQUERY_INPROGRESS;
+       return 0;
+}
+
 static int get_dimm(struct nfit_mem *nfit_mem, unsigned int func)
 {
        int i;
@@ -1146,6 +1191,14 @@ static int nfit_test_ctl(struct nvdimm_bus_descriptor 
*nd_desc,
                                rc = nd_intel_test_cmd_secure_erase(t,
                                                buf, buf_len, i - t->dcr_idx);
                                break;
+                       case NVDIMM_INTEL_OVERWRITE:
+                               rc = nd_intel_test_cmd_overwrite(t,
+                                               buf, buf_len, i - t->dcr_idx);
+                               break;
+                       case NVDIMM_INTEL_QUERY_OVERWRITE:
+                               rc = nd_intel_test_cmd_query_overwrite(t,
+                                               buf, buf_len, i - t->dcr_idx);
+                               break;
                        case ND_INTEL_ENABLE_LSS_STATUS:
                                rc = nd_intel_test_cmd_set_lss_status(t,
                                                buf, buf_len);
@@ -2391,6 +2444,8 @@ static void nfit_test0_setup(struct nfit_test *t)
        set_bit(NVDIMM_INTEL_UNLOCK_UNIT, &acpi_desc->dimm_cmd_force_en);
        set_bit(NVDIMM_INTEL_FREEZE_LOCK, &acpi_desc->dimm_cmd_force_en);
        set_bit(NVDIMM_INTEL_SECURE_ERASE, &acpi_desc->dimm_cmd_force_en);
+       set_bit(NVDIMM_INTEL_OVERWRITE, &acpi_desc->dimm_cmd_force_en);
+       set_bit(NVDIMM_INTEL_QUERY_OVERWRITE, &acpi_desc->dimm_cmd_force_en);
 }
 
 static void nfit_test1_setup(struct nfit_test *t)

_______________________________________________
Linux-nvdimm mailing list
Linux-nvdimm@lists.01.org
https://lists.01.org/mailman/listinfo/linux-nvdimm

Reply via email to