mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-26 09:58:23 +00:00 
			
		
		
		
	net: Use hubs for the vlan feature
Stop using the special-case vlan code in net.c. Instead use the hub net client to implement the vlan feature. The next patch will remove vlan code from net.c completely. Signed-off-by: Stefan Hajnoczi <stefanha@linux.vnet.ibm.com> Signed-off-by: Zhi Yong Wu <wuzhy@linux.vnet.ibm.com> Reviewed-by: Laszlo Ersek <lersek@redhat.com>
This commit is contained in:
		
							parent
							
								
									f6c874e300
								
							
						
					
					
						commit
						d33d93b2c4
					
				
							
								
								
									
										37
									
								
								net.c
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								net.c
									
									
									
									
									
								
							| @ -157,23 +157,25 @@ void qemu_macaddr_default_if_unset(MACAddr *macaddr) | |||||||
|     macaddr->a[5] = 0x56 + index++; |     macaddr->a[5] = 0x56 + index++; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * Generate a name for net client | ||||||
|  |  * | ||||||
|  |  * Only net clients created with the legacy -net option need this.  Naming is | ||||||
|  |  * mandatory for net clients created with -netdev. | ||||||
|  |  */ | ||||||
| static char *assign_name(VLANClientState *vc1, const char *model) | static char *assign_name(VLANClientState *vc1, const char *model) | ||||||
| { | { | ||||||
|     VLANState *vlan; |  | ||||||
|     VLANClientState *vc; |     VLANClientState *vc; | ||||||
|     char buf[256]; |     char buf[256]; | ||||||
|     int id = 0; |     int id = 0; | ||||||
| 
 | 
 | ||||||
|     QTAILQ_FOREACH(vlan, &vlans, next) { |  | ||||||
|         QTAILQ_FOREACH(vc, &vlan->clients, next) { |  | ||||||
|             if (vc != vc1 && strcmp(vc->model, model) == 0) { |  | ||||||
|                 id++; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     QTAILQ_FOREACH(vc, &non_vlan_clients, next) { |     QTAILQ_FOREACH(vc, &non_vlan_clients, next) { | ||||||
|         if (vc != vc1 && strcmp(vc->model, model) == 0) { |         if (vc == vc1) { | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |         /* For compatibility only bump id for net clients on a vlan */ | ||||||
|  |         if (strcmp(vc->model, model) == 0 && | ||||||
|  |             net_hub_id_for_client(vc, NULL) == 0) { | ||||||
|             id++; |             id++; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -750,7 +752,7 @@ int net_handle_fd_param(Monitor *mon, const char *param) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int net_init_nic(const NetClientOptions *opts, const char *name, | static int net_init_nic(const NetClientOptions *opts, const char *name, | ||||||
|                         VLANState *vlan) |                         VLANClientState *peer) | ||||||
| { | { | ||||||
|     int idx; |     int idx; | ||||||
|     NICInfo *nd; |     NICInfo *nd; | ||||||
| @ -776,8 +778,8 @@ static int net_init_nic(const NetClientOptions *opts, const char *name, | |||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|     } else { |     } else { | ||||||
|         assert(vlan); |         assert(peer); | ||||||
|         nd->vlan = vlan; |         nd->netdev = peer; | ||||||
|     } |     } | ||||||
|     if (name) { |     if (name) { | ||||||
|         nd->name = g_strdup(name); |         nd->name = g_strdup(name); | ||||||
| @ -816,7 +818,7 @@ static int net_init_nic(const NetClientOptions *opts, const char *name, | |||||||
| static int (* const net_client_init_fun[NET_CLIENT_OPTIONS_KIND_MAX])( | static int (* const net_client_init_fun[NET_CLIENT_OPTIONS_KIND_MAX])( | ||||||
|     const NetClientOptions *opts, |     const NetClientOptions *opts, | ||||||
|     const char *name, |     const char *name, | ||||||
|     VLANState *vlan) = { |     VLANClientState *peer) = { | ||||||
|         [NET_CLIENT_OPTIONS_KIND_NIC]       = net_init_nic, |         [NET_CLIENT_OPTIONS_KIND_NIC]       = net_init_nic, | ||||||
| #ifdef CONFIG_SLIRP | #ifdef CONFIG_SLIRP | ||||||
|         [NET_CLIENT_OPTIONS_KIND_USER]      = net_init_slirp, |         [NET_CLIENT_OPTIONS_KIND_USER]      = net_init_slirp, | ||||||
| @ -876,17 +878,17 @@ static int net_client_init1(const void *object, int is_netdev, Error **errp) | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (net_client_init_fun[opts->kind]) { |     if (net_client_init_fun[opts->kind]) { | ||||||
|         VLANState *vlan = NULL; |         VLANClientState *peer = NULL; | ||||||
| 
 | 
 | ||||||
|         /* Do not add to a vlan if it's a -netdev or a nic with a netdev=
 |         /* Do not add to a vlan if it's a -netdev or a nic with a netdev=
 | ||||||
|          * parameter. */ |          * parameter. */ | ||||||
|         if (!is_netdev && |         if (!is_netdev && | ||||||
|             (opts->kind != NET_CLIENT_OPTIONS_KIND_NIC || |             (opts->kind != NET_CLIENT_OPTIONS_KIND_NIC || | ||||||
|              !opts->nic->has_netdev)) { |              !opts->nic->has_netdev)) { | ||||||
|             vlan = qemu_find_vlan(u.net->has_vlan ? u.net->vlan : 0, true); |             peer = net_hub_add_port(u.net->has_vlan ? u.net->vlan : 0, NULL); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (net_client_init_fun[opts->kind](opts, name, vlan) < 0) { |         if (net_client_init_fun[opts->kind](opts, name, peer) < 0) { | ||||||
|             /* TODO push error reporting into init() methods */ |             /* TODO push error reporting into init() methods */ | ||||||
|             error_set(errp, QERR_DEVICE_INIT_FAILED, |             error_set(errp, QERR_DEVICE_INIT_FAILED, | ||||||
|                       NetClientOptionsKind_lookup[opts->kind]); |                       NetClientOptionsKind_lookup[opts->kind]); | ||||||
| @ -1085,6 +1087,7 @@ void do_info_network(Monitor *mon) | |||||||
|             print_net_client(mon, peer); |             print_net_client(mon, peer); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |     net_hub_info(mon); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void qmp_set_link(const char *name, bool up, Error **errp) | void qmp_set_link(const char *name, bool up, Error **errp) | ||||||
|  | |||||||
							
								
								
									
										19
									
								
								net/dump.c
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								net/dump.c
									
									
									
									
									
								
							| @ -27,6 +27,7 @@ | |||||||
| #include "qemu-error.h" | #include "qemu-error.h" | ||||||
| #include "qemu-log.h" | #include "qemu-log.h" | ||||||
| #include "qemu-timer.h" | #include "qemu-timer.h" | ||||||
|  | #include "hub.h" | ||||||
| 
 | 
 | ||||||
| typedef struct DumpState { | typedef struct DumpState { | ||||||
|     VLANClientState nc; |     VLANClientState nc; | ||||||
| @ -99,7 +100,7 @@ static NetClientInfo net_dump_info = { | |||||||
|     .cleanup = dump_cleanup, |     .cleanup = dump_cleanup, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static int net_dump_init(VLANState *vlan, const char *device, | static int net_dump_init(VLANClientState *peer, const char *device, | ||||||
|                          const char *name, const char *filename, int len) |                          const char *name, const char *filename, int len) | ||||||
| { | { | ||||||
|     struct pcap_file_hdr hdr; |     struct pcap_file_hdr hdr; | ||||||
| @ -128,7 +129,7 @@ static int net_dump_init(VLANState *vlan, const char *device, | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     nc = qemu_new_net_client(&net_dump_info, vlan, NULL, device, name); |     nc = qemu_new_net_client(&net_dump_info, NULL, peer, device, name); | ||||||
| 
 | 
 | ||||||
|     snprintf(nc->info_str, sizeof(nc->info_str), |     snprintf(nc->info_str, sizeof(nc->info_str), | ||||||
|              "dump to %s (len=%d)", filename, len); |              "dump to %s (len=%d)", filename, len); | ||||||
| @ -145,7 +146,7 @@ static int net_dump_init(VLANState *vlan, const char *device, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_dump(const NetClientOptions *opts, const char *name, | int net_init_dump(const NetClientOptions *opts, const char *name, | ||||||
|                   VLANState *vlan) |                   VLANClientState *peer) | ||||||
| { | { | ||||||
|     int len; |     int len; | ||||||
|     const char *file; |     const char *file; | ||||||
| @ -155,12 +156,18 @@ int net_init_dump(const NetClientOptions *opts, const char *name, | |||||||
|     assert(opts->kind == NET_CLIENT_OPTIONS_KIND_DUMP); |     assert(opts->kind == NET_CLIENT_OPTIONS_KIND_DUMP); | ||||||
|     dump = opts->dump; |     dump = opts->dump; | ||||||
| 
 | 
 | ||||||
|     assert(vlan); |     assert(peer); | ||||||
| 
 | 
 | ||||||
|     if (dump->has_file) { |     if (dump->has_file) { | ||||||
|         file = dump->file; |         file = dump->file; | ||||||
|     } else { |     } else { | ||||||
|         snprintf(def_file, sizeof(def_file), "qemu-vlan%d.pcap", vlan->id); |         int id; | ||||||
|  |         int ret; | ||||||
|  | 
 | ||||||
|  |         ret = net_hub_id_for_client(peer, &id); | ||||||
|  |         assert(ret == 0); /* peer must be on a hub */ | ||||||
|  | 
 | ||||||
|  |         snprintf(def_file, sizeof(def_file), "qemu-vlan%d.pcap", id); | ||||||
|         file = def_file; |         file = def_file; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -174,5 +181,5 @@ int net_init_dump(const NetClientOptions *opts, const char *name, | |||||||
|         len = 65536; |         len = 65536; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return net_dump_init(vlan, "dump", name, file, len); |     return net_dump_init(peer, "dump", name, file, len); | ||||||
| } | } | ||||||
|  | |||||||
| @ -28,6 +28,6 @@ | |||||||
| #include "qapi-types.h" | #include "qapi-types.h" | ||||||
| 
 | 
 | ||||||
| int net_init_dump(const NetClientOptions *opts, const char *name, | int net_init_dump(const NetClientOptions *opts, const char *name, | ||||||
|                   VLANState *vlan); |                   VLANClientState *peer); | ||||||
| 
 | 
 | ||||||
| #endif /* QEMU_NET_DUMP_H */ | #endif /* QEMU_NET_DUMP_H */ | ||||||
|  | |||||||
| @ -206,15 +206,15 @@ int net_hub_id_for_client(VLANClientState *nc, int *id) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_hubport(const NetClientOptions *opts, const char *name, | int net_init_hubport(const NetClientOptions *opts, const char *name, | ||||||
|                      VLANState *vlan) |                      VLANClientState *peer) | ||||||
| { | { | ||||||
|     const NetdevHubPortOptions *hubport; |     const NetdevHubPortOptions *hubport; | ||||||
| 
 | 
 | ||||||
|     assert(opts->kind == NET_CLIENT_OPTIONS_KIND_HUBPORT); |     assert(opts->kind == NET_CLIENT_OPTIONS_KIND_HUBPORT); | ||||||
|     hubport = opts->hubport; |     hubport = opts->hubport; | ||||||
| 
 | 
 | ||||||
|     /* The hub is a "vlan" so this option makes no sense. */ |     /* Treat hub port like a backend, NIC must be the one to peer */ | ||||||
|     if (vlan) { |     if (peer) { | ||||||
|         return -EINVAL; |         return -EINVAL; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ | |||||||
| #include "qemu-common.h" | #include "qemu-common.h" | ||||||
| 
 | 
 | ||||||
| int net_init_hubport(const NetClientOptions *opts, const char *name, | int net_init_hubport(const NetClientOptions *opts, const char *name, | ||||||
|                      VLANState *vlan); |                      VLANClientState *peer); | ||||||
| VLANClientState *net_hub_add_port(int hub_id, const char *name); | VLANClientState *net_hub_add_port(int hub_id, const char *name); | ||||||
| void net_hub_info(Monitor *mon); | void net_hub_info(Monitor *mon); | ||||||
| int net_hub_id_for_client(VLANClientState *nc, int *id); | int net_hub_id_for_client(VLANClientState *nc, int *id); | ||||||
|  | |||||||
| @ -135,7 +135,7 @@ static NetClientInfo net_slirp_info = { | |||||||
|     .cleanup = net_slirp_cleanup, |     .cleanup = net_slirp_cleanup, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static int net_slirp_init(VLANState *vlan, const char *model, | static int net_slirp_init(VLANClientState *peer, const char *model, | ||||||
|                           const char *name, int restricted, |                           const char *name, int restricted, | ||||||
|                           const char *vnetwork, const char *vhost, |                           const char *vnetwork, const char *vhost, | ||||||
|                           const char *vhostname, const char *tftp_export, |                           const char *vhostname, const char *tftp_export, | ||||||
| @ -238,7 +238,7 @@ static int net_slirp_init(VLANState *vlan, const char *model, | |||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|     nc = qemu_new_net_client(&net_slirp_info, vlan, NULL, model, name); |     nc = qemu_new_net_client(&net_slirp_info, NULL, peer, model, name); | ||||||
| 
 | 
 | ||||||
|     snprintf(nc->info_str, sizeof(nc->info_str), |     snprintf(nc->info_str, sizeof(nc->info_str), | ||||||
|              "net=%s,restrict=%s", inet_ntoa(net), |              "net=%s,restrict=%s", inet_ntoa(net), | ||||||
| @ -703,7 +703,7 @@ net_init_slirp_configs(const StringList *fwd, int flags) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_slirp(const NetClientOptions *opts, const char *name, | int net_init_slirp(const NetClientOptions *opts, const char *name, | ||||||
|                    VLANState *vlan) |                    VLANClientState *peer) | ||||||
| { | { | ||||||
|     struct slirp_config_str *config; |     struct slirp_config_str *config; | ||||||
|     char *vnet; |     char *vnet; | ||||||
| @ -722,7 +722,7 @@ int net_init_slirp(const NetClientOptions *opts, const char *name, | |||||||
|     net_init_slirp_configs(user->hostfwd, SLIRP_CFG_HOSTFWD); |     net_init_slirp_configs(user->hostfwd, SLIRP_CFG_HOSTFWD); | ||||||
|     net_init_slirp_configs(user->guestfwd, 0); |     net_init_slirp_configs(user->guestfwd, 0); | ||||||
| 
 | 
 | ||||||
|     ret = net_slirp_init(vlan, "user", name, user->restrict, vnet, user->host, |     ret = net_slirp_init(peer, "user", name, user->restrict, vnet, user->host, | ||||||
|                          user->hostname, user->tftp, user->bootfile, |                          user->hostname, user->tftp, user->bootfile, | ||||||
|                          user->dhcpstart, user->dns, user->smb, |                          user->dhcpstart, user->dns, user->smb, | ||||||
|                          user->smbserver); |                          user->smbserver); | ||||||
|  | |||||||
| @ -32,7 +32,7 @@ | |||||||
| #ifdef CONFIG_SLIRP | #ifdef CONFIG_SLIRP | ||||||
| 
 | 
 | ||||||
| int net_init_slirp(const NetClientOptions *opts, const char *name, | int net_init_slirp(const NetClientOptions *opts, const char *name, | ||||||
|                    VLANState *vlan); |                    VLANClientState *peer); | ||||||
| 
 | 
 | ||||||
| void net_slirp_hostfwd_add(Monitor *mon, const QDict *qdict); | void net_slirp_hostfwd_add(Monitor *mon, const QDict *qdict); | ||||||
| void net_slirp_hostfwd_remove(Monitor *mon, const QDict *qdict); | void net_slirp_hostfwd_remove(Monitor *mon, const QDict *qdict); | ||||||
|  | |||||||
							
								
								
									
										48
									
								
								net/socket.c
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								net/socket.c
									
									
									
									
									
								
							| @ -44,7 +44,7 @@ typedef struct NetSocketState { | |||||||
| } NetSocketState; | } NetSocketState; | ||||||
| 
 | 
 | ||||||
| typedef struct NetSocketListenState { | typedef struct NetSocketListenState { | ||||||
|     VLANState *vlan; |     VLANClientState *peer; | ||||||
|     char *model; |     char *model; | ||||||
|     char *name; |     char *name; | ||||||
|     int fd; |     int fd; | ||||||
| @ -245,7 +245,7 @@ static NetClientInfo net_dgram_socket_info = { | |||||||
|     .cleanup = net_socket_cleanup, |     .cleanup = net_socket_cleanup, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static NetSocketState *net_socket_fd_init_dgram(VLANState *vlan, | static NetSocketState *net_socket_fd_init_dgram(VLANClientState *peer, | ||||||
|                                                 const char *model, |                                                 const char *model, | ||||||
|                                                 const char *name, |                                                 const char *name, | ||||||
|                                                 int fd, int is_connected) |                                                 int fd, int is_connected) | ||||||
| @ -287,7 +287,7 @@ static NetSocketState *net_socket_fd_init_dgram(VLANState *vlan, | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     nc = qemu_new_net_client(&net_dgram_socket_info, vlan, NULL, model, name); |     nc = qemu_new_net_client(&net_dgram_socket_info, NULL, peer, model, name); | ||||||
| 
 | 
 | ||||||
|     snprintf(nc->info_str, sizeof(nc->info_str), |     snprintf(nc->info_str, sizeof(nc->info_str), | ||||||
|             "socket: fd=%d (%s mcast=%s:%d)", |             "socket: fd=%d (%s mcast=%s:%d)", | ||||||
| @ -323,7 +323,7 @@ static NetClientInfo net_socket_info = { | |||||||
|     .cleanup = net_socket_cleanup, |     .cleanup = net_socket_cleanup, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static NetSocketState *net_socket_fd_init_stream(VLANState *vlan, | static NetSocketState *net_socket_fd_init_stream(VLANClientState *peer, | ||||||
|                                                  const char *model, |                                                  const char *model, | ||||||
|                                                  const char *name, |                                                  const char *name, | ||||||
|                                                  int fd, int is_connected) |                                                  int fd, int is_connected) | ||||||
| @ -331,7 +331,7 @@ static NetSocketState *net_socket_fd_init_stream(VLANState *vlan, | |||||||
|     VLANClientState *nc; |     VLANClientState *nc; | ||||||
|     NetSocketState *s; |     NetSocketState *s; | ||||||
| 
 | 
 | ||||||
|     nc = qemu_new_net_client(&net_socket_info, vlan, NULL, model, name); |     nc = qemu_new_net_client(&net_socket_info, NULL, peer, model, name); | ||||||
| 
 | 
 | ||||||
|     snprintf(nc->info_str, sizeof(nc->info_str), "socket: fd=%d", fd); |     snprintf(nc->info_str, sizeof(nc->info_str), "socket: fd=%d", fd); | ||||||
| 
 | 
 | ||||||
| @ -347,7 +347,7 @@ static NetSocketState *net_socket_fd_init_stream(VLANState *vlan, | |||||||
|     return s; |     return s; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static NetSocketState *net_socket_fd_init(VLANState *vlan, | static NetSocketState *net_socket_fd_init(VLANClientState *peer, | ||||||
|                                           const char *model, const char *name, |                                           const char *model, const char *name, | ||||||
|                                           int fd, int is_connected) |                                           int fd, int is_connected) | ||||||
| { | { | ||||||
| @ -362,13 +362,13 @@ static NetSocketState *net_socket_fd_init(VLANState *vlan, | |||||||
|     } |     } | ||||||
|     switch(so_type) { |     switch(so_type) { | ||||||
|     case SOCK_DGRAM: |     case SOCK_DGRAM: | ||||||
|         return net_socket_fd_init_dgram(vlan, model, name, fd, is_connected); |         return net_socket_fd_init_dgram(peer, model, name, fd, is_connected); | ||||||
|     case SOCK_STREAM: |     case SOCK_STREAM: | ||||||
|         return net_socket_fd_init_stream(vlan, model, name, fd, is_connected); |         return net_socket_fd_init_stream(peer, model, name, fd, is_connected); | ||||||
|     default: |     default: | ||||||
|         /* who knows ... this could be a eg. a pty, do warn and continue as stream */ |         /* who knows ... this could be a eg. a pty, do warn and continue as stream */ | ||||||
|         fprintf(stderr, "qemu: warning: socket type=%d for fd=%d is not SOCK_DGRAM or SOCK_STREAM\n", so_type, fd); |         fprintf(stderr, "qemu: warning: socket type=%d for fd=%d is not SOCK_DGRAM or SOCK_STREAM\n", so_type, fd); | ||||||
|         return net_socket_fd_init_stream(vlan, model, name, fd, is_connected); |         return net_socket_fd_init_stream(peer, model, name, fd, is_connected); | ||||||
|     } |     } | ||||||
|     return NULL; |     return NULL; | ||||||
| } | } | ||||||
| @ -390,7 +390,7 @@ static void net_socket_accept(void *opaque) | |||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     s1 = net_socket_fd_init(s->vlan, s->model, s->name, fd, 1); |     s1 = net_socket_fd_init(s->peer, s->model, s->name, fd, 1); | ||||||
|     if (s1) { |     if (s1) { | ||||||
|         snprintf(s1->nc.info_str, sizeof(s1->nc.info_str), |         snprintf(s1->nc.info_str, sizeof(s1->nc.info_str), | ||||||
|                  "socket: connection from %s:%d", |                  "socket: connection from %s:%d", | ||||||
| @ -398,7 +398,7 @@ static void net_socket_accept(void *opaque) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int net_socket_listen_init(VLANState *vlan, | static int net_socket_listen_init(VLANClientState *peer, | ||||||
|                                   const char *model, |                                   const char *model, | ||||||
|                                   const char *name, |                                   const char *name, | ||||||
|                                   const char *host_str) |                                   const char *host_str) | ||||||
| @ -438,7 +438,7 @@ static int net_socket_listen_init(VLANState *vlan, | |||||||
|         closesocket(fd); |         closesocket(fd); | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|     s->vlan = vlan; |     s->peer = peer; | ||||||
|     s->model = g_strdup(model); |     s->model = g_strdup(model); | ||||||
|     s->name = name ? g_strdup(name) : NULL; |     s->name = name ? g_strdup(name) : NULL; | ||||||
|     s->fd = fd; |     s->fd = fd; | ||||||
| @ -446,7 +446,7 @@ static int net_socket_listen_init(VLANState *vlan, | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int net_socket_connect_init(VLANState *vlan, | static int net_socket_connect_init(VLANClientState *peer, | ||||||
|                                    const char *model, |                                    const char *model, | ||||||
|                                    const char *name, |                                    const char *name, | ||||||
|                                    const char *host_str) |                                    const char *host_str) | ||||||
| @ -487,7 +487,7 @@ static int net_socket_connect_init(VLANState *vlan, | |||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     s = net_socket_fd_init(vlan, model, name, fd, connected); |     s = net_socket_fd_init(peer, model, name, fd, connected); | ||||||
|     if (!s) |     if (!s) | ||||||
|         return -1; |         return -1; | ||||||
|     snprintf(s->nc.info_str, sizeof(s->nc.info_str), |     snprintf(s->nc.info_str, sizeof(s->nc.info_str), | ||||||
| @ -496,7 +496,7 @@ static int net_socket_connect_init(VLANState *vlan, | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int net_socket_mcast_init(VLANState *vlan, | static int net_socket_mcast_init(VLANClientState *peer, | ||||||
|                                  const char *model, |                                  const char *model, | ||||||
|                                  const char *name, |                                  const char *name, | ||||||
|                                  const char *host_str, |                                  const char *host_str, | ||||||
| @ -522,7 +522,7 @@ static int net_socket_mcast_init(VLANState *vlan, | |||||||
|     if (fd < 0) |     if (fd < 0) | ||||||
|         return -1; |         return -1; | ||||||
| 
 | 
 | ||||||
|     s = net_socket_fd_init(vlan, model, name, fd, 0); |     s = net_socket_fd_init(peer, model, name, fd, 0); | ||||||
|     if (!s) |     if (!s) | ||||||
|         return -1; |         return -1; | ||||||
| 
 | 
 | ||||||
| @ -535,7 +535,7 @@ static int net_socket_mcast_init(VLANState *vlan, | |||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int net_socket_udp_init(VLANState *vlan, | static int net_socket_udp_init(VLANClientState *peer, | ||||||
|                                  const char *model, |                                  const char *model, | ||||||
|                                  const char *name, |                                  const char *name, | ||||||
|                                  const char *rhost, |                                  const char *rhost, | ||||||
| @ -573,7 +573,7 @@ static int net_socket_udp_init(VLANState *vlan, | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     s = net_socket_fd_init(vlan, model, name, fd, 0); |     s = net_socket_fd_init(peer, model, name, fd, 0); | ||||||
|     if (!s) { |     if (!s) { | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| @ -587,7 +587,7 @@ static int net_socket_udp_init(VLANState *vlan, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_socket(const NetClientOptions *opts, const char *name, | int net_init_socket(const NetClientOptions *opts, const char *name, | ||||||
|                     VLANState *vlan) |                     VLANClientState *peer) | ||||||
| { | { | ||||||
|     const NetdevSocketOptions *sock; |     const NetdevSocketOptions *sock; | ||||||
| 
 | 
 | ||||||
| @ -610,21 +610,21 @@ int net_init_socket(const NetClientOptions *opts, const char *name, | |||||||
|         int fd; |         int fd; | ||||||
| 
 | 
 | ||||||
|         fd = net_handle_fd_param(cur_mon, sock->fd); |         fd = net_handle_fd_param(cur_mon, sock->fd); | ||||||
|         if (fd == -1 || !net_socket_fd_init(vlan, "socket", name, fd, 1)) { |         if (fd == -1 || !net_socket_fd_init(peer, "socket", name, fd, 1)) { | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sock->has_listen) { |     if (sock->has_listen) { | ||||||
|         if (net_socket_listen_init(vlan, "socket", name, sock->listen) == -1) { |         if (net_socket_listen_init(peer, "socket", name, sock->listen) == -1) { | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sock->has_connect) { |     if (sock->has_connect) { | ||||||
|         if (net_socket_connect_init(vlan, "socket", name, sock->connect) == |         if (net_socket_connect_init(peer, "socket", name, sock->connect) == | ||||||
|             -1) { |             -1) { | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| @ -634,7 +634,7 @@ int net_init_socket(const NetClientOptions *opts, const char *name, | |||||||
|     if (sock->has_mcast) { |     if (sock->has_mcast) { | ||||||
|         /* if sock->localaddr is missing, it has been initialized to "all bits
 |         /* if sock->localaddr is missing, it has been initialized to "all bits
 | ||||||
|          * zero" */ |          * zero" */ | ||||||
|         if (net_socket_mcast_init(vlan, "socket", name, sock->mcast, |         if (net_socket_mcast_init(peer, "socket", name, sock->mcast, | ||||||
|             sock->localaddr) == -1) { |             sock->localaddr) == -1) { | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
| @ -646,7 +646,7 @@ int net_init_socket(const NetClientOptions *opts, const char *name, | |||||||
|         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) == |     if (net_socket_udp_init(peer, "udp", name, sock->udp, sock->localaddr) == | ||||||
|         -1) { |         -1) { | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -28,6 +28,6 @@ | |||||||
| #include "qapi-types.h" | #include "qapi-types.h" | ||||||
| 
 | 
 | ||||||
| int net_init_socket(const NetClientOptions *opts, const char *name, | int net_init_socket(const NetClientOptions *opts, const char *name, | ||||||
|                     VLANState *vlan); |                     VLANClientState *peer); | ||||||
| 
 | 
 | ||||||
| #endif /* QEMU_NET_SOCKET_H */ | #endif /* QEMU_NET_SOCKET_H */ | ||||||
|  | |||||||
| @ -673,7 +673,7 @@ static NetClientInfo net_tap_win32_info = { | |||||||
|     .cleanup = tap_cleanup, |     .cleanup = tap_cleanup, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static int tap_win32_init(VLANState *vlan, const char *model, | static int tap_win32_init(VLANClientState *peer, const char *model, | ||||||
|                           const char *name, const char *ifname) |                           const char *name, const char *ifname) | ||||||
| { | { | ||||||
|     VLANClientState *nc; |     VLANClientState *nc; | ||||||
| @ -685,7 +685,7 @@ static int tap_win32_init(VLANState *vlan, const char *model, | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     nc = qemu_new_net_client(&net_tap_win32_info, vlan, NULL, model, name); |     nc = qemu_new_net_client(&net_tap_win32_info, NULL, peer, model, name); | ||||||
| 
 | 
 | ||||||
|     s = DO_UPCAST(TAPState, nc, nc); |     s = DO_UPCAST(TAPState, nc, nc); | ||||||
| 
 | 
 | ||||||
| @ -700,7 +700,7 @@ static int tap_win32_init(VLANState *vlan, const char *model, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_tap(const NetClientOptions *opts, const char *name, | int net_init_tap(const NetClientOptions *opts, const char *name, | ||||||
|                  VLANState *vlan) |                  VLANClientState *peer) | ||||||
| { | { | ||||||
|     const NetdevTapOptions *tap; |     const NetdevTapOptions *tap; | ||||||
| 
 | 
 | ||||||
| @ -712,7 +712,7 @@ int net_init_tap(const NetClientOptions *opts, const char *name, | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (tap_win32_init(vlan, "tap", name, tap->ifname) == -1) { |     if (tap_win32_init(peer, "tap", name, tap->ifname) == -1) { | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										12
									
								
								net/tap.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								net/tap.c
									
									
									
									
									
								
							| @ -322,7 +322,7 @@ static NetClientInfo net_tap_info = { | |||||||
|     .cleanup = tap_cleanup, |     .cleanup = tap_cleanup, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static TAPState *net_tap_fd_init(VLANState *vlan, | static TAPState *net_tap_fd_init(VLANClientState *peer, | ||||||
|                                  const char *model, |                                  const char *model, | ||||||
|                                  const char *name, |                                  const char *name, | ||||||
|                                  int fd, |                                  int fd, | ||||||
| @ -331,7 +331,7 @@ static TAPState *net_tap_fd_init(VLANState *vlan, | |||||||
|     VLANClientState *nc; |     VLANClientState *nc; | ||||||
|     TAPState *s; |     TAPState *s; | ||||||
| 
 | 
 | ||||||
|     nc = qemu_new_net_client(&net_tap_info, vlan, NULL, model, name); |     nc = qemu_new_net_client(&net_tap_info, NULL, peer, model, name); | ||||||
| 
 | 
 | ||||||
|     s = DO_UPCAST(TAPState, nc, nc); |     s = DO_UPCAST(TAPState, nc, nc); | ||||||
| 
 | 
 | ||||||
| @ -514,7 +514,7 @@ static int net_bridge_run_helper(const char *helper, const char *bridge) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_bridge(const NetClientOptions *opts, const char *name, | int net_init_bridge(const NetClientOptions *opts, const char *name, | ||||||
|                     VLANState *vlan) |                     VLANClientState *peer) | ||||||
| { | { | ||||||
|     const NetdevBridgeOptions *bridge; |     const NetdevBridgeOptions *bridge; | ||||||
|     const char *helper, *br; |     const char *helper, *br; | ||||||
| @ -537,7 +537,7 @@ int net_init_bridge(const NetClientOptions *opts, const char *name, | |||||||
| 
 | 
 | ||||||
|     vnet_hdr = tap_probe_vnet_hdr(fd); |     vnet_hdr = tap_probe_vnet_hdr(fd); | ||||||
| 
 | 
 | ||||||
|     s = net_tap_fd_init(vlan, "bridge", name, fd, vnet_hdr); |     s = net_tap_fd_init(peer, "bridge", name, fd, vnet_hdr); | ||||||
|     if (!s) { |     if (!s) { | ||||||
|         close(fd); |         close(fd); | ||||||
|         return -1; |         return -1; | ||||||
| @ -587,7 +587,7 @@ static int net_tap_init(const NetdevTapOptions *tap, int *vnet_hdr, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_tap(const NetClientOptions *opts, const char *name, | int net_init_tap(const NetClientOptions *opts, const char *name, | ||||||
|                  VLANState *vlan) |                  VLANClientState *peer) | ||||||
| { | { | ||||||
|     const NetdevTapOptions *tap; |     const NetdevTapOptions *tap; | ||||||
| 
 | 
 | ||||||
| @ -650,7 +650,7 @@ int net_init_tap(const NetClientOptions *opts, const char *name, | |||||||
|         model = "tap"; |         model = "tap"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     s = net_tap_fd_init(vlan, model, name, fd, vnet_hdr); |     s = net_tap_fd_init(peer, model, name, fd, vnet_hdr); | ||||||
|     if (!s) { |     if (!s) { | ||||||
|         close(fd); |         close(fd); | ||||||
|         return -1; |         return -1; | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ | |||||||
| #define DEFAULT_NETWORK_DOWN_SCRIPT "/etc/qemu-ifdown" | #define DEFAULT_NETWORK_DOWN_SCRIPT "/etc/qemu-ifdown" | ||||||
| 
 | 
 | ||||||
| int net_init_tap(const NetClientOptions *opts, const char *name, | int net_init_tap(const NetClientOptions *opts, const char *name, | ||||||
|                  VLANState *vlan); |                  VLANClientState *peer); | ||||||
| 
 | 
 | ||||||
| int tap_open(char *ifname, int ifname_size, int *vnet_hdr, int vnet_hdr_required); | int tap_open(char *ifname, int ifname_size, int *vnet_hdr, int vnet_hdr_required); | ||||||
| 
 | 
 | ||||||
| @ -59,6 +59,6 @@ struct vhost_net; | |||||||
| struct vhost_net *tap_get_vhost_net(VLANClientState *vc); | struct vhost_net *tap_get_vhost_net(VLANClientState *vc); | ||||||
| 
 | 
 | ||||||
| int net_init_bridge(const NetClientOptions *opts, const char *name, | int net_init_bridge(const NetClientOptions *opts, const char *name, | ||||||
|                     VLANState *vlan); |                     VLANClientState *peer); | ||||||
| 
 | 
 | ||||||
| #endif /* QEMU_NET_TAP_H */ | #endif /* QEMU_NET_TAP_H */ | ||||||
|  | |||||||
| @ -75,7 +75,7 @@ static NetClientInfo net_vde_info = { | |||||||
|     .cleanup = vde_cleanup, |     .cleanup = vde_cleanup, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static int net_vde_init(VLANState *vlan, const char *model, | static int net_vde_init(VLANClientState *peer, const char *model, | ||||||
|                         const char *name, const char *sock, |                         const char *name, const char *sock, | ||||||
|                         int port, const char *group, int mode) |                         int port, const char *group, int mode) | ||||||
| { | { | ||||||
| @ -96,7 +96,7 @@ static int net_vde_init(VLANState *vlan, const char *model, | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     nc = qemu_new_net_client(&net_vde_info, vlan, NULL, model, name); |     nc = qemu_new_net_client(&net_vde_info, NULL, peer, model, name); | ||||||
| 
 | 
 | ||||||
|     snprintf(nc->info_str, sizeof(nc->info_str), "sock=%s,fd=%d", |     snprintf(nc->info_str, sizeof(nc->info_str), "sock=%s,fd=%d", | ||||||
|              sock, vde_datafd(vde)); |              sock, vde_datafd(vde)); | ||||||
| @ -111,7 +111,7 @@ static int net_vde_init(VLANState *vlan, const char *model, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int net_init_vde(const NetClientOptions *opts, const char *name, | int net_init_vde(const NetClientOptions *opts, const char *name, | ||||||
|                  VLANState *vlan) |                  VLANClientState *peer) | ||||||
| { | { | ||||||
|     const NetdevVdeOptions *vde; |     const NetdevVdeOptions *vde; | ||||||
| 
 | 
 | ||||||
| @ -119,7 +119,7 @@ int net_init_vde(const NetClientOptions *opts, const char *name, | |||||||
|     vde = opts->vde; |     vde = opts->vde; | ||||||
| 
 | 
 | ||||||
|     /* missing optional values have been initialized to "all bits zero" */ |     /* missing optional values have been initialized to "all bits zero" */ | ||||||
|     if (net_vde_init(vlan, "vde", name, vde->sock, vde->port, vde->group, |     if (net_vde_init(peer, "vde", name, vde->sock, vde->port, vde->group, | ||||||
|                      vde->has_mode ? vde->mode : 0700) == -1) { |                      vde->has_mode ? vde->mode : 0700) == -1) { | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Stefan Hajnoczi
						Stefan Hajnoczi