1 /*- 2 * Copyright (c) 2012 Sandvine, Inc. 3 * Copyright (c) 2012 NetApp, Inc. 4 * All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: 9 * 1. Redistributions of source code must retain the above copyright 10 * notice, this list of conditions and the following disclaimer. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 25 * SUCH DAMAGE. 26 * 27 * $FreeBSD$ 28 */ 29 30 #include <sys/cdefs.h> 31 __FBSDID("$FreeBSD$"); 32 33 #ifdef _KERNEL 34 #include <sys/param.h> 35 #include <sys/pcpu.h> 36 #include <sys/systm.h> 37 38 #include <vm/vm.h> 39 #include <vm/pmap.h> 40 41 #include <machine/pmap.h> 42 #include <machine/vmparam.h> 43 #include <machine/vmm.h> 44 #else /* !_KERNEL */ 45 #include <sys/types.h> 46 #include <sys/errno.h> 47 48 #include <machine/vmm.h> 49 50 #include <vmmapi.h> 51 #endif /* _KERNEL */ 52 53 enum cpu_mode { 54 CPU_MODE_COMPATIBILITY, /* IA-32E mode (CS.L = 0) */ 55 CPU_MODE_64BIT, /* IA-32E mode (CS.L = 1) */ 56 }; 57 58 /* struct vie_op.op_type */ 59 enum { 60 VIE_OP_TYPE_NONE = 0, 61 VIE_OP_TYPE_MOV, 62 VIE_OP_TYPE_AND, 63 VIE_OP_TYPE_LAST 64 }; 65 66 /* struct vie_op.op_flags */ 67 #define VIE_OP_F_IMM (1 << 0) /* immediate operand present */ 68 #define VIE_OP_F_IMM8 (1 << 1) /* 8-bit immediate operand */ 69 70 static const struct vie_op one_byte_opcodes[256] = { 71 [0x88] = { 72 .op_byte = 0x88, 73 .op_type = VIE_OP_TYPE_MOV, 74 }, 75 [0x89] = { 76 .op_byte = 0x89, 77 .op_type = VIE_OP_TYPE_MOV, 78 }, 79 [0x8B] = { 80 .op_byte = 0x8B, 81 .op_type = VIE_OP_TYPE_MOV, 82 }, 83 [0xC7] = { 84 .op_byte = 0xC7, 85 .op_type = VIE_OP_TYPE_MOV, 86 .op_flags = VIE_OP_F_IMM, 87 }, 88 [0x23] = { 89 .op_byte = 0x23, 90 .op_type = VIE_OP_TYPE_AND, 91 }, 92 [0x81] = { 93 /* XXX Group 1 extended opcode - not just AND */ 94 .op_byte = 0x81, 95 .op_type = VIE_OP_TYPE_AND, 96 .op_flags = VIE_OP_F_IMM, 97 } 98 }; 99 100 /* struct vie.mod */ 101 #define VIE_MOD_INDIRECT 0 102 #define VIE_MOD_INDIRECT_DISP8 1 103 #define VIE_MOD_INDIRECT_DISP32 2 104 #define VIE_MOD_DIRECT 3 105 106 /* struct vie.rm */ 107 #define VIE_RM_SIB 4 108 #define VIE_RM_DISP32 5 109 110 #define GB (1024 * 1024 * 1024) 111 112 static enum vm_reg_name gpr_map[16] = { 113 VM_REG_GUEST_RAX, 114 VM_REG_GUEST_RCX, 115 VM_REG_GUEST_RDX, 116 VM_REG_GUEST_RBX, 117 VM_REG_GUEST_RSP, 118 VM_REG_GUEST_RBP, 119 VM_REG_GUEST_RSI, 120 VM_REG_GUEST_RDI, 121 VM_REG_GUEST_R8, 122 VM_REG_GUEST_R9, 123 VM_REG_GUEST_R10, 124 VM_REG_GUEST_R11, 125 VM_REG_GUEST_R12, 126 VM_REG_GUEST_R13, 127 VM_REG_GUEST_R14, 128 VM_REG_GUEST_R15 129 }; 130 131 static uint64_t size2mask[] = { 132 [1] = 0xff, 133 [2] = 0xffff, 134 [4] = 0xffffffff, 135 [8] = 0xffffffffffffffff, 136 }; 137 138 static int 139 vie_read_register(void *vm, int vcpuid, enum vm_reg_name reg, uint64_t *rval) 140 { 141 int error; 142 143 error = vm_get_register(vm, vcpuid, reg, rval); 144 145 return (error); 146 } 147 148 static int 149 vie_read_bytereg(void *vm, int vcpuid, struct vie *vie, uint8_t *rval) 150 { 151 uint64_t val; 152 int error, rshift; 153 enum vm_reg_name reg; 154 155 rshift = 0; 156 reg = gpr_map[vie->reg]; 157 158 /* 159 * 64-bit mode imposes limitations on accessing legacy byte registers. 160 * 161 * The legacy high-byte registers cannot be addressed if the REX 162 * prefix is present. In this case the values 4, 5, 6 and 7 of the 163 * 'ModRM:reg' field address %spl, %bpl, %sil and %dil respectively. 164 * 165 * If the REX prefix is not present then the values 4, 5, 6 and 7 166 * of the 'ModRM:reg' field address the legacy high-byte registers, 167 * %ah, %ch, %dh and %bh respectively. 168 */ 169 if (!vie->rex_present) { 170 if (vie->reg & 0x4) { 171 /* 172 * Obtain the value of %ah by reading %rax and shifting 173 * right by 8 bits (same for %bh, %ch and %dh). 174 */ 175 rshift = 8; 176 reg = gpr_map[vie->reg & 0x3]; 177 } 178 } 179 180 error = vm_get_register(vm, vcpuid, reg, &val); 181 *rval = val >> rshift; 182 return (error); 183 } 184 185 static int 186 vie_update_register(void *vm, int vcpuid, enum vm_reg_name reg, 187 uint64_t val, int size) 188 { 189 int error; 190 uint64_t origval; 191 192 switch (size) { 193 case 1: 194 case 2: 195 error = vie_read_register(vm, vcpuid, reg, &origval); 196 if (error) 197 return (error); 198 val &= size2mask[size]; 199 val |= origval & ~size2mask[size]; 200 break; 201 case 4: 202 val &= 0xffffffffUL; 203 break; 204 case 8: 205 break; 206 default: 207 return (EINVAL); 208 } 209 210 error = vm_set_register(vm, vcpuid, reg, val); 211 return (error); 212 } 213 214 /* 215 * The following simplifying assumptions are made during emulation: 216 * 217 * - guest is in 64-bit mode 218 * - default address size is 64-bits 219 * - default operand size is 32-bits 220 * 221 * - operand size override is not supported 222 * 223 * - address size override is not supported 224 */ 225 static int 226 emulate_mov(void *vm, int vcpuid, uint64_t gpa, struct vie *vie, 227 mem_region_read_t memread, mem_region_write_t memwrite, void *arg) 228 { 229 int error, size; 230 enum vm_reg_name reg; 231 uint8_t byte; 232 uint64_t val; 233 234 size = 4; 235 error = EINVAL; 236 237 switch (vie->op.op_byte) { 238 case 0x88: 239 /* 240 * MOV byte from reg (ModRM:reg) to mem (ModRM:r/m) 241 * 88/r: mov r/m8, r8 242 * REX + 88/r: mov r/m8, r8 (%ah, %ch, %dh, %bh not available) 243 */ 244 size = 1; 245 error = vie_read_bytereg(vm, vcpuid, vie, &byte); 246 if (error == 0) 247 error = memwrite(vm, vcpuid, gpa, byte, size, arg); 248 break; 249 case 0x89: 250 /* 251 * MOV from reg (ModRM:reg) to mem (ModRM:r/m) 252 * 89/r: mov r/m32, r32 253 * REX.W + 89/r mov r/m64, r64 254 */ 255 if (vie->rex_w) 256 size = 8; 257 reg = gpr_map[vie->reg]; 258 error = vie_read_register(vm, vcpuid, reg, &val); 259 if (error == 0) { 260 val &= size2mask[size]; 261 error = memwrite(vm, vcpuid, gpa, val, size, arg); 262 } 263 break; 264 case 0x8B: 265 /* 266 * MOV from mem (ModRM:r/m) to reg (ModRM:reg) 267 * 8B/r: mov r32, r/m32 268 * REX.W 8B/r: mov r64, r/m64 269 */ 270 if (vie->rex_w) 271 size = 8; 272 error = memread(vm, vcpuid, gpa, &val, size, arg); 273 if (error == 0) { 274 reg = gpr_map[vie->reg]; 275 error = vie_update_register(vm, vcpuid, reg, val, size); 276 } 277 break; 278 case 0xC7: 279 /* 280 * MOV from imm32 to mem (ModRM:r/m) 281 * C7/0 mov r/m32, imm32 282 * REX.W + C7/0 mov r/m64, imm32 (sign-extended to 64-bits) 283 */ 284 val = vie->immediate; /* already sign-extended */ 285 286 if (vie->rex_w) 287 size = 8; 288 289 if (size != 8) 290 val &= size2mask[size]; 291 292 error = memwrite(vm, vcpuid, gpa, val, size, arg); 293 break; 294 default: 295 break; 296 } 297 298 return (error); 299 } 300 301 static int 302 emulate_and(void *vm, int vcpuid, uint64_t gpa, struct vie *vie, 303 mem_region_read_t memread, mem_region_write_t memwrite, void *arg) 304 { 305 int error, size; 306 enum vm_reg_name reg; 307 uint64_t val1, val2; 308 309 size = 4; 310 error = EINVAL; 311 312 switch (vie->op.op_byte) { 313 case 0x23: 314 /* 315 * AND reg (ModRM:reg) and mem (ModRM:r/m) and store the 316 * result in reg. 317 * 318 * 23/r and r32, r/m32 319 * REX.W + 23/r and r64, r/m64 320 */ 321 if (vie->rex_w) 322 size = 8; 323 324 /* get the first operand */ 325 reg = gpr_map[vie->reg]; 326 error = vie_read_register(vm, vcpuid, reg, &val1); 327 if (error) 328 break; 329 330 /* get the second operand */ 331 error = memread(vm, vcpuid, gpa, &val2, size, arg); 332 if (error) 333 break; 334 335 /* perform the operation and write the result */ 336 val1 &= val2; 337 error = vie_update_register(vm, vcpuid, reg, val1, size); 338 break; 339 case 0x81: 340 /* 341 * AND reg (ModRM:reg) with immediate and store the 342 * result in reg 343 * 344 * 81/ and r/m32, imm32 345 * REX.W + 81/ and r/m64, imm32 sign-extended to 64 346 * 347 * Currently, only the AND operation of the 0x81 opcode 348 * is implemented (ModRM:reg = b100). 349 */ 350 if ((vie->reg & 7) != 4) 351 break; 352 353 if (vie->rex_w) 354 size = 8; 355 356 /* get the first operand */ 357 error = memread(vm, vcpuid, gpa, &val1, size, arg); 358 if (error) 359 break; 360 361 /* 362 * perform the operation with the pre-fetched immediate 363 * operand and write the result 364 */ 365 val1 &= vie->immediate; 366 error = memwrite(vm, vcpuid, gpa, val1, size, arg); 367 break; 368 default: 369 break; 370 } 371 return (error); 372 } 373 374 int 375 vmm_emulate_instruction(void *vm, int vcpuid, uint64_t gpa, struct vie *vie, 376 mem_region_read_t memread, mem_region_write_t memwrite, 377 void *memarg) 378 { 379 int error; 380 381 if (!vie->decoded) 382 return (EINVAL); 383 384 switch (vie->op.op_type) { 385 case VIE_OP_TYPE_MOV: 386 error = emulate_mov(vm, vcpuid, gpa, vie, 387 memread, memwrite, memarg); 388 break; 389 case VIE_OP_TYPE_AND: 390 error = emulate_and(vm, vcpuid, gpa, vie, 391 memread, memwrite, memarg); 392 break; 393 default: 394 error = EINVAL; 395 break; 396 } 397 398 return (error); 399 } 400 401 #ifdef _KERNEL 402 static void 403 vie_init(struct vie *vie) 404 { 405 406 bzero(vie, sizeof(struct vie)); 407 408 vie->base_register = VM_REG_LAST; 409 vie->index_register = VM_REG_LAST; 410 } 411 412 static int 413 gla2gpa(struct vm *vm, uint64_t gla, uint64_t ptpphys, 414 uint64_t *gpa, uint64_t *gpaend) 415 { 416 vm_paddr_t hpa; 417 int nlevels, ptpshift, ptpindex; 418 uint64_t *ptpbase, pte, pgsize; 419 420 /* 421 * XXX assumes 64-bit guest with 4 page walk levels 422 */ 423 nlevels = 4; 424 while (--nlevels >= 0) { 425 /* Zero out the lower 12 bits and the upper 12 bits */ 426 ptpphys >>= 12; ptpphys <<= 24; ptpphys >>= 12; 427 428 hpa = vm_gpa2hpa(vm, ptpphys, PAGE_SIZE); 429 if (hpa == -1) 430 goto error; 431 432 ptpbase = (uint64_t *)PHYS_TO_DMAP(hpa); 433 434 ptpshift = PAGE_SHIFT + nlevels * 9; 435 ptpindex = (gla >> ptpshift) & 0x1FF; 436 pgsize = 1UL << ptpshift; 437 438 pte = ptpbase[ptpindex]; 439 440 if ((pte & PG_V) == 0) 441 goto error; 442 443 if (pte & PG_PS) { 444 if (pgsize > 1 * GB) 445 goto error; 446 else 447 break; 448 } 449 450 ptpphys = pte; 451 } 452 453 /* Zero out the lower 'ptpshift' bits and the upper 12 bits */ 454 pte >>= ptpshift; pte <<= (ptpshift + 12); pte >>= 12; 455 *gpa = pte | (gla & (pgsize - 1)); 456 *gpaend = pte + pgsize; 457 return (0); 458 459 error: 460 return (-1); 461 } 462 463 int 464 vmm_fetch_instruction(struct vm *vm, int cpuid, uint64_t rip, int inst_length, 465 uint64_t cr3, struct vie *vie) 466 { 467 int n, err; 468 uint64_t hpa, gpa, gpaend, off; 469 470 /* 471 * XXX cache previously fetched instructions using 'rip' as the tag 472 */ 473 474 if (inst_length > VIE_INST_SIZE) 475 panic("vmm_fetch_instruction: invalid length %d", inst_length); 476 477 vie_init(vie); 478 479 /* Copy the instruction into 'vie' */ 480 while (vie->num_valid < inst_length) { 481 err = gla2gpa(vm, rip, cr3, &gpa, &gpaend); 482 if (err) 483 break; 484 485 off = gpa & PAGE_MASK; 486 n = min(inst_length - vie->num_valid, PAGE_SIZE - off); 487 488 hpa = vm_gpa2hpa(vm, gpa, n); 489 if (hpa == -1) 490 break; 491 492 bcopy((void *)PHYS_TO_DMAP(hpa), &vie->inst[vie->num_valid], n); 493 494 rip += n; 495 vie->num_valid += n; 496 } 497 498 if (vie->num_valid == inst_length) 499 return (0); 500 else 501 return (-1); 502 } 503 504 static int 505 vie_peek(struct vie *vie, uint8_t *x) 506 { 507 508 if (vie->num_processed < vie->num_valid) { 509 *x = vie->inst[vie->num_processed]; 510 return (0); 511 } else 512 return (-1); 513 } 514 515 static void 516 vie_advance(struct vie *vie) 517 { 518 519 vie->num_processed++; 520 } 521 522 static int 523 decode_rex(struct vie *vie) 524 { 525 uint8_t x; 526 527 if (vie_peek(vie, &x)) 528 return (-1); 529 530 if (x >= 0x40 && x <= 0x4F) { 531 vie->rex_present = 1; 532 533 vie->rex_w = x & 0x8 ? 1 : 0; 534 vie->rex_r = x & 0x4 ? 1 : 0; 535 vie->rex_x = x & 0x2 ? 1 : 0; 536 vie->rex_b = x & 0x1 ? 1 : 0; 537 538 vie_advance(vie); 539 } 540 541 return (0); 542 } 543 544 static int 545 decode_opcode(struct vie *vie) 546 { 547 uint8_t x; 548 549 if (vie_peek(vie, &x)) 550 return (-1); 551 552 vie->op = one_byte_opcodes[x]; 553 554 if (vie->op.op_type == VIE_OP_TYPE_NONE) 555 return (-1); 556 557 vie_advance(vie); 558 return (0); 559 } 560 561 static int 562 decode_modrm(struct vie *vie) 563 { 564 uint8_t x; 565 enum cpu_mode cpu_mode; 566 567 /* 568 * XXX assuming that guest is in IA-32E 64-bit mode 569 */ 570 cpu_mode = CPU_MODE_64BIT; 571 572 if (vie_peek(vie, &x)) 573 return (-1); 574 575 vie->mod = (x >> 6) & 0x3; 576 vie->rm = (x >> 0) & 0x7; 577 vie->reg = (x >> 3) & 0x7; 578 579 /* 580 * A direct addressing mode makes no sense in the context of an EPT 581 * fault. There has to be a memory access involved to cause the 582 * EPT fault. 583 */ 584 if (vie->mod == VIE_MOD_DIRECT) 585 return (-1); 586 587 if ((vie->mod == VIE_MOD_INDIRECT && vie->rm == VIE_RM_DISP32) || 588 (vie->mod != VIE_MOD_DIRECT && vie->rm == VIE_RM_SIB)) { 589 /* 590 * Table 2-5: Special Cases of REX Encodings 591 * 592 * mod=0, r/m=5 is used in the compatibility mode to 593 * indicate a disp32 without a base register. 594 * 595 * mod!=3, r/m=4 is used in the compatibility mode to 596 * indicate that the SIB byte is present. 597 * 598 * The 'b' bit in the REX prefix is don't care in 599 * this case. 600 */ 601 } else { 602 vie->rm |= (vie->rex_b << 3); 603 } 604 605 vie->reg |= (vie->rex_r << 3); 606 607 /* SIB */ 608 if (vie->mod != VIE_MOD_DIRECT && vie->rm == VIE_RM_SIB) 609 goto done; 610 611 vie->base_register = gpr_map[vie->rm]; 612 613 switch (vie->mod) { 614 case VIE_MOD_INDIRECT_DISP8: 615 vie->disp_bytes = 1; 616 break; 617 case VIE_MOD_INDIRECT_DISP32: 618 vie->disp_bytes = 4; 619 break; 620 case VIE_MOD_INDIRECT: 621 if (vie->rm == VIE_RM_DISP32) { 622 vie->disp_bytes = 4; 623 /* 624 * Table 2-7. RIP-Relative Addressing 625 * 626 * In 64-bit mode mod=00 r/m=101 implies [rip] + disp32 627 * whereas in compatibility mode it just implies disp32. 628 */ 629 630 if (cpu_mode == CPU_MODE_64BIT) 631 vie->base_register = VM_REG_GUEST_RIP; 632 else 633 vie->base_register = VM_REG_LAST; 634 635 } 636 break; 637 } 638 639 /* Figure out immediate operand size (if any) */ 640 if (vie->op.op_flags & VIE_OP_F_IMM) 641 vie->imm_bytes = 4; 642 else if (vie->op.op_flags & VIE_OP_F_IMM8) 643 vie->imm_bytes = 1; 644 645 done: 646 vie_advance(vie); 647 648 return (0); 649 } 650 651 static int 652 decode_sib(struct vie *vie) 653 { 654 uint8_t x; 655 656 /* Proceed only if SIB byte is present */ 657 if (vie->mod == VIE_MOD_DIRECT || vie->rm != VIE_RM_SIB) 658 return (0); 659 660 if (vie_peek(vie, &x)) 661 return (-1); 662 663 /* De-construct the SIB byte */ 664 vie->ss = (x >> 6) & 0x3; 665 vie->index = (x >> 3) & 0x7; 666 vie->base = (x >> 0) & 0x7; 667 668 /* Apply the REX prefix modifiers */ 669 vie->index |= vie->rex_x << 3; 670 vie->base |= vie->rex_b << 3; 671 672 switch (vie->mod) { 673 case VIE_MOD_INDIRECT_DISP8: 674 vie->disp_bytes = 1; 675 break; 676 case VIE_MOD_INDIRECT_DISP32: 677 vie->disp_bytes = 4; 678 break; 679 } 680 681 if (vie->mod == VIE_MOD_INDIRECT && 682 (vie->base == 5 || vie->base == 13)) { 683 /* 684 * Special case when base register is unused if mod = 0 685 * and base = %rbp or %r13. 686 * 687 * Documented in: 688 * Table 2-3: 32-bit Addressing Forms with the SIB Byte 689 * Table 2-5: Special Cases of REX Encodings 690 */ 691 vie->disp_bytes = 4; 692 } else { 693 vie->base_register = gpr_map[vie->base]; 694 } 695 696 /* 697 * All encodings of 'index' are valid except for %rsp (4). 698 * 699 * Documented in: 700 * Table 2-3: 32-bit Addressing Forms with the SIB Byte 701 * Table 2-5: Special Cases of REX Encodings 702 */ 703 if (vie->index != 4) 704 vie->index_register = gpr_map[vie->index]; 705 706 /* 'scale' makes sense only in the context of an index register */ 707 if (vie->index_register < VM_REG_LAST) 708 vie->scale = 1 << vie->ss; 709 710 vie_advance(vie); 711 712 return (0); 713 } 714 715 static int 716 decode_displacement(struct vie *vie) 717 { 718 int n, i; 719 uint8_t x; 720 721 union { 722 char buf[4]; 723 int8_t signed8; 724 int32_t signed32; 725 } u; 726 727 if ((n = vie->disp_bytes) == 0) 728 return (0); 729 730 if (n != 1 && n != 4) 731 panic("decode_displacement: invalid disp_bytes %d", n); 732 733 for (i = 0; i < n; i++) { 734 if (vie_peek(vie, &x)) 735 return (-1); 736 737 u.buf[i] = x; 738 vie_advance(vie); 739 } 740 741 if (n == 1) 742 vie->displacement = u.signed8; /* sign-extended */ 743 else 744 vie->displacement = u.signed32; /* sign-extended */ 745 746 return (0); 747 } 748 749 static int 750 decode_immediate(struct vie *vie) 751 { 752 int i, n; 753 uint8_t x; 754 union { 755 char buf[4]; 756 int8_t signed8; 757 int32_t signed32; 758 } u; 759 760 if ((n = vie->imm_bytes) == 0) 761 return (0); 762 763 if (n != 1 && n != 4) 764 panic("decode_immediate: invalid imm_bytes %d", n); 765 766 for (i = 0; i < n; i++) { 767 if (vie_peek(vie, &x)) 768 return (-1); 769 770 u.buf[i] = x; 771 vie_advance(vie); 772 } 773 774 if (n == 1) 775 vie->immediate = u.signed8; /* sign-extended */ 776 else 777 vie->immediate = u.signed32; /* sign-extended */ 778 779 return (0); 780 } 781 782 /* 783 * Verify that the 'guest linear address' provided as collateral of the nested 784 * page table fault matches with our instruction decoding. 785 */ 786 static int 787 verify_gla(struct vm *vm, int cpuid, uint64_t gla, struct vie *vie) 788 { 789 int error; 790 uint64_t base, idx; 791 792 /* Skip 'gla' verification */ 793 if (gla == VIE_INVALID_GLA) 794 return (0); 795 796 base = 0; 797 if (vie->base_register != VM_REG_LAST) { 798 error = vm_get_register(vm, cpuid, vie->base_register, &base); 799 if (error) { 800 printf("verify_gla: error %d getting base reg %d\n", 801 error, vie->base_register); 802 return (-1); 803 } 804 805 /* 806 * RIP-relative addressing starts from the following 807 * instruction 808 */ 809 if (vie->base_register == VM_REG_GUEST_RIP) 810 base += vie->num_valid; 811 } 812 813 idx = 0; 814 if (vie->index_register != VM_REG_LAST) { 815 error = vm_get_register(vm, cpuid, vie->index_register, &idx); 816 if (error) { 817 printf("verify_gla: error %d getting index reg %d\n", 818 error, vie->index_register); 819 return (-1); 820 } 821 } 822 823 if (base + vie->scale * idx + vie->displacement != gla) { 824 printf("verify_gla mismatch: " 825 "base(0x%0lx), scale(%d), index(0x%0lx), " 826 "disp(0x%0lx), gla(0x%0lx)\n", 827 base, vie->scale, idx, vie->displacement, gla); 828 return (-1); 829 } 830 831 return (0); 832 } 833 834 int 835 vmm_decode_instruction(struct vm *vm, int cpuid, uint64_t gla, struct vie *vie) 836 { 837 838 if (decode_rex(vie)) 839 return (-1); 840 841 if (decode_opcode(vie)) 842 return (-1); 843 844 if (decode_modrm(vie)) 845 return (-1); 846 847 if (decode_sib(vie)) 848 return (-1); 849 850 if (decode_displacement(vie)) 851 return (-1); 852 853 if (decode_immediate(vie)) 854 return (-1); 855 856 if (verify_gla(vm, cpuid, gla, vie)) 857 return (-1); 858 859 vie->decoded = 1; /* success */ 860 861 return (0); 862 } 863 #endif /* _KERNEL */ 864