|
@@ -1451,8 +1451,8 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata(
|
|
|
size_t count)
|
|
|
{
|
|
|
struct se_device *dev;
|
|
|
- unsigned char *i_fabric, *t_fabric, *i_port = NULL, *t_port = NULL;
|
|
|
- unsigned char *isid = NULL;
|
|
|
+ unsigned char *i_fabric = NULL, *i_port = NULL, *isid = NULL;
|
|
|
+ unsigned char *t_fabric = NULL, *t_port = NULL;
|
|
|
char *orig, *ptr, *arg_p, *opts;
|
|
|
substring_t args[MAX_OPT_ARGS];
|
|
|
unsigned long long tmp_ll;
|
|
@@ -1488,9 +1488,17 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata(
|
|
|
switch (token) {
|
|
|
case Opt_initiator_fabric:
|
|
|
i_fabric = match_strdup(&args[0]);
|
|
|
+ if (!i_fabric) {
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
break;
|
|
|
case Opt_initiator_node:
|
|
|
i_port = match_strdup(&args[0]);
|
|
|
+ if (!i_port) {
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
if (strlen(i_port) > PR_APTPL_MAX_IPORT_LEN) {
|
|
|
printk(KERN_ERR "APTPL metadata initiator_node="
|
|
|
" exceeds PR_APTPL_MAX_IPORT_LEN: %d\n",
|
|
@@ -1501,6 +1509,10 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata(
|
|
|
break;
|
|
|
case Opt_initiator_sid:
|
|
|
isid = match_strdup(&args[0]);
|
|
|
+ if (!isid) {
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
if (strlen(isid) > PR_REG_ISID_LEN) {
|
|
|
printk(KERN_ERR "APTPL metadata initiator_isid"
|
|
|
"= exceeds PR_REG_ISID_LEN: %d\n",
|
|
@@ -1511,6 +1523,10 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata(
|
|
|
break;
|
|
|
case Opt_sa_res_key:
|
|
|
arg_p = match_strdup(&args[0]);
|
|
|
+ if (!arg_p) {
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
ret = strict_strtoull(arg_p, 0, &tmp_ll);
|
|
|
if (ret < 0) {
|
|
|
printk(KERN_ERR "strict_strtoull() failed for"
|
|
@@ -1547,9 +1563,17 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata(
|
|
|
*/
|
|
|
case Opt_target_fabric:
|
|
|
t_fabric = match_strdup(&args[0]);
|
|
|
+ if (!t_fabric) {
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
break;
|
|
|
case Opt_target_node:
|
|
|
t_port = match_strdup(&args[0]);
|
|
|
+ if (!t_port) {
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
if (strlen(t_port) > PR_APTPL_MAX_TPORT_LEN) {
|
|
|
printk(KERN_ERR "APTPL metadata target_node="
|
|
|
" exceeds PR_APTPL_MAX_TPORT_LEN: %d\n",
|
|
@@ -1592,6 +1616,11 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata(
|
|
|
i_port, isid, mapped_lun, t_port, tpgt, target_lun,
|
|
|
res_holder, all_tg_pt, type);
|
|
|
out:
|
|
|
+ kfree(i_fabric);
|
|
|
+ kfree(i_port);
|
|
|
+ kfree(isid);
|
|
|
+ kfree(t_fabric);
|
|
|
+ kfree(t_port);
|
|
|
kfree(orig);
|
|
|
return (ret == 0) ? count : ret;
|
|
|
}
|