提交 bef8e8fe 编写于 作者: L Laszlo Ersek 提交者: Stefan Hajnoczi

convert net_init_socket() to NetClientOptions

I "reverse engineered" the following permissions between the -socket
sub-options:

             fd  listen  connect  mcast  udp | localaddr
  fd         x   .       .        .      .   | .
  listen     .   x       .        .      .   | .
  connect    .   .       x        .      .   | .
  mcast      .   .       .        x      .   | x
  udp        .   .       .        .      x   | x
  -------------------------------------------+
  localaddr  .   .       .        x      x     x

I transformed the code accordingly. The real fix would be to embed "fd",
"listen", "connect", "mcast" and "udp" in a separate union. However
OptsVisitor's enum parser only supports the type=XXX QemuOpt instance as
union discriminator.
Signed-off-by: NLaszlo Ersek <lersek@redhat.com>
Signed-off-by: NStefan Hajnoczi <stefanha@linux.vnet.ibm.com>
上级 094f15c5
...@@ -586,101 +586,68 @@ static int net_socket_udp_init(VLANState *vlan, ...@@ -586,101 +586,68 @@ static int net_socket_udp_init(VLANState *vlan,
return 0; return 0;
} }
int net_init_socket(QemuOpts *opts, const NetClientOptions *new_opts, int net_init_socket(QemuOpts *old_opts, const NetClientOptions *opts,
const char *name, VLANState *vlan) const char *name, VLANState *vlan)
{ {
if (qemu_opt_get(opts, "fd")) { const NetdevSocketOptions *sock;
int fd;
if (qemu_opt_get(opts, "listen") || assert(opts->kind == NET_CLIENT_OPTIONS_KIND_SOCKET);
qemu_opt_get(opts, "connect") || sock = opts->socket;
qemu_opt_get(opts, "mcast") ||
qemu_opt_get(opts, "localaddr")) {
error_report("listen=, connect=, mcast= and localaddr= is invalid with fd=");
return -1;
}
fd = net_handle_fd_param(cur_mon, qemu_opt_get(opts, "fd")); if (sock->has_fd + sock->has_listen + sock->has_connect + sock->has_mcast +
if (fd == -1) { sock->has_udp != 1) {
return -1; error_report("exactly one of fd=, listen=, connect=, mcast= or udp="
} " is required");
return -1;
}
if (!net_socket_fd_init(vlan, "socket", name, fd, 1)) { if (sock->has_localaddr && !sock->has_mcast && !sock->has_udp) {
return -1; error_report("localaddr= is only valid with mcast= or udp=");
} return -1;
} else if (qemu_opt_get(opts, "listen")) { }
const char *listen;
if (qemu_opt_get(opts, "fd") ||
qemu_opt_get(opts, "connect") ||
qemu_opt_get(opts, "mcast") ||
qemu_opt_get(opts, "localaddr")) {
error_report("fd=, connect=, mcast= and localaddr= is invalid with listen=");
return -1;
}
listen = qemu_opt_get(opts, "listen"); if (sock->has_fd) {
int fd;
if (net_socket_listen_init(vlan, "socket", name, listen) == -1) { fd = net_handle_fd_param(cur_mon, sock->fd);
return -1; if (fd == -1 || !net_socket_fd_init(vlan, "socket", name, fd, 1)) {
}
} else if (qemu_opt_get(opts, "connect")) {
const char *connect;
if (qemu_opt_get(opts, "fd") ||
qemu_opt_get(opts, "listen") ||
qemu_opt_get(opts, "mcast") ||
qemu_opt_get(opts, "localaddr")) {
error_report("fd=, listen=, mcast= and localaddr= is invalid with connect=");
return -1; return -1;
} }
return 0;
}
connect = qemu_opt_get(opts, "connect"); if (sock->has_listen) {
if (net_socket_listen_init(vlan, "socket", name, sock->listen) == -1) {
if (net_socket_connect_init(vlan, "socket", name, connect) == -1) {
return -1; return -1;
} }
} else if (qemu_opt_get(opts, "mcast")) { return 0;
const char *mcast, *localaddr; }
if (qemu_opt_get(opts, "fd") || if (sock->has_connect) {
qemu_opt_get(opts, "connect") || if (net_socket_connect_init(vlan, "socket", name, sock->connect) ==
qemu_opt_get(opts, "listen")) { -1) {
error_report("fd=, connect= and listen= is invalid with mcast=");
return -1; return -1;
} }
return 0;
}
mcast = qemu_opt_get(opts, "mcast"); if (sock->has_mcast) {
localaddr = qemu_opt_get(opts, "localaddr"); /* if sock->localaddr is missing, it has been initialized to "all bits
* zero" */
if (net_socket_mcast_init(vlan, "socket", name, mcast, localaddr) == -1) { if (net_socket_mcast_init(vlan, "socket", name, sock->mcast,
return -1; sock->localaddr) == -1) {
}
} else if (qemu_opt_get(opts, "udp")) {
const char *udp, *localaddr;
if (qemu_opt_get(opts, "fd") ||
qemu_opt_get(opts, "connect") ||
qemu_opt_get(opts, "listen") ||
qemu_opt_get(opts, "mcast")) {
error_report("fd=, connect=, listen="
" and mcast= is invalid with udp=");
return -1; return -1;
} }
return 0;
}
udp = qemu_opt_get(opts, "udp"); assert(sock->has_udp);
localaddr = qemu_opt_get(opts, "localaddr"); if (!sock->has_localaddr) {
if (localaddr == NULL) { error_report("localaddr= is mandatory with udp=");
error_report("localaddr= is mandatory with udp="); return -1;
return -1; }
} if (net_socket_udp_init(vlan, "udp", name, sock->udp, sock->localaddr) ==
-1) {
if (net_socket_udp_init(vlan, "udp", name, udp, localaddr) == -1) {
return -1;
}
} else {
error_report("-socket requires fd=, listen=,"
" connect=, mcast= or udp=");
return -1; return -1;
} }
return 0; return 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册