All that is missing is a helper to go from an nvdimm to its bus. With
the new nvdimm_to_bus() and nvdimm_ctl() helpers some boilerplate can be
consolidated.

Signed-off-by: Dan Williams <dan.j.willi...@intel.com>
---
 drivers/acpi/nfit/intel.c  |   46 +++++++++++++++-----------------------------
 drivers/nvdimm/bus.c       |    6 ++++++
 drivers/nvdimm/dimm_devs.c |   25 +++++++++---------------
 include/linux/libnvdimm.h  |   28 +++++++++++++++------------
 4 files changed, 47 insertions(+), 58 deletions(-)

diff --git a/drivers/acpi/nfit/intel.c b/drivers/acpi/nfit/intel.c
index 419a7d54d4e8..70bccb0c57e2 100644
--- a/drivers/acpi/nfit/intel.c
+++ b/drivers/acpi/nfit/intel.c
@@ -18,10 +18,9 @@
 #include "intel.h"
 #include "nfit.h"
 
-static int intel_dimm_security_erase(struct nvdimm_bus *nvdimm_bus,
-               struct nvdimm *nvdimm, const struct nvdimm_key_data *nkey)
+static int intel_dimm_security_erase(struct nvdimm *nvdimm,
+               const struct nvdimm_key_data *nkey)
 {
-       struct nvdimm_bus_descriptor *nd_desc = to_nd_desc(nvdimm_bus);
        int cmd_rc, rc = 0;
        struct nfit_mem *nfit_mem = nvdimm_provider_data(nvdimm);
        struct {
@@ -47,8 +46,7 @@ static int intel_dimm_security_erase(struct nvdimm_bus 
*nvdimm_bus,
        wbinvd_on_all_cpus();
        memcpy(nd_cmd.cmd.passphrase, nkey->data,
                        sizeof(nd_cmd.cmd.passphrase));
-       rc = nd_desc->ndctl(nd_desc, nvdimm, ND_CMD_CALL, &nd_cmd,
-                       sizeof(nd_cmd), &cmd_rc);
+       rc = nvdimm_ctl(nvdimm, ND_CMD_CALL, &nd_cmd, sizeof(nd_cmd), &cmd_rc);
        if (rc < 0)
                goto out;
        if (cmd_rc < 0) {
@@ -75,10 +73,8 @@ static int intel_dimm_security_erase(struct nvdimm_bus 
*nvdimm_bus,
        return rc;
 }
 
-static int intel_dimm_security_freeze_lock(struct nvdimm_bus *nvdimm_bus,
-               struct nvdimm *nvdimm)
+static int intel_dimm_security_freeze_lock(struct nvdimm *nvdimm)
 {
-       struct nvdimm_bus_descriptor *nd_desc = to_nd_desc(nvdimm_bus);
        int cmd_rc, rc = 0;
        struct nfit_mem *nfit_mem = nvdimm_provider_data(nvdimm);
        struct {
@@ -100,8 +96,7 @@ static int intel_dimm_security_freeze_lock(struct nvdimm_bus 
*nvdimm_bus,
        if (!test_bit(NVDIMM_INTEL_FREEZE_LOCK, &nfit_mem->dsm_mask))
                return -ENOTTY;
 
-       rc = nd_desc->ndctl(nd_desc, nvdimm, ND_CMD_CALL, &nd_cmd,
-                       sizeof(nd_cmd), &cmd_rc);
+       rc = nvdimm_ctl(nvdimm, ND_CMD_CALL, &nd_cmd, sizeof(nd_cmd), &cmd_rc);
        if (rc < 0)
                goto out;
        if (cmd_rc < 0) {
@@ -122,10 +117,9 @@ static int intel_dimm_security_freeze_lock(struct 
nvdimm_bus *nvdimm_bus,
        return rc;
 }
 
-static int intel_dimm_security_disable(struct nvdimm_bus *nvdimm_bus,
-               struct nvdimm *nvdimm, const struct nvdimm_key_data *nkey)
+static int intel_dimm_security_disable(struct nvdimm *nvdimm,
+               const struct nvdimm_key_data *nkey)
 {
-       struct nvdimm_bus_descriptor *nd_desc = to_nd_desc(nvdimm_bus);
        int cmd_rc, rc = 0;
        struct nfit_mem *nfit_mem = nvdimm_provider_data(nvdimm);
        struct {
@@ -149,8 +143,7 @@ static int intel_dimm_security_disable(struct nvdimm_bus 
*nvdimm_bus,
 
        memcpy(nd_cmd.cmd.passphrase, nkey->data,
                        sizeof(nd_cmd.cmd.passphrase));
-       rc = nd_desc->ndctl(nd_desc, nvdimm, ND_CMD_CALL, &nd_cmd,
-                       sizeof(nd_cmd), &cmd_rc);
+       rc = nvdimm_ctl(nvdimm, ND_CMD_CALL, &nd_cmd, sizeof(nd_cmd), &cmd_rc);
        if (rc < 0)
                goto out;
        if (cmd_rc < 0) {
@@ -182,12 +175,10 @@ static int intel_dimm_security_disable(struct nvdimm_bus 
*nvdimm_bus,
  * if the old passphrase is NULL. This typically happens when we are
  * enabling security from the disabled state.
  */
-static int intel_dimm_security_update_passphrase(
-               struct nvdimm_bus *nvdimm_bus, struct nvdimm *nvdimm,
+static int intel_dimm_security_update_passphrase(struct nvdimm *nvdimm,
                const struct nvdimm_key_data *old_data,
                const struct nvdimm_key_data *new_data)
 {
-       struct nvdimm_bus_descriptor *nd_desc = to_nd_desc(nvdimm_bus);
        int cmd_rc, rc = 0;
        struct nfit_mem *nfit_mem = nvdimm_provider_data(nvdimm);
        struct {
@@ -216,8 +207,7 @@ static int intel_dimm_security_update_passphrase(
                memset(nd_cmd.cmd.old_pass, 0, sizeof(nd_cmd.cmd.old_pass));
        memcpy(nd_cmd.cmd.new_pass, new_data->data,
                        sizeof(nd_cmd.cmd.new_pass));
-       rc = nd_desc->ndctl(nd_desc, nvdimm, ND_CMD_CALL, &nd_cmd,
-                       sizeof(nd_cmd), &cmd_rc);
+       rc = nvdimm_ctl(nvdimm, ND_CMD_CALL, &nd_cmd, sizeof(nd_cmd), &cmd_rc);
        if (rc < 0)
                goto out;
        if (cmd_rc < 0) {
@@ -241,10 +231,9 @@ static int intel_dimm_security_update_passphrase(
        return rc;
 }
 
-static int intel_dimm_security_unlock(struct nvdimm_bus *nvdimm_bus,
-               struct nvdimm *nvdimm, const struct nvdimm_key_data *nkey)
+static int intel_dimm_security_unlock(struct nvdimm *nvdimm,
+               const struct nvdimm_key_data *nkey)
 {
-       struct nvdimm_bus_descriptor *nd_desc = to_nd_desc(nvdimm_bus);
        int cmd_rc, rc = 0;
        struct nfit_mem *nfit_mem = nvdimm_provider_data(nvdimm);
        struct {
@@ -268,8 +257,7 @@ static int intel_dimm_security_unlock(struct nvdimm_bus 
*nvdimm_bus,
 
        memcpy(nd_cmd.cmd.passphrase, nkey->data,
                        sizeof(nd_cmd.cmd.passphrase));
-       rc = nd_desc->ndctl(nd_desc, nvdimm, ND_CMD_CALL, &nd_cmd,
-                       sizeof(nd_cmd), &cmd_rc);
+       rc = nvdimm_ctl(nvdimm, ND_CMD_CALL, &nd_cmd, sizeof(nd_cmd), &cmd_rc);
        if (rc < 0)
                goto out;
        if (cmd_rc < 0) {
@@ -300,10 +288,9 @@ static int intel_dimm_security_unlock(struct nvdimm_bus 
*nvdimm_bus,
        return rc;
 }
 
-static int intel_dimm_security_state(struct nvdimm_bus *nvdimm_bus,
-               struct nvdimm *nvdimm, enum nvdimm_security_state *state)
+static int intel_dimm_security_state(struct nvdimm *nvdimm,
+               enum nvdimm_security_state *state)
 {
-       struct nvdimm_bus_descriptor *nd_desc = to_nd_desc(nvdimm_bus);
        int cmd_rc, rc = 0;
        struct nfit_mem *nfit_mem = nvdimm_provider_data(nvdimm);
        struct {
@@ -331,8 +318,7 @@ static int intel_dimm_security_state(struct nvdimm_bus 
*nvdimm_bus,
        }
 
        *state = NVDIMM_SECURITY_DISABLED;
-       rc = nd_desc->ndctl(nd_desc, nvdimm, ND_CMD_CALL, &nd_cmd,
-                       sizeof(nd_cmd), &cmd_rc);
+       rc = nvdimm_ctl(nvdimm, ND_CMD_CALL, &nd_cmd, sizeof(nd_cmd), &cmd_rc);
        if (rc < 0)
                goto out;
        if (cmd_rc < 0) {
diff --git a/drivers/nvdimm/bus.c b/drivers/nvdimm/bus.c
index 9743d8083538..eae17d8ee539 100644
--- a/drivers/nvdimm/bus.c
+++ b/drivers/nvdimm/bus.c
@@ -331,6 +331,12 @@ struct nvdimm_bus *to_nvdimm_bus(struct device *dev)
 }
 EXPORT_SYMBOL_GPL(to_nvdimm_bus);
 
+struct nvdimm_bus *nvdimm_to_bus(struct nvdimm *nvdimm)
+{
+       return to_nvdimm_bus(nvdimm->dev.parent);
+}
+EXPORT_SYMBOL_GPL(nvdimm_to_bus);
+
 struct nvdimm_bus *nvdimm_bus_register(struct device *parent,
                struct nvdimm_bus_descriptor *nd_desc)
 {
diff --git a/drivers/nvdimm/dimm_devs.c b/drivers/nvdimm/dimm_devs.c
index 752149c9450c..06d0395c1f43 100644
--- a/drivers/nvdimm/dimm_devs.c
+++ b/drivers/nvdimm/dimm_devs.c
@@ -174,13 +174,11 @@ static int nvdimm_check_key_len(unsigned short len)
 int nvdimm_security_get_state(struct device *dev)
 {
        struct nvdimm *nvdimm = to_nvdimm(dev);
-       struct nvdimm_bus *nvdimm_bus = walk_to_nvdimm_bus(dev);
 
        if (!nvdimm->security_ops)
                return 0;
 
-       return nvdimm->security_ops->state(nvdimm_bus, nvdimm,
-                       &nvdimm->state);
+       return nvdimm->security_ops->state(nvdimm, &nvdimm->state);
 }
 
 static int nvdimm_security_erase(struct device *dev, unsigned int keyid)
@@ -236,8 +234,8 @@ static int nvdimm_security_erase(struct device *dev, 
unsigned int keyid)
 
        down_read(&key->sem);
        payload = key->payload.data[0];
-       rc = nvdimm->security_ops->erase(nvdimm_bus, nvdimm,
-                       (void *)payload->data);
+       rc = nvdimm->security_ops->erase(nvdimm,
+                       (struct nvdimm_key_data *) payload->data);
        up_read(&key->sem);
        /* remove key since secure erase kills the passphrase */
 
@@ -257,7 +255,6 @@ static int nvdimm_security_erase(struct device *dev, 
unsigned int keyid)
 static int nvdimm_security_freeze_lock(struct device *dev)
 {
        struct nvdimm *nvdimm = to_nvdimm(dev);
-       struct nvdimm_bus *nvdimm_bus = walk_to_nvdimm_bus(dev);
        int rc;
 
        if (!nvdimm->security_ops)
@@ -266,7 +263,7 @@ static int nvdimm_security_freeze_lock(struct device *dev)
        if (nvdimm->state == NVDIMM_SECURITY_UNSUPPORTED)
                return -EOPNOTSUPP;
 
-       rc = nvdimm->security_ops->freeze_lock(nvdimm_bus, nvdimm);
+       rc = nvdimm->security_ops->freeze_lock(nvdimm);
        if (rc < 0)
                return rc;
 
@@ -277,7 +274,6 @@ static int nvdimm_security_freeze_lock(struct device *dev)
 static int nvdimm_security_disable(struct device *dev, unsigned int keyid)
 {
        struct nvdimm *nvdimm = to_nvdimm(dev);
-       struct nvdimm_bus *nvdimm_bus = walk_to_nvdimm_bus(dev);
        struct key *key;
        int rc;
        struct user_key_payload *payload;
@@ -304,8 +300,8 @@ static int nvdimm_security_disable(struct device *dev, 
unsigned int keyid)
        down_read(&key->sem);
        payload = key->payload.data[0];
 
-       rc = nvdimm->security_ops->disable(nvdimm_bus, nvdimm,
-                       (void *)payload->data);
+       rc = nvdimm->security_ops->disable(nvdimm,
+                       (struct nvdimm_key_data *) payload->data);
        up_read(&key->sem);
        if (rc < 0) {
                dev_warn(dev, "unlock failed\n");
@@ -328,7 +324,6 @@ static int nvdimm_security_disable(struct device *dev, 
unsigned int keyid)
 int nvdimm_security_unlock_dimm(struct device *dev)
 {
        struct nvdimm *nvdimm = to_nvdimm(dev);
-       struct nvdimm_bus *nvdimm_bus = walk_to_nvdimm_bus(dev);
        struct key *key;
        struct user_key_payload *payload;
        int rc;
@@ -361,8 +356,8 @@ int nvdimm_security_unlock_dimm(struct device *dev)
        dev_dbg(dev, "%s: key: %#x\n", __func__, key_serial(key));
        down_read(&key->sem);
        payload = key->payload.data[0];
-       rc = nvdimm->security_ops->unlock(nvdimm_bus, nvdimm,
-                       (const void *)payload->data);
+       rc = nvdimm->security_ops->unlock(nvdimm,
+                       (struct nvdimm_key_data *) payload->data);
        up_read(&key->sem);
 
        if (rc == 0) {
@@ -388,7 +383,6 @@ static int nvdimm_security_change_key(struct device *dev,
                unsigned int old_keyid, unsigned int new_keyid)
 {
        struct nvdimm *nvdimm = to_nvdimm(dev);
-       struct nvdimm_bus *nvdimm_bus = walk_to_nvdimm_bus(dev);
        struct key *key, *old_key;
        int rc;
        void *old_data = NULL, *new_data;
@@ -451,8 +445,7 @@ static int nvdimm_security_change_key(struct device *dev,
 
        new_data = payload->data;
 
-       rc = nvdimm->security_ops->change_key(nvdimm_bus, nvdimm, old_data,
-                       new_data);
+       rc = nvdimm->security_ops->change_key(nvdimm, old_data, new_data);
        /* copy new payload to old payload */
        if (rc == 0) {
                if (update)
diff --git a/include/linux/libnvdimm.h b/include/linux/libnvdimm.h
index 0d85e092a6dd..c352b8195675 100644
--- a/include/linux/libnvdimm.h
+++ b/include/linux/libnvdimm.h
@@ -172,23 +172,17 @@ struct nvdimm_key_data {
 };
 
 struct nvdimm_security_ops {
-       int (*state)(struct nvdimm_bus *nvdimm_bus,
-                       struct nvdimm *nvdimm,
+       int (*state)(struct nvdimm *nvdimm,
                        enum nvdimm_security_state *state);
-       int (*unlock)(struct nvdimm_bus *nvdimm_bus,
-                       struct nvdimm *nvdimm,
+       int (*unlock)(struct nvdimm *nvdimm,
                        const struct nvdimm_key_data *nkey);
-       int (*change_key)(struct nvdimm_bus *nvdimm_bus,
-                       struct nvdimm *nvdimm,
+       int (*change_key)(struct nvdimm *nvdimm,
                        const struct nvdimm_key_data *old_data,
                        const struct nvdimm_key_data *new_data);
-       int (*disable)(struct nvdimm_bus *nvdimm_bus,
-                       struct nvdimm *nvdimm,
+       int (*disable)(struct nvdimm *nvdimm,
                        const struct nvdimm_key_data *nkey);
-       int (*freeze_lock)(struct nvdimm_bus *nvdimm_bus,
-                       struct nvdimm *nvdimm);
-       int (*erase)(struct nvdimm_bus *nvdimm_bus,
-                       struct nvdimm *nvdimm,
+       int (*freeze_lock)(struct nvdimm *nvdimm);
+       int (*erase)(struct nvdimm *nvdimm,
                        const struct nvdimm_key_data *nkey);
 };
 
@@ -202,6 +196,7 @@ struct nvdimm_bus *nvdimm_bus_register(struct device 
*parent,
                struct nvdimm_bus_descriptor *nfit_desc);
 void nvdimm_bus_unregister(struct nvdimm_bus *nvdimm_bus);
 struct nvdimm_bus *to_nvdimm_bus(struct device *dev);
+struct nvdimm_bus *nvdimm_to_bus(struct nvdimm *nvdimm);
 struct nvdimm *to_nvdimm(struct device *dev);
 struct nd_region *to_nd_region(struct device *dev);
 struct device *nd_region_dev(struct nd_region *nd_region);
@@ -243,6 +238,15 @@ void nvdimm_flush(struct nd_region *nd_region);
 int nvdimm_has_flush(struct nd_region *nd_region);
 int nvdimm_has_cache(struct nd_region *nd_region);
 
+static inline int nvdimm_ctl(struct nvdimm *nvdimm, unsigned int cmd, void 
*buf,
+               unsigned int buf_len, int *cmd_rc)
+{
+       struct nvdimm_bus *nvdimm_bus = nvdimm_to_bus(nvdimm);
+       struct nvdimm_bus_descriptor *nd_desc = to_nd_desc(nvdimm_bus);
+
+       return nd_desc->ndctl(nd_desc, nvdimm, cmd, buf, buf_len, cmd_rc);
+}
+
 #ifdef CONFIG_ARCH_HAS_PMEM_API
 #define ARCH_MEMREMAP_PMEM MEMREMAP_WB
 void arch_wb_cache_pmem(void *addr, size_t size);

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

Reply via email to