{{sellerTotalView > 1 ? __("sellers", {number: sellerTotalView}) : __("seller", {number: sellerTotalView}) }}, {{numTotalView > 1 ? __("items", {number: numTotalView}) : __("item", {number: numTotalView}) }}
무료배송

배송 지역 전환

지역에 따라 재고 및 배송 속도가 다를 수 있습니다.

위치 기록

{{email ? __('Got it!') : __('Restock Alert')}}

상품입고 후 바로 알려드리겠습니다.

취소
Yami

Jingdong book

处理器虚拟化技术

{{buttonTypePin == 3 ? __("Scan to view more PinGo") : __("Scan to start")}}

处理器虚拟化技术

{{__(":people-members", {'people': item.limit_people_count})}} {{ itemCurrency }}{{ item.valid_price }} {{ itemCurrency }}{{ item.invalid_price }} {{ itemDiscount }}
후 종료
{{ itemCurrency }}{{ item.valid_price }}
{{ itemCurrency }}{{ priceFormat(item.valid_price / item.bundle_specification) }}/{{ item.unit }}
{{ itemDiscount }}
{{ itemCurrency }}{{ item.valid_price }} {{ itemCurrency }}{{ priceFormat(item.valid_price / item.bundle_specification) }}/{{ item.unit }} {{ itemCurrency }}{{ item.invalid_price }} {{itemDiscount}}
{{ itemCurrency }}{{ item.valid_price }}
후에 세일 종료
후 초특가세일 시작 후 초특가세일 종료
{{ getSeckillDesc(item.seckill_data) }}
{{ __( "Pay with Gift Card to get sale price: :itemCurrency:price", { 'itemCurrency' : itemCurrency, 'price' : (item.giftcard_price ? priceFormat(item.giftcard_price) : '0.00') } ) }} ({{ itemCurrency }}{{ priceFormat(item.giftcard_price / item.bundle_specification) }}/{{ item.unit }}) 상세정보
상품 유효 기간

판매 중단

이 상품이 언제 재입고될지는 알 수 없습니다.

현재 주소로 배송 불가
품절

제품 설명

제품 세부 정보 전체보기
Content Description

《处理器虚拟化技术》针对在Intel处理器端的虚拟化技术(Intel Virtualization Technology for x86,即Intel VT-x)进行全面讲解。在Intel VT-x技术下实现了VMX(Virtual-Machine Extensions,虚拟机扩展)架构平台来支持对处理器的虚拟化管理。因此,VMX架构是Intel VT-x技术的核心。本书内容围绕VMX架构实现细节展开全面讲解。但Intel VT-d(Virtualization Technology for Directed I/O)和Intel VT-c(Virtualization Technology for Connectivity)技术并不在本书的描述范围。同时,也不针对AMD-v技术进行讨论。
《处理器虚拟化技术》共分为7章,书的整体结构也较为规整,可读性比较强。本书共提供14个例子,对VMX架构的一些特色功能进行辅助讲解。
读者阅读《处理器虚拟化技术》,可以学习Intel VT-x技术的VMX架构知识,并且对整个x86/x64体系有更深入的了解!可以说,不了解VMX架构,根本算不上对x86/x64体系熟悉,因为,在处理器的虚拟化技术里需要使用全方位的体系知识,对处理器在非常细节的地方进行虚拟化处理。

Author Description

邓志,1977年生于广东,在银行工作十余年,现自由职业者。对计算机有一股热情和蛮劲,善于思考,特别喜欢琢磨底层架构。熟悉C语言,并且精通x86/x64平台的汇编语言与机器指令系统,能用汇编写简易的OS核心。

Catalogue

第1章 系统平台
1.1 环境及工具
1.1.1 使用vmware
1.1.2 使用bochs
1.1.3 在真实机器上运行
1.1.4 Build工具
1.2 64位与32位代码的混合编译
1.2.1 使用符号__X64
1.2.2 指令操作数
1.2.3 64-bit模式下其他指令处理
1.2.4 函数重定义表
1.3 地址空间
1.4 数据结构
1.4.1 PCB结构
1.4.2 LSB结构
1.4.3 初始化PCB
1.4.4 SDA结构
1.4.5 初始化SDA
1.4.6 DRS结构
1.5 系统启动
1.5.1 Boot阶段
1.5.2 Stage1阶段
1.5.2.1 Stage1阶段的多处理器初始化
1.5.2.2 BSP的收尾工作
1.5.2.3 APs的stage1阶段工作
1.5.3 Stage2阶段
1.5.3.1 BSP在stage2最后处理
1.5.3.2 APs在stage2阶段收尾工作
1.5.4 Stage3阶段
1.5.4.1 BSP在stage3阶段的最后工作
1.5.4.2 APs在stage3阶段收尾工作
1.5.5 例子1-1
1.6 系统机制
1.6.1 分页机制
1.6.1.1 PAE分页模式实现
1.6.1.2 IA-32e分页模式实现
1.6.2 多处理器机制
1.6.2.1 调度任务
1.6.2.2 处理器切换
1.6.3 调试记录机制
1.6.3.1 例子1-2
1.6.3.2 运行结果

第2章 VMX架构基础
2.1 虚拟化概述
2.1.1 虚拟设备
2.1.2 地址转换
2.1.3 设备的I/O访问
2.2 VMX架构
2.2.1 VMM与VM
2.2.2 VMXON与VMCS区域
2.2.3 检测VMX支持
2.2.4 开启VMX进入允许
2.3 VMX operation模式
2.3.1 进入VMX operation模式
2.3.2 进入VMX operation的制约
2.3.2.1 IA32_FEATURE_CONTROL寄存器
2.3.2.2 CR0与CR4固定位
2.3.2.3 A20M模式
2.3.3 设置VMXON区域
2.3.3.1 分配VMXON区域
2.3.3.2 VMXON区域初始设置
2.3.4 退出VMX operation模式
2.4 VMX operation模式切换
2.4.1 VM entry
2.4.2 VM exit
2.4.3 SMM双重监控处理下
2.5 VMX能力的检测
2.5.1 检测是否支持VMX
2.5.2 通过MSR组检查VMX能力
2.5.3 例子2-1
2.5.4 基本信息检测
2.5.5 允许为0以及允许为1位
2.5.5.1 决定VMX支持的功能
2.5.5.2 控制字段设置算法
2.5.6 VM-execution控制字段
2.5.6.1 Pin-based VM-execution control字段
2.5.6.2 primary processor-based VM-execution control字段
2.5.6.3 secondary processor-based VM-execution control字段
2.5.7 VM-exit control字段
2.5.8 VM-entry control字段
2.5.9 VM-function control字段
2.5.10 CR0与CR4的固定位
2.5.10.1 CR0与CR4寄存器设置算法
2.5.11 VMX杂项信息
2.5.12 VMCS区域字段index值
2.5.13 VPID与EPT能力
2.6 VMX指令
2.6.1 VMX指令执行环境
2.6.2 指令执行的状态
2.6.3 VMfailValid事件原因
2.6.4 指令异常优先级
2.6.5 VMCS管理指令
2.6.5.1 VMPTRLD指令
2.6.5.2 VMPTRST指令
2.6.5.3 VMCLEAR指令
2.6.5.4 VMREAD指令
2.6.5.5 VMWRITE指令
2.6.6 VMX模式管理指令
2.6.6.1 VMXON指令
2.6.6.2 VMXOFF指令
2.6.6.3 VMLAUNCH指令
2.6.6.4 VMRESUME指令
2.6.6.5 返回到executive monitor
2.6.7 cache刷新指令
2.6.7.1 INVEPT指令
2.6.7.2 INVVPID指令
2.6.8 调用服务例程指令
2.6.8.1 VMCALL指令
2.6.8.2 VMFUNC指令

第3章 VMCS结构
3.1 VMCS状态
3.1.1 activity属性
3.1.2 current属性
3.1.3 launch属性
3.2 VMCS区域
3.2.1 VMXON区域
3.2.2 Executive-VMCS与SMM-transfer VMCS
3.2.3 VMCS区域格式
3.3 访问VMCS字段
3.3.1 字段ID格式
3.3.2 不同宽度的字段处理
3.4 字段ID值
3.4.1 16位字段ID
3.4.2 64位字段ID
3.4.3 32位字段ID
3.4.4 natural-width字段ID
3.5 VM-execution控制类字段
3.5.1 Pin-based VM-execution control字段
3.5.2 processor-based VM-execution control字段
3.5.2.1 primary processor-based VM-execution control字段
3.5.2.2 secondary processor-based VM-execution control字段
3.5.3 exception bitmap字段
3.5.4 PFEC_MASK与PFEC_MATCH字段
3.5.5 I/O bitmap address字段
3.5.6 TSC offset字段
3.5.7 guest/host mask与read shadow字段
3.5.8 CR3-target字段
3.5.9 APIC-access address字段
3.5.10 virtual-APIC address字段
3.5.11 TPR threshold字段
3.5.12 EOI-exit bitmap字段
3.5.13 posted-interrupt notification vector字段
3.5.14 posted-interrupt descriptor address字段
3.5.15 MSR bitmap address字段
3.5.16 executive-VMCS pointer
3.5.17 EPTP字段
3.5.18 virtual-processor identifier字段
3.5.19 PLE_Gap与PLE_Window字段
3.5.20 VM-function control字段
3.5.21 EPTP-list address字段
3.6 VM-entry控制类字段
3.6.1 VM-entry control字段
3.6.2 VM-entry MSR-load字段
3.6.3 事件注入控制字段
3.6.3.1 VM-entry interruption information字段
3.6.3.2 VM-entry exception error code字段
3.6.3.3 VM-entry instruction length字段
3.7 VM-exit控制类字段
3.7.1 VM-exit control字段
3.7.2 VM-exit MSR-store与MSR-load字段
3.8 guest-state区域字段
3.8.1 段寄存器字段
3.8.1.1 access rigth字段
3.8.2 GDTR与IDTR字段
3.8.3 MSR字段
3.8.4 SMBASE字段
3.8.5 activity state字段
3.8.6 interruptibility state字段
3.8.7 pending debug exceptions字段
3.8.7.1 #DB异常的处理
3.8.8 VMCS link pointer字段
3.8.9 VMX-preemption timer value字段
3.8.10 PDPTEs字段
3.8.11 guest interrupt status字段
3.9 host-state区域字段
3.10 VM-exit信息类字段
3.10.1 基本信息类字段
3.10.1.1 Exit reason字段
3.10.1.2 VM-exit原因
3.10.1.3 Exit qualification字段
3.10.1.4 由某些指令引发的VM-exit
3.10.1.5 由#DB异常引发的VM-exit
3.10.1.6 由#PF异常引发的VM-exit
3.10.1.7 由SIPI引发的VM-exit
3.10.1.8 由I/O SMI引发的VM-exit
3.10.1.9 由任务切换引发的VM-exit
3.10.1.10 访问控制寄存器引发的VM-exit
3.10.1.11 由MOV-DR指令引发的VM-exit
3.10.1.12 由I/O指令引发的VM-exit
3.10.1.13 由于访问APIC-access page引发的VM-exit
3.10.1.14 由EPT violation引发的VM-exit
3.10.1.15 由EOI虚拟化引发的VM-exit
3.10.1.16 由APIC-write引发的VM-exit
3.10.1.17 guest-linear address字段
3.10.1.18 guest-physical address字段
3.10.2 直接向量事件类信息字段
3.10.2.1 VM-exit interruption information字段
3.10.2.2 VM-exit interruption error code字段
3.10.3 间接向量事件类信息字段
3.10.3.1 IDT-vectoring information字段
3.10.3.2 IDT-vectoring error code字段
3.10.4 指令类信息字段
3.10.4.1 VM-exit instruction length字段
3.10.4.2 VM-exit instruction information字段
3.10.5 I/O SMI信息类字段
3.10.6 指令错误类字段
3.11 VMM初始化实例
3.11.1 VMCS相关的数据结构
3.11.1.1 VMB结构
3.11.1.2 VSB结构
3.11.1.3 VMCS buffer结构
3.11.2 初始化VMXON区域
3.11.3 初始化VMCS区域
3.11.3.1 分配VMCS区域
3.11.3.2 VMCS初始化模式
3.11.3.3 VMCS buffer初始化
3.11.4 例子3-1

第4章 VM-entry处理
4.1 发起VM-entry操作
4.2 VM-entry执行流程
4.3 指令执行的基本检查
4.4 检查控制区域及host-state区域
4.4.1 VM-execution控制区域检查
4.4.1.1 检查pin-based VM-execution control字段
4.4.1.2 检查primary processor-based VM-execution control字段
4.4.1.3 检查secondary processor-based VM-execution字段
4.4.1.4 检查CR3-target字段
4.4.2 VM-exit控制区域检查
4.4.2.1 VM-exit control字段的检查
4.4.2.2 MSR-store与MSR-load相关字段的检查
4.4.3 VM-entry控制区域检查
4.4.3.1 VM-entry control字段的检查
4.4.3.2 MSR-load相关字段的检查
4.4.3.3 事件注入相关字段的检查
4.4.4 Host-state区域的检查
4.4.4.1 Host控制寄存器字段的检查
4.4.4.2 Host-RIP的检查
4.4.4.3 段selector字段的检查
4.4.4.4 段基址字段的检查
4.4.4.5 MSR字段的检查
4.5 检查guest-state区域
4.5.1 检查控制寄存器字段
4.5.2 检查RIP与RFLAGS字段
4.5.3 检查DR7与IA32_DEBUGCTL字段
4.5.4 检查段寄存器字段
4.5.4.1 virtual-8086模式下的检查
4.5.4.2 unrestricted guest位为0时的检查
4.5.4.3 unrestricted guest位为1时的检查
4.5.5 检查GDTR与IDTR字段
4.5.6 检查MSR字段
4.5.7 检查activity state字段
4.5.8 检查interruptibility state字段
4.5.9 检查pending debug exception字段
4.5.10 检查VMCS link pointer字段
4.5.11 检查PDPTE字段
4.5.11.1 由加载CR3引发的PDPTE检查
4.6 检查guest state引起的VM-entry失败
4.7 加载guest环境信息
4.7.1 加载控制寄存器
4.7.2 加载DR7与IA32_DEBUGCTL
4.7.3 加载MSR
4.7.4 SMBASE字段处理
4.7.5 加载段寄存器与描述符表寄存器
4.7.5.1 unusable段寄存器
4.7.5.2 加载GDTR与IDTR
4.7.6 加载RIP、RSP和RFLAGS
4.7.7 加载PDPTE表项
4.8 刷新处理器cache
4.9 更新Vritual-APIC状态
4.9.1 PPR虚拟化
4.9.2 虚拟中断评估与delivery
4.10 加载MSR-load列表
4.10.1 IA32_EFER的加载处理
4.10.2 其他MSR字段的加载处理
4.11 由加载guest state引起的VM-entry失败
4.12 事件注入
4.12.1 注入事件的delivery
4.12.1.1 保护模式下的事件注入
4.12.1.2 实模式下的事件注入
4.12.1.3 virtual-8086模式下的事件注入
4.12.2 注入事件的间接VM-exit
4.13 执行pending debug exception
4.13.1 注入事件下的#DB异常delivery
4.13.2 例子4-1
4.13.3 非注入事件下的#DB异常delivery
4.14 使用MTF VM-exit功能
4.14.1 注入事件下的MTF VM-exit
4.14.2 非注入事件下的MTF VM-exit
4.14.3 MTF VM-exit与其他VM-exit
4.14.4 MTF VM-exit的优先级别
4.14.5 例子4-2
4.15 VM-entry后直接导致VM-exit的事件
4.15.1 VM-exit事件的优先级别
4.15.2 TPR below threshold VM-exit
4.15.3 pending MTF VM-exit
4.15.4 由pending debug exception引发的VM-exit
4.15.5 VMX-preemption timer
4.15.6 NMI-window exiting
4.15.7 interrupt-window exiting
4.16 处理器的可中断状态
4.16.1 中断的阻塞状态
4.16.2 阻塞状态的解除
4.16.3 中断的阻塞
4.16.4 VM-entry后的可中断状态
4.17 处理器的活动状态
4.17.1 active与inactive状态
4.17.2 事件的阻塞
4.17.3 inactive状态的唤醒
4.17.4 VM-entry后的活动状态
4.18 VM-entry的机器检查事件

第5章 VM-exit处理
5.1 无条件引发VM-exit的指令
5.2 有条件引发VM-exit的指令
5.3 引发VM-exit的事件
5.4 由于VM-entry失败导致的VM-exit
5.5 例子5-1
5.6 指令引发的异常与VM-exit
5.6.1 优先级高于VM-exit的异常
5.6.2 VM-exit优先级高于指令的异常
5.6.3 例子5-2
5.7 VM-exit的处理流程
5.8 记录VM-exit的相关信息
5.9 更新VM-entry区域字段
5.10 更新处理器状态信息
5.10.1 直接VM-exit事件下的状态更新
5.10.2 间接VM-exit事件下的状态更新
5.10.3 其他情况下的状态更新
5.11 保存guest环境信息
5.11.1 保存控制寄存器,debug寄存器及MSR
5.11.2 保存RIP与RSP
5.11.3 保存RFLAGS
5.11.4 保存段寄存器
5.11.5 保存GDTR与IDTR
5.11.6 保存activity与interruptibility状态信息
5.11.7 保存pending debug exception信息
5.11.8 保存VMX-preemption timer值
5.11.9 保存PDPTE
5.11.10 保存SMBASE与VMCS-link pointer
5.12 保存MSR-store列表
5.13 加载host环境
5.13.1 加载控制寄存器
5.13.2 加载DR7与MSR
5.13.3 加载host段寄存器
5.13.3.1 加载selector
5.13.3.2 加载base
5.13.3.3 加载limit
5.13.3.4 加载access rights
5.13.4 加载GDTR与IDTR
5.13.5 加载RIP,RSP及RFLAGS
5.13.6 加载PDPTE
5.14 更新host处理器状态信息
5.15 刷新处理器cache信息
5.16 加载MSR-load列表
5.17 VMX-abort

第6章 内存虚拟化
6.1 EPT(扩展页表)机制
6.1.1 EPT机制概述
6.1.1.1 guest分页机制与EPT
6.1.2 EPT页表结构
6.1.3 guest-physical address
6.1.4 EPTP
6.1.5 4K页面下的EPT页表结构
6.1.6 2M页面下的EPT页表结构
6.1.7 1G页面下的EPT页表结构
6.1.8 EPT导致的VM-exit
6.1.8.1 EPT violation
6.1.8.2 EPT misconfiguration
6.1.8.3 EPT 页故障的优先级
6.1.8.4 修复EPT页故障
6.1.9 accessed与dirty标志位
6.1.10 EPT内存类型
6.1.11 EPTP switching
6.1.12 实现EPT机制
6.2 Cache管理
6.2.1 linear mapping(线性映射)
6.2.2 guest-physical mapping(guest物理映射)
6.2.3 combined mapping(合并映射)
6.2.4 cache域
6.2.5 cache建立
6.2.6 cache刷新
6.2.6.1 INVLPG指令刷新cache
6.2.6.2 INVPCID指令刷新cache
6.2.6.3 INVVPID指令刷新cache
6.2.6.4 INVEPT指令刷新cache
6.2.6.5 INVVPID指令使用指南
6.2.6.6 INVEPT指令使用指南
6.3 内存虚拟化管理
6.3.1 分配物理内存
6.3.2 实模式guest OS内存处理
6.3.3 guest内存虚拟化
6.3.3.1 guest虚拟地址转换
6.3.3.2 guest OS的cache管理
6.4 例子6-1
6.4.1 GuestBoot模块
6.4.2 GuestKernel模块
6.4.3 VSB结构
6.4.4 VMM初始化guest
6.4.5 使用VMX-preemption timer
6.4.6 host处理流程
6.4.7 运行结果

第7章 中断虚拟化
7.1 异常处理
7.1.1 反射异常给guest
7.1.2 恢复guest异常
7.1.2.1 直接恢复
7.1.2.2 例子7-1
7.1.2.3 恢复原始向量事件
7.1.3 处理任务切换
7.1.3.1 检查任务切换条件
7.1.3.2 VMM处理任务切换
7.1.3.3 恢复guest运行
7.1.3.4 例子7-2
7.2 Local APIC虚拟化
7.2.1 监控guest访问local APIC
7.2.1.1 例子7-3
7.2.2 local APIC虚拟化机制
7.2.3 APIC-access page
7.2.3.1 APIC-access page的设置
7.2.4 虚拟化x2APIC MSR组
7.2.5 virtual-APIC page
7.2.6 APIC-access VM-exit
7.2.6.1 APIC-access VM-exit优先级别
7.2.7 虚拟化读取APIC-access page
7.2.8 虚拟化写入APIC-access page
7.2.9 虚拟化基于MSR读local APIC
7.2.10 虚拟化基于MSR写local APIC
7.2.11 虚拟化基于CR8访问TPR
7.2.12 local APIC虚拟化操作
7.2.12.1 TPR虚拟化
7.2.12.2 PPR虚拟化
7.2.12.3 EOI虚拟化
7.2.12.4 Self-IPI虚拟化
7.2.13 虚拟中断的评估与delivery
7.2.13.1 虚拟中断的评估
7.2.13.2 虚拟中断的delivery
7.2.14 posted-interrupt处理
7.3 中断处理
7.3.1 拦截INT指令
7.3.1.1 处理IDTR.limit
7.3.1.2 处理#GP异常
7.3.1.3 处理中断delivery
7.3.1.4 完成中断的delivery操作
7.3.1.5 例子7-4
7.3.2 处理NMI
7.3.2.1 拦截NMI
7.3.2.2 虚拟NMI
7.3.3 处理外部中断
7.3.3.1 拦截外部中断
7.3.3.2 转发外部中断
7.3.3.3 监控guest设置8259
7.3.3.4 例子7-5

Introduction

虚拟化技术大概可以分为软件虚拟化和硬件虚拟化两大类。软件上的虚拟化实际上很多地方都可以看到,例如常见的系统虚拟机软件,Java 虚拟机和Android 上的虚拟机可以算是广义上的软件虚拟机了。
在硬件虚拟化技术出现之前,虚拟机只能靠软件来模拟实现。硬件上的虚拟化技术可以算是比较热的一门技术了,但它并不是什么新鲜的技术。据资料显示,实际上Intel第一代VT-x 技术Vanderpool 在2005 年就已经推出了,但Intel 发展得很快,从处理器端到芯片组端,再到网络端都已经可以布署硬件虚拟化技术了。
《处理器虚拟化技术》一书围绕Intel VT-x 处理器端的虚拟化技术而写,可以算是前作《x86/x64 体系探索及编程》的下册。尽管此书只围绕一个主题,但笔者认为它的知识面并不比《x86/x64 体系探索及编程》一书窄,甚至还要超出。因为,完整地虚拟化一个“虚拟处理器”,必须结合原来的x86/x64 体系知识并扩展开来。编写本书所花的时间比前作还要多许多,从开始动笔到完稿用了11 个月的时间,期间不可谓不艰辛。
本书内容
全书共7 章。
第1 章 系统平台
本书的代码使用汇编语言编写,运行在祼机平台上。本章主要介绍如何实现一个简易平台来支撑书中所有例子的运行。这个平台可以被编译生成32 位或者64 位环境。也实现了一些特色机制,例如,开启了多处理器环境,并且为了更好地、直观地了解代码的执行流程而加入了调试信息机制。
第2 章 VMX 架构基础
VMX 架构是Intel 处理器端虚拟化技术(Intel VT-x)的实现框架。本章对虚拟化技术进行概括讲解,全面了解VMX 架构的基础知识。首先介绍了VMX 架构下引入VMX root operation 与VMX non-root operation 模式,以及这两个模式之间的切换。然后介绍了┃处理器虚拟化技术VMX 架构下的各种处理器能力,以及这些能力的检测。最后全面讲解新引进的VMX 指令集,以及VMX 指令产生的各种失败的情形。
第3 章 VMCS 结构
VMCS 结构是VMX 架构下最基本、最重要的数据结构。VMCS 结构内分为6 个区域,每个区域有若干个字段。整个VMX operation 模式的运行环境由VMCS 结构内的这些字段来配置与管理,例如配置guest 与host 的运行环境。全面地讲解了这6 个区域内每个字段的设置与使用。
第4 章 VM-entry 处理
在VMX 架构下,guest 运行在VMX non-root operation 模式下,而host 运行在VMX root operation 模式下。如果需要运行guest 软件,则处理器需要从VMX root operation 切换到VMX non-root operation 模式运行,这个行为被称为“VM-entry”。
本章详细地讲解处理器在执行VM-entry 操作时的每个流程。例如,在VM-entry 时会检查VMCS 结构内字段配置是否合理,并且加载guest 的运行环境。处理器也会根据VMCS 内字段来控制guest 软件的运行。
第5 章 VM-exit 处理
在guest 运行过程中,会因为某些事件而被迫返回host 环境。处理器由VMX nonroot operation 模式切换回VMX root operation 模式,这个行为被称为“VM-exit”。
本章详细地讲解处理器在执行VM-exit 操作时的每个流程。例如,在VM-exit 处理器的相应状态信息会得到更新,guest 的环境信息会保存在VMCS 结构内的guest-state 区域,并且从host-state 区域加载host 环境信息。最后转入host 入口执行VMM 的管理代码。
第6 章 内存虚拟化
VMX 架构引进了EPT 机制来实现对物理内存的虚拟化管理,使得每个VM 在物理平台上拥有自己独立的物理内存区域,而不受VMM 及其他VM 的干扰。同样也避免了VM 对VMM 的干扰。
本章全面讲解了EPT 机制的实现细节,也着重介绍了VMX 架构下的cache 管理。在随书例子中,我们实现了EPT 机制来管理VM 内存。
第7 章 中断虚拟化
VMX 架构下也实现了对local APIC 的虚拟化管理,引进了两个重要的页面:APICaccess page 页面与virtual-APIC page 页面。因此而形成了virtual-APIC 的概念。它是物理平台上的local APIC 的shadow。
在这一章里,我们将看到处理器如何处理APIC-access page 与virtual-APIC page 之间的关系,将对APIC-access page 的访问转化为对virtual-APIC page 的访问。从而实现访问和管理virtual-APIC 组件。
本章也着重介绍了VMM 应该如何处理guest 产生的异常与任务切换。最后以实际例子来展现VMM 如何监控INT 指令及NMI 与外部中断。
如何阅读本书
本书将理论结合实际地进行讲解,但每章内容还是会有侧重点。以章节的篇幅来说,第2 章至第5 章偏重于理论知识。而第1 章、第6 章和第7 章偏于实际例子。
因此,如果读者并不想通篇阅读,可以选择偏重理论知识的章节来看。第6 章与第7章介绍的重点知识主要是EPT(扩展页表)与local APIC 虚拟化。这两个内容也是必须掌握的。
在第1 章中并不涉及VMX 架构知识,而是通过代码的讲解来介绍基础平台。书中的全部例子将构建于这个基础平台之上。如果读者对此章不感兴趣,可以直接跳过。但是,如果读者对一些OS 的基础元素感兴趣,大可详细加以阅读。
读者对象
读者最好有一些x86/x64 体系知识基础,如果感到这方面的基础知识相对薄弱,可以阅读作者的另一本著作《x86/x64 体系探索及编程》或者Intel 官方手册。
如果读者只是想了解VMX 的理论知识,那么可以选择相应章节,对汇编知识的要求不高。如果读者想深入全面地了解整个VMX 架构知识,希望能够仔细阅读所有章节(第1 章可以略过),那么需要对汇编有一定了解。
随书例子
书中的每个章节有若干例子, 全书共14 个例子。
源码包解压后有7 个chapXX 目录,对应于每一章。还有commom、inc 以及lib 目录,存放所有例子共用的代码。每个chapXX 目录下有多个ex 实例目录,对应于每个例子。以第1 章为例,chap01 目录下有ex1-1 和ex1-2 实例目录。
每个实例目录里有下面的文件。
Bs:bochs 的配置文件。
Build:一个DOS 批处理的编译工具,用来编译源码。
c.img:硬盘与U 盘映像文件。
demo。img:软盘映像文件。
ex.asm:例子实体代码的汇编源文件。
ex.inc:例子实体代码头文件。
在时间宽裕的情况下,我会在Windows 平台上用C 语言来实现代码示例。目前已经写了大部分代码,但为了保证代码的正确性,力求在所有代码完成后再放出来。
致谢
感谢电子工业出版社博文视点公司的全体工作人员,特别感谢本书的策划编辑李冰,正是有你们的辛勤劳动,才使得本书可以顺利出版。
邓志
2014 年5 月

명세서

상표 Jingdong book
브랜드 영역 China

면책성명

제품 가격, 포장, 사양 등의 정보는 예고 없이 변경될 수 있습니다. 적시에 제품 정보를 업데이트 할 수 있도록 최선을 다하지만, 받은 실제 제품을 참고하시기 바랍니다. 제품을 사용하기 전에 반드시 제품에 동봉된 라벨, 경고 및 설명을 읽어 주십시오.

상세정보 보기
찜한 목록에 추가
{{ $isZh ? coupon.coupon_name_sub : coupon.coupon_ename_sub | formatCurrency }}
{{__("Buy Directly")}} {{ itemCurrency }}{{ item.directly_price }}
수량
{{ quantity }}
{{ instockMsg }}
{{ limitText }}
{{buttonTypePin == 3 ? __("Scan to view more PinGo") : __("Scan to start")}}
JD@CHINA 판매
배송지
{{ __("Ship to United States only") }}
69이상 주문 시 무료 배송
정품 보증

장바구니에 추가됨

쇼핑 계속하기

당신을 위한 추천

{{ item.brand_name }}

{{ item.item_name }}

{{ item.currency }}{{ item.market_price }}

{{ item.currency }}{{ item.unit_price }}

{{ item.currency }}{{ item.unit_price }}

쿠폰

{{ coupon.coupon_name_new | formatCurrency }}
받기 받았음 마감
{{ getCouponDescStr(coupon) }}
{{ coupon.use_time_desc }}
곧 만료됩니다: {{ formatTime(coupon.use_end_time) }}

친구들과 공유하세요

취소

Yami 기프트카드 전용특가

기프트카드로 결제하면 전용특가를 받을 수 있습니다

규칙 설명

기프트카드 전용특가는 일부 상품에 대한 특혜가격입니다.

기프트카드 전용특가 상품 구매 시 E-기프트 카드 잔액으로 결제하고 기프트카드 잔액이 주문 내 상품의 총액을 지불하기에 충분하하 기프트카드 전용특가가 자동으로 활성화됩니다.

기프트 카드 잔액으로 결제하지 않거나 기프트카드 잔액이 전항의 요건을 충족하지 못할 경우 기프트카드 전용특가를 활성화할 수 없으며 상품은 정상 가격으로 구매할 수 있습니다.

기프트카드 전용특가 상품 구매 시 잔액이 부족할 경우 장바구니 또는 결제 페이지에서 "충전" 버튼을 클릭하여 기프트카드를 구매 및 충전할 수 있습니다.

기프트카드 전용특가가 있는 상품은 "전용특가"라는 특별한 가격표시가 표시됩니다.

질문이 있으시면 언제든지 고객 서비스에 문의하십시오.

Yami는 기프트카드 전용특가 관련 최종 해석권을 보유합니다.

Yami 판매

서비스 보장

Yami $49 이상 무료 배송
Yami 걱정 없는 반품/교환
Yami 미국에서 발송

배송 정보

  • 미국

    표준 배송 $5.99(알래스카, 하와이 제외), 최종 가격 $49 이상 시 무료 배송

    지역 배송 $5.99(캘리포니아, 뉴욕, 뉴저지, 매사추세츠, 펜실베이니아, 위 주의 일부 지역), 최종 가격 $49 이상 시 무료 배송

    2일 이내 배송(알래스카 및 하와이 포함) $19.99부터 시작

반품 및 교환 정책

Yami는 고객님께 최상의 A/S를 제공하고, 모든 분들이 Yami에서 안심하고 쇼핑할 수 있도록 노력하고 있습니다. Yami의 자영 상품은 반품 및 교환 조건을 충족하는 경우, 상품 수령 후 30일 이내에 반품 및 교환할 수 있습니다(식품은 품질 문제로 인해 7일 이내에 반품 및 교환이 가능합니다. 모든 고객이 안전하고 고품질의 제품을 받을 수 있도록 뷰티 제품은 개봉 또는 사용 후에는 품질 문제를 제외하고 환불 또는 반품을 제공하지 않습니다. 기타 특별 카테고리의 제품은 고객 서비스에 문의하시기 바랍니다).
이해와 지원에 감사드립니다.

상세정보 보기

Yami 판매

Yami E-기프트카드 사용 약관

구매 시 자동 충전을 선택한 경우, 주문 완료 후 기프트카드가 자동으로 계정에 충전됩니다.

구매 시 이메일 발송을 선택한 경우, 주문 완료 후 시스템이 자동으로 카드 번호와 비밀번호를 입력한 이메일로 발송합니다.

이메일을 보낼 때, 모든 사용자는 이메일에 있는 카드 번호와 비밀번호를 사용하여 기프트카드를 충전할 수 있으니, 이메일 정보를 잘 보관하세요.

이메일을 받는 데 문제가 있으면, 고객 서비스에 연락하여 처리해 주세요.

이메일을 보낼 때, 기프트카드가 교환되지 않았다면 이메일을 재발송할 수 있습니다. 이미 다른 사용자에 의해 교환된 경우에는 보상할 수 없습니다.

Yamibuy의 E-기프트카드는 자영 또는 제3자 상품 구매에 사용할 수 있습니다.

Yamibuy의 E-기프트카드는 유효 기간 제한이 없으며, 장기간 유효합니다.

Yami 전자 상품권의 금액은 여러 번에 나눠서 사용할 수 있습니다;

Yami 전자 상품권 업무 규칙의 최종 해석 권한은 Yami 웹사이트에 있습니다.

반품 및 교환 정책

이미 사용된 E-기프트카드는 환불이 불가능합니다.

판매자: JD@CHINA

서비스 보장

Yami $49 이상 무료 배송
Yami 최고의 A/S
Yami 미국 본토에서 발송

배송 정보

  • 미국

    표준 배송 $5.99(알래스카, 하와이 제외), 최종 가격 $49 이상 시 무료 배송

    지역 배송 $5.99(캘리포니아, 뉴욕, 뉴저지, 매사추세츠, 펜실베이니아, 위 주의 일부 지역), 최종 가격 $49 이상 시 무료 배송

    2일 이내 배송(알래스카 및 하와이 포함) $19.99부터 시작

반품 및 교환 정책

제품을 받으신 후 30일 이내에 제품을 반품하실 수 있습니다. 반품된 품목은 구매에 대한 원본 송장을 포함하여 원래 포장된 새 품목이어야 합니다. 고객이 자신의 비용으로 제품을 반품합니다.

JD@CHINA 판매

서비스 보장

Yami 점포간 $:amount 이상 구매 시 무료 배송
Yami 30일 반품/교환 보장

Yami-중국 집하창고

Yami는 중국 내 주요 우수매장에서 제품을 선별하여 모아 Yami 중국통합센터로 배송하며 택배를 합친 후 전국 각지의 주소로 배송해 드립니다. 점포간 무료 배송 조건은 최저 $69입니다. 여러 판매자가 제공하는 다양한 상품 중에서 원하는 상품을 선택하고 점포간 무료배송으로 저렴한 배송비를 쉽게 누릴 수 있습니다.

반품 정책

30일 이내 반품 및 교환 보증을 제공합니다. 제품은 새로 사용하지 않은 원래 포장에 구매 증명서가 첨부되어 있어야 합니다. 상품 품질 문제, 잘못된 배송, 배송 누락 등 판매자의 실수로 인한 경우 환불 처리됩니다. 기타 사유로 인한 반품 및 교환은 배송비는 고객이 자체로 부담하셔야 합니다. 모든 제품은 장거리 배송을 하기 때문에 간혹 간단한 외부 포장이 눌려 마모되는 등이 있지만 내부 품질 문제가 없는 경우 반품 및 교환할 수 없습니다.

배송 정보

Yami 중국집하배송 Consolidated Shipping 배송비 $9.99 ($69 이상 주문시 무료배송)

중국 판매자는 주문 후 영업일 기준 2일 후에 상품을 발송합니다. 모든 택배는 Yami 중국통합센터(특별한 상황 및 중국 내 개별 법정 공휴일 제외)에 도착하여 택배를 합친 후 UPS를 통해 미국으로 배송됩니다. UPS는 중국에서 발송 후 미국까지 평균 10영업일 정도 소요되며 직배송 주문 번호에 따라 수시로 추적 및 조회할 수 있습니다 전염병의 영향으로 현재 물류가 5일 정도 지연될 수 있습니다. 택배는 고객 서명이 필요합니다. 서명하지 않은 경우 고객은 택배가 분실될 위험을 부담하게 됩니다.

JD@CHINA 판매

서비스 보장

69이상 주문 시 무료 배송
정품 보증

배송 정보

Yami Consolidated Shipping배송비$9.99($69 이상 주문 시 무료 배송)


Seller will ship the orders within 1-2 business days. The logistics time limit is expected to be 7-15 working days. In case of customs clearance, the delivery time will be extended by 3-7 days. The final receipt date is subject to the information of the postal company.

포인트 규칙

모든 품목은 Yamibuy 의 프로모션이나 포인트 이벤트에서 제외됩니다.

반품 및 교환 정책

제품을 받으신 후 30일 이내에 제품을 반품하실 수 있습니다. 반품된 품목은 구매에 대한 원본 송장을 포함하여 원래 포장된 새 품목이어야 합니다. 고객이 자신의 비용으로 제품을 반품합니다.

Yami

Yami 앱 다운로드

맨 위로 돌아가기

당신을 위한 추천

브랜드 스토리

Jingdong book

为您推荐

Yami
欣葉
2种选择
欣叶 御大福 芋头麻薯 180g

周销量 600+

$1.66 $1.99 83折
Yami
欣葉
2种选择
欣叶 御大福 芋头麻薯 180g

周销量 600+

$1.66 $1.99 83折
Yami
欣葉
2种选择
欣叶 御大福 芋头麻薯 180g

周销量 600+

$1.66 $1.99 83折
Yami
欣葉
2种选择
欣叶 御大福 芋头麻薯 180g

周销量 600+

$1.66 $1.99 83折
Yami
欣葉
2种选择
欣叶 御大福 芋头麻薯 180g

周销量 600+

$1.66 $1.99 83折
Yami
欣葉
2种选择
欣叶 御大福 芋头麻薯 180g

周销量 600+

$1.66 $1.99 83折

리뷰{{'('+ commentList.posts_count + ')'}}

당신의 체험을 공유하고 더 많은 사용자가 선택할 수 있도록 도와줍니다.

리뷰 작성
{{ totalRating }} 리뷰 작성
  • {{i}}별

    {{i}} 별

    {{ parseInt(commentRatingList[i]) }}%

Yami Yami
{{ comment.user_name }}

{{ showTranslate(comment) }}접기

{{ strLimit(comment,800) }}전체 보기

Show Original

{{ comment.content }}

Yami
모두 보기

{{ formatTime(comment.in_dtm) }} 구매 완료 {{groupData}}

{{ comment.likes_count }} {{ comment.likes_count }} {{ comment.reply_count }} {{comment.in_user==uid ? __('Delete') : __('Report')}}
Yami Yami
{{ comment.user_name }}

{{ showTranslate(comment) }}접기

{{ strLimit(comment,800) }}전체 보기

Show Original

{{ comment.content }}

Yami
모두 보기

{{ formatTime(comment.in_dtm) }} 구매 완료 {{groupData}}

{{ comment.likes_count }} {{ comment.likes_count }} {{ comment.reply_count }} {{comment.in_user==uid ? __('Delete') : __('Report')}}

조건에 맞는 리뷰가 없습니다

리뷰 상세

Yami Yami

{{ showTranslate(commentDetails) }}접기

{{ strLimit(commentDetails,800) }}전체 보기

Show Original

{{ commentDetails.content }}

Yami
모두 보기

{{ formatTime(commentDetails.in_dtm) }} 구매 완료 {{groupData}}

{{ commentDetails.likes_count }} {{ commentDetails.likes_count }} {{ commentDetails.reply_count }} {{commentDetails.in_user==uid ? __('Delete') : __('Report')}}

내용을 입력하세요

답변{{'(' + replyList.length + ')'}}

Yami Yami

{{ showTranslate(reply) }}접기

{{ strLimit(reply,800) }}전체 보기

Show Original

{{ reply.reply_content }}

{{ formatTime(reply.reply_in_dtm) }}

{{ reply.reply_likes_count }} {{ reply.reply_likes_count }} {{ reply.reply_reply_count }} {{reply.reply_in_user==uid ? __('Delete') : __('Report')}}

내용을 입력하세요

취소

지금까지의 모든 리뷰입니다!

리뷰 작성하기
상품 평점

댓글을 입력하세요.

  • 좋은 닉네임이 당신의 리뷰를 더 인기 있게 만들 것입니다!
  • 여기에서 닉네임을 변경하면 개인정보의 닉네임도 같이 변경됩니다.
리뷰를 남겨주셔서 감사합니다
당신의 좋은 리뷰는 우리 커뮤니티가 아시아 최고의 상품을 찾는 데 도움이 됩니다.

신고하기

취소

이 리뷰를 삭제하시겠습니까?

취소

최근 본 상품

브랜드 스토리

Jingdong book