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);
|
virBufferAsprintf(buf, "<format type='%s'/>\n", format);
|
||||||
}
|
}
|
||||||
|
|
||||||
virBufferAddLit(buf, "<permissions>\n");
|
if (def->perms) {
|
||||||
virBufferAdjustIndent(buf, 2);
|
virBufferAddLit(buf, "<permissions>\n");
|
||||||
|
virBufferAdjustIndent(buf, 2);
|
||||||
|
|
||||||
virBufferAsprintf(buf, "<mode>0%o</mode>\n",
|
virBufferAsprintf(buf, "<mode>0%o</mode>\n",
|
||||||
def->perms->mode);
|
def->perms->mode);
|
||||||
virBufferAsprintf(buf, "<owner>%u</owner>\n",
|
virBufferAsprintf(buf, "<owner>%u</owner>\n",
|
||||||
(unsigned int) def->perms->uid);
|
(unsigned int) def->perms->uid);
|
||||||
virBufferAsprintf(buf, "<group>%u</group>\n",
|
virBufferAsprintf(buf, "<group>%u</group>\n",
|
||||||
(unsigned int) def->perms->gid);
|
(unsigned int) def->perms->gid);
|
||||||
|
|
||||||
|
|
||||||
virBufferEscapeString(buf, "<label>%s</label>\n",
|
virBufferEscapeString(buf, "<label>%s</label>\n",
|
||||||
def->perms->label);
|
def->perms->label);
|
||||||
|
|
||||||
virBufferAdjustIndent(buf, -2);
|
virBufferAdjustIndent(buf, -2);
|
||||||
virBufferAddLit(buf, "</permissions>\n");
|
virBufferAddLit(buf, "</permissions>\n");
|
||||||
|
}
|
||||||
|
|
||||||
if (def->timestamps) {
|
if (def->timestamps) {
|
||||||
virBufferAddLit(buf, "<timestamps>\n");
|
virBufferAddLit(buf, "<timestamps>\n");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user