mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-08 22:15:21 +00:00
qemu: monitor: Properly configure backend for UDP chardevs
Since introduction of chardev hotplug the code was wrong for the UDP case and basically created a TCP socket instead. Use proper objects and type for UDP. Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1377602
This commit is contained in:
parent
386fe237b2
commit
9bc4179dd4
@ -6204,12 +6204,20 @@ qemuMonitorJSONAttachCharDevCommand(const char *chrID,
|
||||
break;
|
||||
|
||||
case VIR_DOMAIN_CHR_TYPE_UDP:
|
||||
backend_type = "socket";
|
||||
backend_type = "udp";
|
||||
addr = qemuMonitorJSONBuildInetSocketAddress(chr->data.udp.connectHost,
|
||||
chr->data.udp.connectService);
|
||||
if (!addr ||
|
||||
virJSONValueObjectAppend(data, "addr", addr) < 0)
|
||||
virJSONValueObjectAppend(data, "remote", addr) < 0)
|
||||
goto error;
|
||||
|
||||
if (chr->data.udp.bindHost) {
|
||||
addr = qemuMonitorJSONBuildInetSocketAddress(chr->data.udp.bindHost,
|
||||
chr->data.udp.bindService);
|
||||
if (!addr ||
|
||||
virJSONValueObjectAppend(data, "local", addr) < 0)
|
||||
goto error;
|
||||
}
|
||||
addr = NULL;
|
||||
break;
|
||||
|
||||
|
@ -853,11 +853,23 @@ qemuMonitorJSONTestAttachChardev(virDomainXMLOptionPtr xmlopt)
|
||||
chr.data.udp.connectService = (char *) "1234";
|
||||
CHECK("udp", false,
|
||||
"{'id':'alias',"
|
||||
"'backend':{'type':'socket',"
|
||||
"'data':{'addr':{'type':'inet',"
|
||||
"'backend':{'type':'udp',"
|
||||
"'data':{'remote':{'type':'inet',"
|
||||
"'data':{'host':'example.com',"
|
||||
"'port':'1234'}}}}}");
|
||||
|
||||
chr.data.udp.bindHost = (char *) "localhost";
|
||||
chr.data.udp.bindService = (char *) "4321";
|
||||
CHECK("udp", false,
|
||||
"{'id':'alias',"
|
||||
"'backend':{'type':'udp',"
|
||||
"'data':{'remote':{'type':'inet',"
|
||||
"'data':{'host':'example.com',"
|
||||
"'port':'1234'}},"
|
||||
"'local':{'type':'inet',"
|
||||
"'data':{'host':'localhost',"
|
||||
"'port':'4321'}}}}}");
|
||||
|
||||
memset(&chr, 0, sizeof(chr));
|
||||
chr.type = VIR_DOMAIN_CHR_TYPE_UNIX;
|
||||
chr.data.nix.path = (char *) "/path/to/socket";
|
||||
|
Loading…
Reference in New Issue
Block a user