]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
kvm tools: remove global kvm object
authorSasha Levin <levinsasha928@gmail.com>
Mon, 17 Sep 2012 08:03:32 +0000 (10:03 +0200)
committerPekka Enberg <penberg@kernel.org>
Tue, 18 Sep 2012 07:33:01 +0000 (10:33 +0300)
This was ugly, and now we get rid of it.

Signed-off-by: Sasha Levin <levinsasha928@gmail.com>
Signed-off-by: Pekka Enberg <penberg@kernel.org>
22 files changed:
tools/kvm/builtin-run.c
tools/kvm/hw/i8042.c
tools/kvm/hw/pci-shmem.c
tools/kvm/hw/rtc.c
tools/kvm/hw/serial.c
tools/kvm/hw/vesa.c
tools/kvm/include/kvm/brlock.h
tools/kvm/include/kvm/ioport.h
tools/kvm/include/kvm/kvm.h
tools/kvm/include/kvm/term.h
tools/kvm/ioport.c
tools/kvm/kvm-cpu.c
tools/kvm/kvm-ipc.c
tools/kvm/kvm.c
tools/kvm/mmio.c
tools/kvm/pci.c
tools/kvm/term.c
tools/kvm/virtio/balloon.c
tools/kvm/virtio/console.c
tools/kvm/virtio/net.c
tools/kvm/virtio/pci.c
tools/kvm/x86/ioport.c

index ee59d1cfa102b730f384b080536b138b925af2aa..1b046dc506c08bd57475a944e1b26b1cc64eae37 100644 (file)
@@ -53,7 +53,6 @@
 #define KB_SHIFT               (10)
 #define GB_SHIFT               (30)
 
-struct kvm *kvm;
 __thread struct kvm_cpu *current_kvm_cpu;
 
 static int  kvm_run_wrapper;
@@ -339,11 +338,13 @@ static const char *find_vmlinux(void)
 
 void kvm_run_help(void)
 {
+       struct kvm *kvm = NULL;
+
        BUILD_OPTIONS(options, &kvm->cfg, kvm);
        usage_with_options(run_usage, options);
 }
 
-static int kvm_setup_guest_init(void)
+static int kvm_setup_guest_init(struct kvm *kvm)
 {
        const char *rootfs = kvm->cfg.custom_rootfs_name;
        char tmp[PATH_MAX];
@@ -367,7 +368,7 @@ static int kvm_setup_guest_init(void)
        return 0;
 }
 
-static int kvm_run_set_sandbox(void)
+static int kvm_run_set_sandbox(struct kvm *kvm)
 {
        const char *guestfs_name = kvm->cfg.custom_rootfs_name;
        char path[PATH_MAX], script[PATH_MAX], *tmp;
@@ -439,7 +440,7 @@ static void resolve_program(const char *src, char *dst, size_t len)
                strncpy(dst, src, len);
 }
 
-static void kvm_run_write_sandbox_cmd(const char **argv, int argc)
+static void kvm_run_write_sandbox_cmd(struct kvm *kvm, const char **argv, int argc)
 {
        const char script_hdr[] = "#! /bin/bash\n\n";
        char program[PATH_MAX];
@@ -474,15 +475,15 @@ static void kvm_run_write_sandbox_cmd(const char **argv, int argc)
        close(fd);
 }
 
-static int kvm_cmd_run_init(int argc, const char **argv)
+static struct kvm *kvm_cmd_run_init(int argc, const char **argv)
 {
        static char real_cmdline[2048], default_name[20];
        unsigned int nr_online_cpus;
        struct sigaction sa;
+       struct kvm *kvm = kvm__new();
 
-       kvm = kvm__new();
        if (IS_ERR(kvm))
-               return PTR_ERR(kvm);
+               return kvm;
 
        sa.sa_flags = SA_SIGINFO;
        sa.sa_sigaction = handle_sigalrm;
@@ -502,7 +503,7 @@ static int kvm_cmd_run_init(int argc, const char **argv)
                        if (strcmp(argv[0], "--") == 0) {
                                if (kvm_run_wrapper == KVM_RUN_SANDBOX) {
                                        kvm->cfg.sandbox = DEFAULT_SANDBOX_FILENAME;
-                                       kvm_run_write_sandbox_cmd(argv+1, argc-1);
+                                       kvm_run_write_sandbox_cmd(kvm, argv+1, argc-1);
                                        break;
                                }
                        }
@@ -513,7 +514,7 @@ static int kvm_cmd_run_init(int argc, const char **argv)
                                                "%s\n", argv[0]);
                                usage_with_options(run_usage, options);
                                free(kvm);
-                               return -EINVAL;
+                               return ERR_PTR(-EINVAL);
                        }
                        if (kvm_run_wrapper == KVM_RUN_SANDBOX) {
                                /*
@@ -521,7 +522,7 @@ static int kvm_cmd_run_init(int argc, const char **argv)
                                 * sandbox command
                                 */
                                kvm->cfg.sandbox = DEFAULT_SANDBOX_FILENAME;
-                               kvm_run_write_sandbox_cmd(argv, argc);
+                               kvm_run_write_sandbox_cmd(kvm, argv, argc);
                        } else {
                                /*
                                 * first unhandled parameter is treated as a kernel
@@ -542,7 +543,7 @@ static int kvm_cmd_run_init(int argc, const char **argv)
 
        if (!kvm->cfg.kernel_filename) {
                kernel_usage_with_options();
-               return -EINVAL;
+               return ERR_PTR(-EINVAL);
        }
 
        kvm->cfg.vmlinux_filename = find_vmlinux();
@@ -633,13 +634,13 @@ static int kvm_cmd_run_init(int argc, const char **argv)
        if (kvm->cfg.using_rootfs) {
                strcat(real_cmdline, " root=/dev/root rw rootflags=rw,trans=virtio,version=9p2000.L rootfstype=9p");
                if (kvm->cfg.custom_rootfs) {
-                       kvm_run_set_sandbox();
+                       kvm_run_set_sandbox(kvm);
 
                        strcat(real_cmdline, " init=/virt/init");
 
                        if (!kvm->cfg.no_dhcp)
                                strcat(real_cmdline, "  ip=dhcp");
-                       if (kvm_setup_guest_init())
+                       if (kvm_setup_guest_init(kvm))
                                die("Failed to setup init for guest.");
                }
        } else if (!strstr(real_cmdline, "root=")) {
@@ -651,10 +652,12 @@ static int kvm_cmd_run_init(int argc, const char **argv)
        printf("  # %s run -k %s -m %Lu -c %d --name %s\n", KVM_BINARY_NAME,
                kvm->cfg.kernel_filename, kvm->cfg.ram_size / 1024 / 1024, kvm->cfg.nrcpus, kvm->cfg.guest_name);
 
-       return init_list__init(kvm);
+       init_list__init(kvm);
+
+       return kvm;
 }
 
-static int kvm_cmd_run_work(void)
+static int kvm_cmd_run_work(struct kvm *kvm)
 {
        int i;
        void *ret = NULL;
@@ -668,7 +671,7 @@ static int kvm_cmd_run_work(void)
        return pthread_join(kvm->cpus[0]->thread, &ret);
 }
 
-static void kvm_cmd_run_exit(int guest_ret)
+static void kvm_cmd_run_exit(struct kvm *kvm, int guest_ret)
 {
        compat__print_all_messages();
 
@@ -680,14 +683,15 @@ static void kvm_cmd_run_exit(int guest_ret)
 
 int kvm_cmd_run(int argc, const char **argv, const char *prefix)
 {
-       int r, ret = -EFAULT;
+       int ret = -EFAULT;
+       struct kvm *kvm;
 
-       r = kvm_cmd_run_init(argc, argv);
-       if (r < 0)
-               return r;
+       kvm = kvm_cmd_run_init(argc, argv);
+       if (IS_ERR(kvm))
+               return PTR_ERR(kvm);
 
-       ret = kvm_cmd_run_work();
-       kvm_cmd_run_exit(ret);
+       ret = kvm_cmd_run_work(kvm);
+       kvm_cmd_run_exit(kvm, ret);
 
        return ret;
 }
index 5893d1d31a13b9d16dcd4ba13756537c306a18d6..9f8be6a4abf9b8978c46b031325285f4a76336d9 100644 (file)
@@ -347,8 +347,8 @@ int kbd__init(struct kvm *kvm)
 
        kbd_reset();
        state.kvm = kvm;
-       ioport__register(I8042_DATA_REG, &kbd_ops, 2, NULL);
-       ioport__register(I8042_COMMAND_REG, &kbd_ops, 2, NULL);
+       ioport__register(kvm, I8042_DATA_REG, &kbd_ops, 2, NULL);
+       ioport__register(kvm, I8042_COMMAND_REG, &kbd_ops, 2, NULL);
 
        return 0;
 }
index 0eefa4eeadecf81e880203470af1ac188a0ec8a9..41613359b5fcef3a0c80745b47b48b5a72c4302e 100644 (file)
@@ -362,7 +362,7 @@ int pci_shmem__init(struct kvm *kvm)
        pci_shmem_pci_device.irq_line = line;
 
        /* Register MMIO space for MSI-X */
-       r = ioport__register(IOPORT_EMPTY, &shmem_pci__io_ops, IOPORT_SIZE, NULL);
+       r = ioport__register(kvm, IOPORT_EMPTY, &shmem_pci__io_ops, IOPORT_SIZE, NULL);
        if (r < 0)
                return r;
        ivshmem_registers = (u16)r;
index dd6dca31901ebabaa9356d0d58791315250d52c4..ad6dd65ebf3393385330ea454a3e7a6a53011ba9 100644 (file)
@@ -114,13 +114,13 @@ int rtc__init(struct kvm *kvm)
        int r = 0;
 
        /* PORT 0070-007F - CMOS RAM/RTC (REAL TIME CLOCK) */
-       r = ioport__register(0x0070, &cmos_ram_index_ioport_ops, 1, NULL);
+       r = ioport__register(kvm, 0x0070, &cmos_ram_index_ioport_ops, 1, NULL);
        if (r < 0)
                return r;
 
-       r = ioport__register(0x0071, &cmos_ram_data_ioport_ops, 1, NULL);
+       r = ioport__register(kvm, 0x0071, &cmos_ram_data_ioport_ops, 1, NULL);
        if (r < 0) {
-               ioport__unregister(0x0071);
+               ioport__unregister(kvm, 0x0071);
                return r;
        }
 
@@ -131,8 +131,8 @@ dev_init(rtc__init);
 int rtc__exit(struct kvm *kvm)
 {
        /* PORT 0070-007F - CMOS RAM/RTC (REAL TIME CLOCK) */
-       ioport__unregister(0x0070);
-       ioport__unregister(0x0071);
+       ioport__unregister(kvm, 0x0070);
+       ioport__unregister(kvm, 0x0071);
 
        return 0;
 }
index 5348a9244a49a863d8030eb8fcb7e8143f486095..a177a7f2906592d7b4d5d6820e583bb49d97e07f 100644 (file)
@@ -195,7 +195,7 @@ static void serial8250__receive(struct kvm *kvm, struct serial8250_device *dev,
        while (term_readable(dev->id) &&
               dev->rxcnt < FIFO_LEN) {
 
-               c = term_getc(dev->id);
+               c = term_getc(kvm, dev->id);
 
                if (c < 0)
                        break;
@@ -403,7 +403,7 @@ static int serial8250__device_init(struct kvm *kvm, struct serial8250_device *de
 {
        int r;
 
-       r = ioport__register(dev->iobase, &serial8250_ops, 8, NULL);
+       r = ioport__register(kvm, dev->iobase, &serial8250_ops, 8, NULL);
        kvm__irq_line(kvm, dev->irq, 0);
 
        return r;
@@ -427,7 +427,7 @@ cleanup:
        for (j = 0; j <= i; j++) {
                struct serial8250_device *dev = &devices[j];
 
-               ioport__unregister(dev->iobase);
+               ioport__unregister(kvm, dev->iobase);
        }
 
        return r;
@@ -442,7 +442,7 @@ int serial8250__exit(struct kvm *kvm)
        for (i = 0; i < ARRAY_SIZE(devices); i++) {
                struct serial8250_device *dev = &devices[i];
 
-               r = ioport__unregister(dev->iobase);
+               r = ioport__unregister(kvm, dev->iobase);
                if (r < 0)
                        return r;
        }
index 6f2d9f4107670c704fc789d037f821c137d613d4..a21149192befb030f0e0770cce3ea3dfd22a6fda 100644 (file)
@@ -60,7 +60,7 @@ struct framebuffer *vesa__init(struct kvm *kvm)
        if (r < 0)
                return ERR_PTR(r);
 
-       r = ioport__register(IOPORT_EMPTY, &vesa_io_ops, IOPORT_SIZE, NULL);
+       r = ioport__register(kvm, IOPORT_EMPTY, &vesa_io_ops, IOPORT_SIZE, NULL);
        if (r < 0)
                return ERR_PTR(r);
 
index bd1d882ac0558ced690759d11462d879764f71f5..29f72e0e8e0dac0ddb806a7977679f6251a99cd1 100644 (file)
 
 DECLARE_RWSEM(brlock_sem);
 
-#define br_read_lock()         down_read(&brlock_sem);
-#define br_read_unlock()       up_read(&brlock_sem);
+#define br_read_lock(kvm)      down_read(&brlock_sem);
+#define br_read_unlock(kvm)    up_read(&brlock_sem);
 
-#define br_write_lock()                down_write(&brlock_sem);
-#define br_write_unlock()      up_write(&brlock_sem);
+#define br_write_lock(kvm)     down_write(&brlock_sem);
+#define br_write_unlock(kvm)   up_write(&brlock_sem);
 
 #else
 
-#define br_read_lock()         barrier()
-#define br_read_unlock()       barrier()
+#define br_read_lock(kvm)      barrier()
+#define br_read_unlock(kvm)    barrier()
 
-#define br_write_lock()                kvm__pause()
-#define br_write_unlock()      kvm__continue()
+#define br_write_lock(kvm)     kvm__pause(kvm)
+#define br_write_unlock(kvm)   kvm__continue(kvm)
 #endif
 
 #endif
index ced8cf594516a7a680c62e3a65e2854233d9dca6..6660acb66b96929de7aeba3cff44aa1854b6d6a7 100644 (file)
@@ -29,10 +29,11 @@ struct ioport_operations {
        bool (*io_out)(struct ioport *ioport, struct kvm *kvm, u16 port, void *data, int size);
 };
 
-void ioport__setup_arch(void);
+void ioport__setup_arch(struct kvm *kvm);
 
-int ioport__register(u16 port, struct ioport_operations *ops, int count, void *param);
-int ioport__unregister(u16 port);
+int ioport__register(struct kvm *kvm, u16 port, struct ioport_operations *ops,
+                       int count, void *param);
+int ioport__unregister(struct kvm *kvm, u16 port);
 int ioport__init(struct kvm *kvm);
 int ioport__exit(struct kvm *kvm);
 
index f009695fa09a6760264981d7a6f92e309ea8dfdc..b4606565131b8ac607da9f27363ee0b75f9328ea 100644 (file)
@@ -81,8 +81,8 @@ int kvm__register_mmio(struct kvm *kvm, u64 phys_addr, u64 phys_addr_len, bool c
                        void (*mmio_fn)(u64 addr, u8 *data, u32 len, u8 is_write, void *ptr),
                        void *ptr);
 bool kvm__deregister_mmio(struct kvm *kvm, u64 phys_addr);
-void kvm__pause(void);
-void kvm__continue(void);
+void kvm__pause(struct kvm *kvm);
+void kvm__continue(struct kvm *kvm);
 void kvm__notify_paused(void);
 int kvm__get_sock_by_instance(const char *name);
 int kvm__enumerate_instances(int (*callback)(const char *name, int pid));
index 493ce396c78c634ba39341856612de7e02e81f0f..5f63457196567e2fa12dc52f7437838a58340c8e 100644 (file)
@@ -11,9 +11,9 @@
 #define CONSOLE_HV     3
 
 int term_putc_iov(struct iovec *iov, int iovcnt, int term);
-int term_getc_iov(struct iovec *iov, int iovcnt, int term);
+int term_getc_iov(struct kvm *kvm, struct iovec *iov, int iovcnt, int term);
 int term_putc(char *addr, int cnt, int term);
-int term_getc(int term);
+int term_getc(struct kvm *kvm, int term);
 
 bool term_readable(int term);
 void term_set_tty(int term);
index 8d6e382e61cd5f3a25439c16dc6e522ee056c9bb..a4f15827acb4fa07ae524016db40e8b156bb4f5a 100644 (file)
@@ -55,12 +55,12 @@ static void ioport_remove(struct rb_root *root, struct ioport *data)
        rb_int_erase(root, &data->node);
 }
 
-int ioport__register(u16 port, struct ioport_operations *ops, int count, void *param)
+int ioport__register(struct kvm *kvm, u16 port, struct ioport_operations *ops, int count, void *param)
 {
        struct ioport *entry;
        int r;
 
-       br_write_lock();
+       br_write_lock(kvm);
        if (port == IOPORT_EMPTY)
                port = ioport__find_free_port();
 
@@ -83,20 +83,20 @@ int ioport__register(u16 port, struct ioport_operations *ops, int count, void *p
        r = ioport_insert(&ioport_tree, entry);
        if (r < 0) {
                free(entry);
-               br_write_unlock();
+               br_write_unlock(kvm);
                return r;
        }
-       br_write_unlock();
+       br_write_unlock(kvm);
 
        return port;
 }
 
-int ioport__unregister(u16 port)
+int ioport__unregister(struct kvm *kvm, u16 port)
 {
        struct ioport *entry;
        int r;
 
-       br_write_lock();
+       br_write_lock(kvm);
 
        r = -ENOENT;
        entry = ioport_search(&ioport_tree, port);
@@ -110,7 +110,7 @@ int ioport__unregister(u16 port)
        r = 0;
 
 done:
-       br_write_unlock();
+       br_write_unlock(kvm);
 
        return r;
 }
@@ -184,7 +184,7 @@ error:
 
 int ioport__init(struct kvm *kvm)
 {
-       ioport__setup_arch();
+       ioport__setup_arch(kvm);
 
        return 0;
 }
index 86d3b04014c3414549b2bef99723e19a2df6e805..be05c4988dcd8341128e42fb3591db7a9c64e1e3 100644 (file)
@@ -41,7 +41,7 @@ static void kvm_cpu_signal_handler(int signum)
        if (signum == SIGKVMEXIT) {
                if (current_kvm_cpu && current_kvm_cpu->is_running) {
                        current_kvm_cpu->is_running = false;
-                       kvm__continue();
+                       kvm__continue(current_kvm_cpu->kvm);
                }
        } else if (signum == SIGKVMPAUSE) {
                current_kvm_cpu->paused = 1;
index 6b472705022995ab6a7e840e9191f467fccd77f1..d23edd271dc2b1294b5389fc417d5cf6214fe500 100644 (file)
@@ -321,11 +321,11 @@ static void handle_pause(struct kvm *kvm, int fd, u32 type, u32 len, u8 *msg)
 
        if (type == KVM_IPC_RESUME && is_paused) {
                kvm->vm_state = KVM_VMSTATE_RUNNING;
-               kvm__continue();
+               kvm__continue(kvm);
        } else if (type == KVM_IPC_PAUSE && !is_paused) {
                kvm->vm_state = KVM_VMSTATE_PAUSED;
                ioctl(kvm->vm_fd, KVM_KVMCLOCK_CTRL);
-               kvm__pause();
+               kvm__pause(kvm);
        } else {
                return;
        }
index d107931c688feedae12e69d7d575c337265fd00f..b283171c8d7c322a5a4bdb2cb588ffbd5307bcd7 100644 (file)
@@ -55,8 +55,6 @@ const char *kvm_exit_reasons[] = {
 #endif
 };
 
-extern struct kvm *kvm;
-extern struct kvm_cpu **kvm_cpus;
 static int pause_event;
 static DEFINE_MUTEX(pause_lock);
 extern struct kvm_ext kvm_req_ext[];
@@ -413,7 +411,7 @@ void kvm__dump_mem(struct kvm *kvm, unsigned long addr, unsigned long size)
        }
 }
 
-void kvm__pause(void)
+void kvm__pause(struct kvm *kvm)
 {
        int i, paused_vcpus = 0;
 
@@ -439,7 +437,7 @@ void kvm__pause(void)
        close(pause_event);
 }
 
-void kvm__continue(void)
+void kvm__continue(struct kvm *kvm)
 {
        /* Check if the guest is running */
        if (!kvm->cpus[0] || kvm->cpus[0]->thread == 0)
index 38ce117cdb25f7f39fbb7d7ac7f446431417f8a5..5d65d280391bbd19a5f3cfd7e05fd7d856a7fe55 100644 (file)
@@ -87,9 +87,9 @@ int kvm__register_mmio(struct kvm *kvm, u64 phys_addr, u64 phys_addr_len, bool c
                        return -errno;
                }
        }
-       br_write_lock();
+       br_write_lock(kvm);
        ret = mmio_insert(&mmio_tree, mmio);
-       br_write_unlock();
+       br_write_unlock(kvm);
 
        return ret;
 }
@@ -99,10 +99,10 @@ bool kvm__deregister_mmio(struct kvm *kvm, u64 phys_addr)
        struct mmio_mapping *mmio;
        struct kvm_coalesced_mmio_zone zone;
 
-       br_write_lock();
+       br_write_lock(kvm);
        mmio = mmio_search_single(&mmio_tree, phys_addr);
        if (mmio == NULL) {
-               br_write_unlock();
+               br_write_unlock(kvm);
                return false;
        }
 
@@ -113,7 +113,7 @@ bool kvm__deregister_mmio(struct kvm *kvm, u64 phys_addr)
        ioctl(kvm->vm_fd, KVM_UNREGISTER_COALESCED_MMIO, &zone);
 
        rb_int_erase(&mmio_tree, &mmio->node);
-       br_write_unlock();
+       br_write_unlock(kvm);
 
        free(mmio);
        return true;
index fc4ad39f8985d495d60f3a958aeaa5d92474a263..a28b5e22aa17fb3c7ef0441ad34f6867ca6cfb08 100644 (file)
@@ -191,13 +191,13 @@ int pci__init(struct kvm *kvm)
 {
        int r;
 
-       r = ioport__register(PCI_CONFIG_DATA + 0, &pci_config_data_ops, 4, NULL);
+       r = ioport__register(kvm, PCI_CONFIG_DATA + 0, &pci_config_data_ops, 4, NULL);
        if (r < 0)
                return r;
 
-       r = ioport__register(PCI_CONFIG_ADDRESS + 0, &pci_config_address_ops, 4, NULL);
+       r = ioport__register(kvm, PCI_CONFIG_ADDRESS + 0, &pci_config_address_ops, 4, NULL);
        if (r < 0) {
-               ioport__unregister(PCI_CONFIG_DATA);
+               ioport__unregister(kvm, PCI_CONFIG_DATA);
                return r;
        }
 
@@ -207,8 +207,8 @@ base_init(pci__init);
 
 int pci__exit(struct kvm *kvm)
 {
-       ioport__unregister(PCI_CONFIG_DATA);
-       ioport__unregister(PCI_CONFIG_ADDRESS);
+       ioport__unregister(kvm, PCI_CONFIG_DATA);
+       ioport__unregister(kvm, PCI_CONFIG_ADDRESS);
 
        return 0;
 }
index d47a75e55dbd2fc7f86dd97f5d350069bdac5cdc..4413450f57d2e3ca5e586d606ce6e61917515e78 100644 (file)
@@ -17,7 +17,6 @@
 #define TERM_FD_IN      0
 #define TERM_FD_OUT     1
 
-extern struct kvm *kvm;
 static struct termios  orig_term;
 
 int term_escape_char   = 0x01; /* ctrl-a is used for escape */
@@ -25,7 +24,7 @@ bool term_got_escape  = false;
 
 int term_fds[4][2];
 
-int term_getc(int term)
+int term_getc(struct kvm *kvm, int term)
 {
        unsigned char c;
 
@@ -61,11 +60,11 @@ int term_putc(char *addr, int cnt, int term)
        return cnt;
 }
 
-int term_getc_iov(struct iovec *iov, int iovcnt, int term)
+int term_getc_iov(struct kvm *kvm, struct iovec *iov, int iovcnt, int term)
 {
        int c;
 
-       c = term_getc(term);
+       c = term_getc(kvm, term);
 
        if (c < 0)
                return 0;
index d6bde32e40e8f69f70040f1bc311d3e4b5203352..e08f628a47878ed2d8e3eaaa530fa5596fceb45f 100644 (file)
@@ -48,7 +48,6 @@ struct bln_dev {
 };
 
 static struct bln_dev bdev;
-extern struct kvm *kvm;
 static int compat_id = -1;
 
 static bool virtio_bln_do_io_request(struct kvm *kvm, struct bln_dev *bdev, struct virt_queue *queue)
@@ -125,7 +124,7 @@ static void virtio_bln_do_io(struct kvm *kvm, void *param)
        }
 }
 
-static int virtio_bln__collect_stats(void)
+static int virtio_bln__collect_stats(struct kvm *kvm)
 {
        u64 tmp;
 
@@ -146,7 +145,7 @@ static void virtio_bln__print_stats(struct kvm *kvm, int fd, u32 type, u32 len,
        if (WARN_ON(type != KVM_IPC_STAT || len))
                return;
 
-       if (virtio_bln__collect_stats() < 0)
+       if (virtio_bln__collect_stats(kvm) < 0)
                return;
 
        r = write(fd, bdev.stats, sizeof(bdev.stats));
index b4c0463e7f279922124fb1b6fd97c9772626da7c..88b110614de2b1bceffb6dd8668e33b0b2132c0f 100644 (file)
@@ -71,7 +71,7 @@ static void virtio_console__inject_interrupt_callback(struct kvm *kvm, void *par
 
        if (term_readable(0) && virt_queue__available(vq)) {
                head = virt_queue__get_iov(vq, iov, &out, &in, kvm);
-               len = term_getc_iov(iov, in, 0);
+               len = term_getc_iov(kvm, iov, in, 0);
                virt_queue__set_used_elem(vq, head, len);
                cdev.vdev.ops->signal_vq(kvm, &cdev.vdev, vq - cdev.vqs);
        }
index e6da7f819e963787cc4068896cf74b1f9e6a85de..d6d344a37d3332680fb08b51e15309688c8c28e2 100644 (file)
@@ -33,8 +33,6 @@
 
 struct net_dev;
 
-extern struct kvm *kvm;
-
 struct net_dev_operations {
        int (*rx)(struct iovec *iov, u16 in, struct net_dev *ndev);
        int (*tx)(struct iovec *iov, u16 in, struct net_dev *ndev);
@@ -495,8 +493,8 @@ static inline void str_to_mac(const char *str, char *mac)
        sscanf(str, "%hhx:%hhx:%hhx:%hhx:%hhx:%hhx",
                mac, mac+1, mac+2, mac+3, mac+4, mac+5);
 }
-static int set_net_param(struct virtio_net_params *p, const char *param,
-                               const char *val)
+static int set_net_param(struct kvm *kvm, struct virtio_net_params *p,
+                       const char *param, const char *val)
 {
        if (strcmp(param, "guest_mac") == 0) {
                str_to_mac(val, p->guest_mac);
@@ -561,7 +559,7 @@ int netdev_parser(const struct option *opt, const char *arg, int unset)
                if (on_cmd) {
                        cmd = cur;
                } else {
-                       if (set_net_param(&p, cmd, cur) < 0)
+                       if (set_net_param(kvm, &p, cmd, cur) < 0)
                                goto done;
                }
                on_cmd = !on_cmd;
@@ -619,10 +617,10 @@ static int virtio_net__init_one(struct virtio_net_params *params)
        }
 
        if (params->trans && strcmp(params->trans, "mmio") == 0)
-               virtio_init(kvm, ndev, &ndev->vdev, &net_dev_virtio_ops,
+               virtio_init(params->kvm, ndev, &ndev->vdev, &net_dev_virtio_ops,
                            VIRTIO_MMIO, PCI_DEVICE_ID_VIRTIO_NET, VIRTIO_ID_NET, PCI_CLASS_NET);
        else
-               virtio_init(kvm, ndev, &ndev->vdev, &net_dev_virtio_ops,
+               virtio_init(params->kvm, ndev, &ndev->vdev, &net_dev_virtio_ops,
                            VIRTIO_PCI, PCI_DEVICE_ID_VIRTIO_NET, VIRTIO_ID_NET, PCI_CLASS_NET);
 
        if (params->vhost)
index 81f95aea4eb6ab6d894953be9419d30bf6421882..b6ac571b076bcdff441616242ebcb398aa377632 100644 (file)
@@ -307,7 +307,7 @@ int virtio_pci__init(struct kvm *kvm, void *dev, struct virtio_device *vdev,
        vpci->dev = dev;
        vpci->msix_io_block = pci_get_io_space_block(PCI_IO_SIZE * 2);
 
-       r = ioport__register(IOPORT_EMPTY, &virtio_pci__io_ops, IOPORT_SIZE, vdev);
+       r = ioport__register(kvm, IOPORT_EMPTY, &virtio_pci__io_ops, IOPORT_SIZE, vdev);
        if (r < 0)
                return r;
 
@@ -379,7 +379,7 @@ int virtio_pci__init(struct kvm *kvm, void *dev, struct virtio_device *vdev,
 free_mmio:
        kvm__deregister_mmio(kvm, vpci->msix_io_block);
 free_ioport:
-       ioport__unregister(vpci->base_addr);
+       ioport__unregister(kvm, vpci->base_addr);
        return r;
 }
 
@@ -389,7 +389,7 @@ int virtio_pci__exit(struct kvm *kvm, struct virtio_device *vdev)
        int i;
 
        kvm__deregister_mmio(kvm, vpci->msix_io_block);
-       ioport__unregister(vpci->base_addr);
+       ioport__unregister(kvm, vpci->base_addr);
 
        for (i = 0; i < VIRTIO_PCI_MAX_VQ; i++)
                ioeventfd__del_event(vpci->base_addr + VIRTIO_PCI_QUEUE_NOTIFY, i);
index 86302e68b3bd931f022406b844a2d953589b20bf..4993f9daa8c47edf44c3fd57cb57f6a497d744a7 100644 (file)
@@ -46,32 +46,32 @@ static struct ioport_operations dummy_write_only_ioport_ops = {
        .io_out         = dummy_io_out,
 };
 
-void ioport__setup_arch(void)
+void ioport__setup_arch(struct kvm *kvm)
 {
        /* Legacy ioport setup */
 
        /* 0x0020 - 0x003F - 8259A PIC 1 */
-       ioport__register(0x0020, &dummy_read_write_ioport_ops, 2, NULL);
+       ioport__register(kvm, 0x0020, &dummy_read_write_ioport_ops, 2, NULL);
 
        /* PORT 0040-005F - PIT - PROGRAMMABLE INTERVAL TIMER (8253, 8254) */
-       ioport__register(0x0040, &dummy_read_write_ioport_ops, 4, NULL);
+       ioport__register(kvm, 0x0040, &dummy_read_write_ioport_ops, 4, NULL);
 
        /* 0x00A0 - 0x00AF - 8259A PIC 2 */
-       ioport__register(0x00A0, &dummy_read_write_ioport_ops, 2, NULL);
+       ioport__register(kvm, 0x00A0, &dummy_read_write_ioport_ops, 2, NULL);
 
        /* PORT 00E0-00EF are 'motherboard specific' so we use them for our
           internal debugging purposes.  */
-       ioport__register(IOPORT_DBG, &debug_ops, 1, NULL);
+       ioport__register(kvm, IOPORT_DBG, &debug_ops, 1, NULL);
 
        /* PORT 00ED - DUMMY PORT FOR DELAY??? */
-       ioport__register(0x00ED, &dummy_write_only_ioport_ops, 1, NULL);
+       ioport__register(kvm, 0x00ED, &dummy_write_only_ioport_ops, 1, NULL);
 
        /* 0x00F0 - 0x00FF - Math co-processor */
-       ioport__register(0x00F0, &dummy_write_only_ioport_ops, 2, NULL);
+       ioport__register(kvm, 0x00F0, &dummy_write_only_ioport_ops, 2, NULL);
 
        /* PORT 03D4-03D5 - COLOR VIDEO - CRT CONTROL REGISTERS */
-       ioport__register(0x03D4, &dummy_read_write_ioport_ops, 1, NULL);
-       ioport__register(0x03D5, &dummy_write_only_ioport_ops, 1, NULL);
+       ioport__register(kvm, 0x03D4, &dummy_read_write_ioport_ops, 1, NULL);
+       ioport__register(kvm, 0x03D5, &dummy_write_only_ioport_ops, 1, NULL);
 
-       ioport__register(0x402, &seabios_debug_ops, 1, NULL);
+       ioport__register(kvm, 0x402, &seabios_debug_ops, 1, NULL);
 }