|
@@ -202,8 +202,10 @@ xfs_attr_shortform_list(xfs_attr_list_context_t *context)
|
|
sbp->namelen,
|
|
sbp->namelen,
|
|
sbp->valuelen,
|
|
sbp->valuelen,
|
|
&sbp->name[sbp->namelen]);
|
|
&sbp->name[sbp->namelen]);
|
|
- if (error)
|
|
|
|
|
|
+ if (error) {
|
|
|
|
+ kmem_free(sbuf);
|
|
return error;
|
|
return error;
|
|
|
|
+ }
|
|
if (context->seen_enough)
|
|
if (context->seen_enough)
|
|
break;
|
|
break;
|
|
cursor->offset++;
|
|
cursor->offset++;
|
|
@@ -454,14 +456,13 @@ xfs_attr3_leaf_list_int(
|
|
args.rmtblkcnt = xfs_attr3_rmt_blocks(
|
|
args.rmtblkcnt = xfs_attr3_rmt_blocks(
|
|
args.dp->i_mount, valuelen);
|
|
args.dp->i_mount, valuelen);
|
|
retval = xfs_attr_rmtval_get(&args);
|
|
retval = xfs_attr_rmtval_get(&args);
|
|
- if (retval)
|
|
|
|
- return retval;
|
|
|
|
- retval = context->put_listent(context,
|
|
|
|
- entry->flags,
|
|
|
|
- name_rmt->name,
|
|
|
|
- (int)name_rmt->namelen,
|
|
|
|
- valuelen,
|
|
|
|
- args.value);
|
|
|
|
|
|
+ if (!retval)
|
|
|
|
+ retval = context->put_listent(context,
|
|
|
|
+ entry->flags,
|
|
|
|
+ name_rmt->name,
|
|
|
|
+ (int)name_rmt->namelen,
|
|
|
|
+ valuelen,
|
|
|
|
+ args.value);
|
|
kmem_free(args.value);
|
|
kmem_free(args.value);
|
|
} else {
|
|
} else {
|
|
retval = context->put_listent(context,
|
|
retval = context->put_listent(context,
|