diff mbox series

libnvdimm: Drop nvdimm_bus from security_ops interface

Message ID 153801494299.825550.17855026442303724316.stgit@dwillia2-desk3.amr.corp.intel.com (mailing list archive)
State New, archived
Headers show
Series libnvdimm: Drop nvdimm_bus from security_ops interface | expand

Commit Message

Dan Williams Sept. 27, 2018, 2:22 a.m. UTC
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.williams@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(-)

Comments

Dave Jiang Sept. 27, 2018, 3:46 p.m. UTC | #1
On 09/26/2018 07:22 PM, Dan Williams wrote:
> 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.williams@intel.com>

Reviewed-by: Dave Jiang <dave.jiang@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);
>
diff mbox series

Patch

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);