久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

KVM based VM example cpde的示例代碼

146次閱讀
沒有評論

共計 4534 個字符,預計需要花費 12 分鐘才能閱讀完成。

這篇文章將為大家詳細講解有關 KVM based VM example cpde 的示例代碼,丸趣 TV 小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

/* Sample code for /dev/kvm API
 *
 * Copyright (c) 2015 Intel Corporation
 * Author: Josh Triplett  josh@joshtriplett.org 
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the  Software), to
 * deal in the Software without restriction, including without limitation the
 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
 * sell copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED  AS IS , WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 * IN THE SOFTWARE.
 */
#include  err.h 
#include  fcntl.h 
#include  linux/kvm.h 
#include  stdint.h 
#include  stdio.h 
#include  stdlib.h 
#include  string.h 
#include  sys/ioctl.h 
#include  sys/mman.h 
#include  sys/stat.h 
#include  sys/types.h 
int main(void)
 int kvm, vmfd, vcpufd, ret;
 const uint8_t code[] = {
 0xba, 0xf8, 0x03, /* mov $0x3f8, %dx */
 0x00, 0xd8, /* add %bl, %al */
 0x04,  0 , /* add $ 0 , %al */
 0xee, /* out %al, (%dx) */
 0xb0,  \n , /* mov $ \n , %al */
 0xee, /* out %al, (%dx) */
 0xf4, /* hlt */
 };
 uint8_t *mem;
 struct kvm_sregs sregs;
 size_t mmap_size;
 struct kvm_run *run;
 kvm = open(/dev/kvm , O_RDWR | O_CLOEXEC);
 if (kvm == -1)
 err(1,  /dev/kvm 
 /* Make sure we have the stable version of the API */
 ret = ioctl(kvm, KVM_GET_API_VERSION, NULL);
 if (ret == -1)
 err(1,  KVM_GET_API_VERSION 
 if (ret != 12)
 errx(1,  KVM_GET_API_VERSION %d, expected 12 , ret);
 vmfd = ioctl(kvm, KVM_CREATE_VM, (unsigned long)0);
 if (vmfd == -1)
 err(1,  KVM_CREATE_VM 
 /* Allocate one aligned page of guest memory to hold the code. */
 mem = mmap(NULL, 0x1000, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANONYMOUS, -1, 0);
 if (!mem)
 err(1,  allocating guest memory 
 memcpy(mem, code, sizeof(code));
 /* Map it to the second page frame (to avoid the real-mode IDT at 0). */
 struct kvm_userspace_memory_region region = {
 .slot = 0,
 .guest_phys_addr = 0x1000,
 .memory_size = 0x1000,
 .userspace_addr = (uint64_t)mem,
 };
 ret = ioctl(vmfd, KVM_SET_USER_MEMORY_REGION,  region);
 if (ret == -1)
 err(1,  KVM_SET_USER_MEMORY_REGION 
 vcpufd = ioctl(vmfd, KVM_CREATE_VCPU, (unsigned long)0);
 if (vcpufd == -1)
 err(1,  KVM_CREATE_VCPU 
 /* Map the shared kvm_run structure and following data. */
 ret = ioctl(kvm, KVM_GET_VCPU_MMAP_SIZE, NULL);
 if (ret == -1)
 err(1,  KVM_GET_VCPU_MMAP_SIZE 
 mmap_size = ret;
 if (mmap_size   sizeof(*run))
 errx(1,  KVM_GET_VCPU_MMAP_SIZE unexpectedly small 
 run = mmap(NULL, mmap_size, PROT_READ | PROT_WRITE, MAP_SHARED, vcpufd, 0);
 if (!run)
 err(1,  mmap vcpu 
 /* Initialize CS to point at 0, via a read-modify-write of sregs. */
 ret = ioctl(vcpufd, KVM_GET_SREGS,  sregs);
 if (ret == -1)
 err(1,  KVM_GET_SREGS 
 sregs.cs.base = 0;
 sregs.cs.selector = 0;
 ret = ioctl(vcpufd, KVM_SET_SREGS,  sregs);
 if (ret == -1)
 err(1,  KVM_SET_SREGS 
 /* Initialize registers: instruction pointer for our code, addends, and
 * initial flags required by x86 architecture. */
 struct kvm_regs regs = {
 .rip = 0x1000,
 .rax = 2,
 .rbx = 2,
 .rflags = 0x2,
 };
 ret = ioctl(vcpufd, KVM_SET_REGS,  regs);
 if (ret == -1)
 err(1,  KVM_SET_REGS 
 /* Repeatedly run code and handle VM exits. */
 while (1) { ret = ioctl(vcpufd, KVM_RUN, NULL);
 if (ret == -1)
 err(1,  KVM_RUN 
 switch (run- exit_reason) {
 case KVM_EXIT_HLT:
 puts( KVM_EXIT_HLT 
 return 0;
 case KVM_EXIT_IO:
 if (run- io.direction == KVM_EXIT_IO_OUT   run- io.size == 1   run- io.port == 0x3f8   run- io.count == 1)
 putchar(*(((char *)run) + run- io.data_offset));
 else
 errx(1,  unhandled KVM_EXIT_IO 
 break;
 case KVM_EXIT_FAIL_ENTRY:
 errx(1,  KVM_EXIT_FAIL_ENTRY: hardware_entry_failure_reason = 0x%llx ,
 (unsigned long long)run- fail_entry.hardware_entry_failure_reason);
 case KVM_EXIT_INTERNAL_ERROR:
 errx(1,  KVM_EXIT_INTERNAL_ERROR: suberror = 0x%x , run- internal.suberror);
 default:
 errx(1,  exit_reason = 0x%x , run- exit_reason);
 }
 }
}

關于“KVM based VM example cpde 的示例代碼”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-08-16發表,共計4534字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 延川县| 思茅市| 通道| 马龙县| 九江市| 宜城市| 和田市| 姚安县| 遂溪县| 嘉荫县| 申扎县| 庆元县| 深水埗区| 刚察县| 阳谷县| 云林县| 神农架林区| 阿坝县| 溧阳市| 米林县| 福清市| 云林县| 定襄县| 泰顺县| 合江县| 大渡口区| 澜沧| 泾阳县| 鹤庆县| 贺州市| 石首市| 徐闻县| 金华市| 隆尧县| 高雄市| 信宜市| 如东县| 田阳县| 镶黄旗| 永寿县| 岳西县|