net: vl: Move default_net to vl.c

All handling of defaults (default_* variables) is inside vl.c,
move default_net there too, so we can more easily refactor that
code later.

Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
Signed-off-by: Jason Wang <jasowang@redhat.com>
This commit is contained in:
Eduardo Habkost 2016-05-12 11:17:16 -03:00 committed by Jason Wang
parent 3af9187fc6
commit d30300f771
3 changed files with 23 additions and 25 deletions

View File

@ -178,7 +178,6 @@ struct NICInfo {
extern int nb_nics; extern int nb_nics;
extern NICInfo nd_table[MAX_NICS]; extern NICInfo nd_table[MAX_NICS];
extern int default_net;
extern const char *host_net_devices[]; extern const char *host_net_devices[];
/* from net.c */ /* from net.c */

View File

@ -76,8 +76,6 @@ const char *host_net_devices[] = {
NULL, NULL,
}; };
int default_net = 1;
/***********************************************************/ /***********************************************************/
/* network device redirectors */ /* network device redirectors */
@ -1415,18 +1413,6 @@ void net_check_clients(void)
NetClientState *nc; NetClientState *nc;
int i; int i;
/* Don't warn about the default network setup that you get if
* no command line -net or -netdev options are specified. There
* are two cases that we would otherwise complain about:
* (1) board doesn't support a NIC but the implicit "-net nic"
* requested one
* (2) CONFIG_SLIRP not set, in which case the implicit "-net nic"
* sets up a nic that isn't connected to anything.
*/
if (default_net) {
return;
}
net_hub_check_clients(); net_hub_check_clients();
QTAILQ_FOREACH(nc, &net_clients, next) { QTAILQ_FOREACH(nc, &net_clients, next) {
@ -1483,14 +1469,6 @@ int net_init_clients(void)
{ {
QemuOptsList *net = qemu_find_opts("net"); QemuOptsList *net = qemu_find_opts("net");
if (default_net) {
/* if no clients, we use a default config */
qemu_opts_set(net, NULL, "type", "nic", &error_abort);
#ifdef CONFIG_SLIRP
qemu_opts_set(net, NULL, "type", "user", &error_abort);
#endif
}
net_change_state_entry = net_change_state_entry =
qemu_add_vm_change_state_handler(net_vm_change_state_handler, NULL); qemu_add_vm_change_state_handler(net_vm_change_state_handler, NULL);
@ -1521,7 +1499,6 @@ int net_client_parse(QemuOptsList *opts_list, const char *optarg)
return -1; return -1;
} }
default_net = 0;
return 0; return 0;
} }

24
vl.c
View File

@ -207,6 +207,7 @@ static int default_floppy = 1;
static int default_cdrom = 1; static int default_cdrom = 1;
static int default_sdcard = 1; static int default_sdcard = 1;
static int default_vga = 1; static int default_vga = 1;
static int default_net = 1;
static struct { static struct {
const char *driver; const char *driver;
@ -3267,11 +3268,13 @@ int main(int argc, char **argv, char **envp)
fd_bootchk = 0; fd_bootchk = 0;
break; break;
case QEMU_OPTION_netdev: case QEMU_OPTION_netdev:
default_net = 0;
if (net_client_parse(qemu_find_opts("netdev"), optarg) == -1) { if (net_client_parse(qemu_find_opts("netdev"), optarg) == -1) {
exit(1); exit(1);
} }
break; break;
case QEMU_OPTION_net: case QEMU_OPTION_net:
default_net = 0;
if (net_client_parse(qemu_find_opts("net"), optarg) == -1) { if (net_client_parse(qemu_find_opts("net"), optarg) == -1) {
exit(1); exit(1);
} }
@ -4361,6 +4364,14 @@ int main(int argc, char **argv, char **envp)
/* clean up network at qemu process termination */ /* clean up network at qemu process termination */
atexit(&net_cleanup); atexit(&net_cleanup);
if (default_net) {
QemuOptsList *net = qemu_find_opts("net");
qemu_opts_set(net, NULL, "type", "nic", &error_abort);
#ifdef CONFIG_SLIRP
qemu_opts_set(net, NULL, "type", "user", &error_abort);
#endif
}
if (net_init_clients() < 0) { if (net_init_clients() < 0) {
exit(1); exit(1);
} }
@ -4509,7 +4520,18 @@ int main(int argc, char **argv, char **envp)
/* Did we create any drives that we failed to create a device for? */ /* Did we create any drives that we failed to create a device for? */
drive_check_orphaned(); drive_check_orphaned();
net_check_clients(); /* Don't warn about the default network setup that you get if
* no command line -net or -netdev options are specified. There
* are two cases that we would otherwise complain about:
* (1) board doesn't support a NIC but the implicit "-net nic"
* requested one
* (2) CONFIG_SLIRP not set, in which case the implicit "-net nic"
* sets up a nic that isn't connected to anything.
*/
if (!default_net) {
net_check_clients();
}
if (boot_once) { if (boot_once) {
qemu_boot_set(boot_once, &error_fatal); qemu_boot_set(boot_once, &error_fatal);