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.willi...@intel.com>

Reviewed-by: Dave Jiang <dave.ji...@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