mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 12:35:17 +00:00
conf: Fix possible NULL dereference in virStorageVolTargetDefFormat
Commit dae1568c6c6455091e8cd9bc2e90a22af3d3880c converted the perms member of the virStorageVolTarget struct into a pointer to make it optional. But virStorageVolTargetDefFormat did not check perms for NULL before dereferencing it.
This commit is contained in:
parent
9b1e4cd503
commit
270969c4dd
@ -1423,22 +1423,24 @@ virStorageVolTargetDefFormat(virStorageVolOptionsPtr options,
|
||||
virBufferAsprintf(buf, "<format type='%s'/>\n", format);
|
||||
}
|
||||
|
||||
virBufferAddLit(buf, "<permissions>\n");
|
||||
virBufferAdjustIndent(buf, 2);
|
||||
if (def->perms) {
|
||||
virBufferAddLit(buf, "<permissions>\n");
|
||||
virBufferAdjustIndent(buf, 2);
|
||||
|
||||
virBufferAsprintf(buf, "<mode>0%o</mode>\n",
|
||||
def->perms->mode);
|
||||
virBufferAsprintf(buf, "<owner>%u</owner>\n",
|
||||
(unsigned int) def->perms->uid);
|
||||
virBufferAsprintf(buf, "<group>%u</group>\n",
|
||||
(unsigned int) def->perms->gid);
|
||||
virBufferAsprintf(buf, "<mode>0%o</mode>\n",
|
||||
def->perms->mode);
|
||||
virBufferAsprintf(buf, "<owner>%u</owner>\n",
|
||||
(unsigned int) def->perms->uid);
|
||||
virBufferAsprintf(buf, "<group>%u</group>\n",
|
||||
(unsigned int) def->perms->gid);
|
||||
|
||||
|
||||
virBufferEscapeString(buf, "<label>%s</label>\n",
|
||||
def->perms->label);
|
||||
virBufferEscapeString(buf, "<label>%s</label>\n",
|
||||
def->perms->label);
|
||||
|
||||
virBufferAdjustIndent(buf, -2);
|
||||
virBufferAddLit(buf, "</permissions>\n");
|
||||
virBufferAdjustIndent(buf, -2);
|
||||
virBufferAddLit(buf, "</permissions>\n");
|
||||
}
|
||||
|
||||
if (def->timestamps) {
|
||||
virBufferAddLit(buf, "<timestamps>\n");
|
||||
|
Loading…
x
Reference in New Issue
Block a user