X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fsvm_io.c;h=1aa76ae6133863b3f6091bcfaf1ce9c538f305e2;hb=9c9370627c5a95e3abaa1b4a6b78f6f5846f53cc;hp=aaa61017d25b0e90f245dc0f7c72acc6b70a5b73;hpb=14fa18cc54571eaa7aaa0f7d55677bdb4dad81a6;p=palacios.git diff --git a/palacios/src/palacios/svm_io.c b/palacios/src/palacios/svm_io.c index aaa6101..1aa76ae 100644 --- a/palacios/src/palacios/svm_io.c +++ b/palacios/src/palacios/svm_io.c @@ -57,6 +57,11 @@ int v3_init_svm_io_map(struct v3_vm_info * vm) { return 0; } +int v3_deinit_svm_io_map(struct v3_vm_info * vm) { + V3_FreePages(V3_PAddr(vm->io_map.arch_data), 3); + return 0; +} + // This should package up an IO request and call vmm_handle_io @@ -269,7 +274,7 @@ int v3_handle_svm_io_outs(struct guest_info * core, struct svm_io_info * io_info uint_t rep_num = 1; ullong_t mask = 0; addr_t inst_ptr; - struct v3_segment * theseg = &(core->segments.es); // default is ES + struct v3_segment * theseg = &(core->segments.ds); // default is DS // This is kind of hacky... // direction can equal either 1 or -1 @@ -359,12 +364,13 @@ int v3_handle_svm_io_outs(struct guest_info * core, struct svm_io_info * io_info PrintDebug("OUTS size=%d for %d steps\n", write_size, rep_num); while (rep_num > 0) { - addr_t host_addr; + addr_t host_addr = 0; dst_addr = get_addr_linear(core, (core->vm_regs.rsi & mask), theseg); if (v3_gva_to_hva(core, dst_addr, &host_addr) == -1) { - // either page fault or gpf... + PrintError("Could not translate outs dest addr, either page fault or gpf...\n"); + return -1; } if (hook->write(core, io_info->port, (char*)host_addr, write_size, hook->priv_data) != write_size) {