mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-26 18:04:22 +03:00
Fix removal of SA in sa_modify_attrs()
The sa_modify_attrs() function can add, remove or replace an SA. The main loop in the function uses the index "i" to iterate over the existing SAs and uses the index "j" for writing them into a new buffer via SA_ADD_BULK_ATTR(). The write index, "j" is incremented on remove (SA_REMOVE) operations which leads to a corruption in the new SA buffer. This patch remove the increment for SA_REMOVE operations. Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Tim Chase <tim@chase2k.com> Signed-off-by: Ned Bass <bass6@llnl.gov> Closes #3028
This commit is contained in:
parent
841c9d43c7
commit
b0cf0676c0
@ -1730,10 +1730,8 @@ sa_modify_attrs(sa_handle_t *hdl, sa_attr_type_t newattr,
|
|||||||
if (attr == newattr) {
|
if (attr == newattr) {
|
||||||
if (length == 0)
|
if (length == 0)
|
||||||
++length_idx;
|
++length_idx;
|
||||||
if (action == SA_REMOVE) {
|
if (action == SA_REMOVE)
|
||||||
j++;
|
|
||||||
continue;
|
continue;
|
||||||
}
|
|
||||||
ASSERT(length == 0);
|
ASSERT(length == 0);
|
||||||
ASSERT(action == SA_REPLACE);
|
ASSERT(action == SA_REPLACE);
|
||||||
SA_ADD_BULK_ATTR(attr_desc, j, attr,
|
SA_ADD_BULK_ATTR(attr_desc, j, attr,
|
||||||
|
Loading…
Reference in New Issue
Block a user