{ NVMF_ADDR_FAMILY_FC,  "fc" },
 };
 
+static bool nvmet_is_port_enabled(struct nvmet_port *p, const char *caller)
+{
+       if (p->enabled)
+               pr_err("Disable port '%u' before changing attribute in %s\n",
+                               le16_to_cpu(p->disc_addr.portid), caller);
+       return p->enabled;
+}
+
 /*
  * nvmet_port Generic ConfigFS definitions.
  * Used in any place in the ConfigFS tree that refers to an address.
        struct nvmet_port *port = to_nvmet_port(item);
        int i;
 
-       if (port->enabled) {
-               pr_err("Cannot modify address while enabled\n");
-               pr_err("Disable the address before modifying\n");
+       if (nvmet_is_port_enabled(port, __func__))
                return -EACCES;
-       }
 
        for (i = 1; i < ARRAY_SIZE(nvmet_addr_family); i++) {
                if (sysfs_streq(page, nvmet_addr_family[i].name))
                return -EINVAL;
        }
 
-       if (port->enabled) {
-               pr_err("Cannot modify address while enabled\n");
-               pr_err("Disable the address before modifying\n");
+       if (nvmet_is_port_enabled(port, __func__))
                return -EACCES;
-       }
+
        port->disc_addr.portid = cpu_to_le16(portid);
        return count;
 }
                return -EINVAL;
        }
 
-       if (port->enabled) {
-               pr_err("Cannot modify address while enabled\n");
-               pr_err("Disable the address before modifying\n");
+       if (nvmet_is_port_enabled(port, __func__))
                return -EACCES;
-       }
 
        if (sscanf(page, "%s\n", port->disc_addr.traddr) != 1)
                return -EINVAL;
        u8 treq = port->disc_addr.treq & ~NVME_TREQ_SECURE_CHANNEL_MASK;
        int i;
 
-       if (port->enabled) {
-               pr_err("Cannot modify address while enabled\n");
-               pr_err("Disable the address before modifying\n");
+       if (nvmet_is_port_enabled(port, __func__))
                return -EACCES;
-       }
 
        for (i = 0; i < ARRAY_SIZE(nvmet_addr_treq); i++) {
                if (sysfs_streq(page, nvmet_addr_treq[i].name))
                pr_err("Invalid value '%s' for trsvcid\n", page);
                return -EINVAL;
        }
-       if (port->enabled) {
-               pr_err("Cannot modify address while enabled\n");
-               pr_err("Disable the address before modifying\n");
+       if (nvmet_is_port_enabled(port, __func__))
                return -EACCES;
-       }
 
        if (sscanf(page, "%s\n", port->disc_addr.trsvcid) != 1)
                return -EINVAL;
        struct nvmet_port *port = to_nvmet_port(item);
        int ret;
 
-       if (port->enabled) {
-               pr_err("Cannot modify inline_data_size while port enabled\n");
-               pr_err("Disable the port before modifying\n");
+       if (nvmet_is_port_enabled(port, __func__))
                return -EACCES;
-       }
        ret = kstrtoint(page, 0, &port->inline_data_size);
        if (ret) {
                pr_err("Invalid value '%s' for inline_data_size\n", page);
        struct nvmet_port *port = to_nvmet_port(item);
        int i;
 
-       if (port->enabled) {
-               pr_err("Cannot modify address while enabled\n");
-               pr_err("Disable the address before modifying\n");
+       if (nvmet_is_port_enabled(port, __func__))
                return -EACCES;
-       }
 
        for (i = 0; i < ARRAY_SIZE(nvmet_transport); i++) {
                if (sysfs_streq(page, nvmet_transport[i].name))