版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
KVM內(nèi)核模塊解析KVM內(nèi)核模塊組成概述KVMAPIKVM內(nèi)核模塊重要的數(shù)據(jù)結(jié)構(gòu)5KVM內(nèi)核模塊重要流程的分析第5章KVM內(nèi)核模塊解析5.1KVM內(nèi)核模塊組成概述5.1.1Makefile文件分析KVM內(nèi)核模塊從Linux2.6.20版本開始已經(jīng)被收入到內(nèi)核樹中,在源碼中涉及KVM的主要有兩個目錄,virt和arch/x86/kvm。virt目錄主要包含內(nèi)核中非硬件體系架構(gòu)相關(guān)的部分如IOMMU、中斷控制等,其他的主要部分都包含在后者。因為KVM除了支持x86架構(gòu)以外,還支持PowerPC、MIPS、ARM等架構(gòu)。5.1.2KVM的內(nèi)核源碼結(jié)構(gòu)KVM的基本工作原理:
用戶模式的QEMU利用接口libkvm通過ioctl系統(tǒng)調(diào)用進入內(nèi)核模式。KVMDriver為虛擬機創(chuàng)建虛擬內(nèi)存和虛擬CPU后執(zhí)行VMLAUNCH指令進入客戶模式,裝載GuestOS且執(zhí)行。如果GuestOS發(fā)生外部中斷或者影子頁表缺頁之類的情況,暫停GuestOS的執(zhí)行,退出客戶模式進行一些必要的處理。處理完畢后重新進入客戶模式,執(zhí)行客戶代碼。如果發(fā)生I/O事件或者信號隊列中有信號到達,就會進入用戶模式處理。KVM采用全虛擬化技術(shù),客戶機不用修改就可以運行。第5章KVM內(nèi)核模塊解析圖5-1KVM工作原理第5章KVM內(nèi)核模塊解析KVM內(nèi)核模塊的實現(xiàn)主要包括三大部分:虛擬機的調(diào)度執(zhí)行、內(nèi)存管理、設(shè)備管理。KVM中的GuestOS的調(diào)度執(zhí)行
VMM調(diào)度GuestOS執(zhí)行時,QEMU通過ioctl系統(tǒng)調(diào)用進入內(nèi)核模式,在KVMDriver中通過get_cpu獲得當前物理CPU的引用。之后將GuestOS狀態(tài)從VMCS(VirtualMachineControlStructure)中讀出,并裝入物理CPU中。執(zhí)行VMLAUNCH指令使得物理處理器進入非內(nèi)核態(tài),然后運行客戶代碼。第5章KVM內(nèi)核模塊解析GuestOS執(zhí)行一些特權(quán)指令或者外部事件時,比如I/O訪問、對控制寄存器的操作、MSR(MicrosoftReservedPartition)的讀寫數(shù)據(jù)包到達等,都會導(dǎo)致物理CPU發(fā)生VMExit,停止運行GuestOS代碼。將GuestOS保存到VMCS中,Host狀態(tài)裝入物理處理器中,處理器進入內(nèi)核態(tài),KVM取得控制權(quán),通過讀取VMCS中VM_EXIT_REASON字段得到引起VMExit的原因,從而調(diào)用kvm_exit_handler處理函數(shù)。如果由于I/O獲得信號到達,則退出到用戶模式的QEMU進行處理。處理完畢后,重新進入客戶模式運行虛擬CPU。第5章KVM內(nèi)核模塊解析KVM中的內(nèi)存管理在KVM中提供了一個哈希列表和哈希函數(shù),以客戶機頁表項中的虛擬頁號和該頁表項所在頁表的級別作為鍵值,通過該鍵值查詢,如不為空,則表示該對應(yīng)的影子頁表項中的物理頁號已經(jīng)存在并且所指向的影子頁表已經(jīng)生成。如為空,則需新生成一張影子頁表,KVM將獲取指向該影子頁表的主機物理頁號填充到相應(yīng)的影子頁表項的內(nèi)容中,同時以客戶機頁表虛擬頁號和表所在的級別生成鍵值,在代表該鍵值的哈希表中填入主機物理頁號,以備查詢。但是一旦GuestOS中出現(xiàn)進程切換。第5章KVM內(nèi)核模塊解析KVM中的設(shè)備管理
一個機器只有一套I/O地址和設(shè)備。設(shè)備的管理和訪問是操作系統(tǒng)中的突出問題,同樣也是虛擬機實現(xiàn)的難題,另外還要提供虛擬設(shè)備供各個VM使用。在KVM中通過移植QEMU中的設(shè)備模型進行設(shè)備的管理和訪問。操作系統(tǒng)中,軟件使用可編程I/O(ProgrammableInput/Output,PIO)和內(nèi)存映射I/O(MemoryMappingInput/Output,MMIO)與硬件交互。而且硬件可以發(fā)出中斷請求,由操作系統(tǒng)處理。第5章KVM內(nèi)核模塊解析PIO的捕獲:由硬件直接提供。當VM發(fā)出PIO指令時,導(dǎo)致VMExit然后硬件會將VMExit的原因及對應(yīng)的指令寫入VMCS控制結(jié)構(gòu)中,這樣KVM就會模擬PIO指令。MMIO的捕獲:對MMIO頁的訪問導(dǎo)致缺頁異常,被KVM捕獲,通過x86模擬器模擬執(zhí)行MMIO指令。KVM中的I/O虛擬化都是通過用戶空間的QEMU實現(xiàn)的,而所有PIO和MMIO的訪問也都是被轉(zhuǎn)發(fā)到QEMU的,QEMU模擬硬件設(shè)備提供給虛擬機使用。
第5章KVM內(nèi)核模塊解析圖5-2KVMI/O模型第5章KVM內(nèi)核模塊解析例:以虛擬機接收數(shù)據(jù)包說明虛擬機和設(shè)備的交互(1)當數(shù)據(jù)包到達主機的物理網(wǎng)卡后,調(diào)用物理網(wǎng)卡的驅(qū)動程序,在其中利用Linux內(nèi)核中軟件網(wǎng)橋,實現(xiàn)數(shù)據(jù)的轉(zhuǎn)發(fā)。(2)在軟件網(wǎng)橋這一層,會判斷數(shù)據(jù)包是發(fā)往哪個設(shè)備的,同時調(diào)用網(wǎng)橋的發(fā)送函數(shù),向?qū)?yīng)的端口發(fā)送數(shù)據(jù)包。(3)若數(shù)據(jù)包是發(fā)往虛擬機的,則要通過tap設(shè)備進行轉(zhuǎn)發(fā)。tap設(shè)備由兩部分組成,網(wǎng)絡(luò)設(shè)備和字符設(shè)備。網(wǎng)絡(luò)設(shè)備負責接收和發(fā)送數(shù)據(jù)包,字符設(shè)備負責將數(shù)據(jù)包往內(nèi)核空間和用戶空間進行轉(zhuǎn)發(fā)。第5章KVM內(nèi)核模塊解析(4)返回用戶模式的QEMU中,執(zhí)行設(shè)備模型。返回到KVMmain_loop中,執(zhí)行KVMmain_loop_wait,之后進入main_loop_wait中,在這個函數(shù)里收集對應(yīng)設(shè)備的設(shè)備文件描述符的狀態(tài),此時tap設(shè)備文件描述符的狀態(tài)同樣被收集到fd_set。(5)
KVM中的main_loop不停地循環(huán),通過select系統(tǒng)調(diào)用判斷哪個文件描述符的狀態(tài)發(fā)生變化,相應(yīng)地調(diào)用對應(yīng)的處理函數(shù)。第5章KVM內(nèi)核模塊解析5.2KVM
API5.2.1KVMAPI簡介表5-1KVMAPI的三種類型第5章KVM內(nèi)核模塊解析
用戶態(tài)程序?qū)VMAPI的操作是從打開kvm設(shè)備文件開始的,通過調(diào)用open函數(shù)會獲得針對kvm模塊的一個句柄,這個句柄其實是文件描述符。在系統(tǒng)調(diào)用ioctl執(zhí)行的時候,文件描述符指定當前設(shè)備為/dev/kvm。ioctl配合特定的控制命令告訴kvm字符設(shè)備進行特定的操作,比如,KVM_CREATE_VM指令字表示創(chuàng)建一個虛擬機同時會返回此虛擬機對應(yīng)的fd文件描述符,利用此fd文件描述符可以執(zhí)行VM指令,對具體的虛擬機進行控制。例如KVM_CREATE_VCPU指令字表示創(chuàng)建一個虛擬CPU并且返回此vCPU對應(yīng)的fd文件描述符。第5章KVM內(nèi)核模塊解析5.2.2KVMAPI中的結(jié)構(gòu)體
用戶空間的程序與KVM的交互中關(guān)于KVMHypervisor和GuestOS的查詢與管理,是通過使用ioctl函數(shù)與一個特殊的設(shè)備/dev/kvm之間的交互來實現(xiàn)的。KVMAPI就是一些可以用于控制虛擬機各個方面的ioctl的集合。用戶空間的程序可以通過KVMAPI獲得KVM的版本信息、創(chuàng)建虛擬機、創(chuàng)建VCPU、查詢KVM的特性支持和性能容量,而KVMAPI是通過符合Linux標準的一系列結(jié)構(gòu)體進行支撐,主要是kvm_device_fops、kvm_vm_fops、kvm_vcpu_fops,分別對應(yīng)字符型設(shè)備、VM文件描述符和vCPU文件描述符的三種操作,結(jié)構(gòu)體都是標準file_operations結(jié)構(gòu)體。第5章KVM內(nèi)核模塊解析5.2.3Systemioctl調(diào)用ioctl是設(shè)備驅(qū)動程序中對設(shè)備的I/O通道進行管理的函數(shù)。所謂對I/O通道進行管理,就是對設(shè)備的一些特性進行控制,例如串口的傳輸波特率、電動機的轉(zhuǎn)速,等等。它的調(diào)用參數(shù)如下:intioctl(intfd,indcmd,…);
其中,fd是用戶程序打開設(shè)備時使用open函數(shù)返回的文件標示符,cmd是用戶程序?qū)υO(shè)備的控制命令,至于后面的省略號,那是一些補充參數(shù),一般最多一個,這個參數(shù)的有無和cmd的意義相關(guān)。第5章KVM內(nèi)核模塊解析主要的指令字包括:(1)?KVM_CREATE_VM創(chuàng)建KVM虛擬機。(2)?KVM_GET_API_VERSION查詢當前KVMAPI版本。(3)?KVM_GET_MSR_INDEX_LIST獲得MSR索引列表。(4)?KVM_CHECK_EXTENSION檢查擴展支持情況。(5)
KVM_GET_VCPU_MMAP_SIZE運行虛擬機及獲得用戶態(tài)空間共享的一片內(nèi)存區(qū)域的大小。(6)?KVM_GET_VCPU_MMAP_SIZE也是其中比較重要的指令字,返回vCPUmmap區(qū)域的大小。第5章KVM內(nèi)核模塊解析(7)?KVM_CREATE_VM是其中比較重要的指令字。通過該參數(shù),KVM將返回虛擬機對應(yīng)的一個文件描述符,文件描述符指向內(nèi)核空間中一個新的虛擬機。(8)?KVM_RUNioctl通過共享的內(nèi)存區(qū)域與用戶空間進行通信。(9)?KVM_CHECK_EXTENSION如果支持的話返回1,不支持的話返回0。(10)?KVM_GET_API_VERSION返回常量KVM_API_VERSION(=?12),此指令字會將API版本作為穩(wěn)定的KVMAPI,并且這個版本號的數(shù)字不會發(fā)生變化。如果通過KVM_GET_API_VERSION得到的版本號不是12,那么應(yīng)用程序?qū)⒕芙^運行。第5章KVM內(nèi)核模塊解析5.2.4VMioctl調(diào)用VMioctl指令實現(xiàn)對虛擬機的控制,大多需要從KVM_CREATE_VM中返回的fd來進行操作,具體操作包括:配置內(nèi)存、配置vCPU、運行虛擬機等,主要指令如下:(1)?KVM_CREATE_VCPU為虛擬機創(chuàng)建vCPU。(2)?KVM_RUN根據(jù)kvm_run結(jié)構(gòu)體信息,運行VM虛擬機。(3)?KVM_CREATE_IRQCHIP創(chuàng)建虛擬APIC,且隨后創(chuàng)建的vCPU都關(guān)聯(lián)到此APIC。(4)?KVM_IRQ_LINE對某虛擬APIC發(fā)出中斷信號。第5章KVM內(nèi)核模塊解析(5)?KVM_GET_IRQCHIP讀取APIC的中斷標志信息。(6)?KVM_SET_IRQCHIP寫入APIC的中斷標志信息。(7)?KVM_GET_DIRTY_LOG返回臟內(nèi)存頁的位圖。(8)?KVM_CREATE_VCPU和KVM_RUN是VMioctl指令中兩種重要的指令字,通過KVM_CREATE_VCPU為虛擬機創(chuàng)建vCPU,并獲得對應(yīng)的fd描述符后,可以對其調(diào)用KVM_RUN,以啟動該虛擬機(或稱為調(diào)度vCPU)。第5章KVM內(nèi)核模塊解析5.2.5vCPUioctl調(diào)用表5-3vCPUioctl指令字(中斷和控制類)第5章KVM內(nèi)核模塊解析5.3KVM
內(nèi)核模塊重要的數(shù)據(jù)結(jié)構(gòu)5.3.1kvm結(jié)構(gòu)KVM虛擬機通過使用?/dev/kvm字符設(shè)備的ioctl的System指令KVM_CREATE_VM來進行創(chuàng)建。對虛擬機來說,kvm結(jié)構(gòu)體是關(guān)鍵,一個虛擬機對應(yīng)一個kvm結(jié)構(gòu)體,虛擬機的創(chuàng)建過程實質(zhì)為kvm結(jié)構(gòu)體的創(chuàng)建和初始化過程。第5章KVM內(nèi)核模塊解析5.3.2kvm_vcpu結(jié)構(gòu)體
在用戶通過KVM_CREATE_VCPU系統(tǒng)調(diào)用請求創(chuàng)建vCPU之后,KVM子模塊將創(chuàng)建kvm_vcpu結(jié)構(gòu)體并進行相應(yīng)的初始化操作,然后返回對應(yīng)的vcpu_fd描述符。在KVM的內(nèi)部虛擬機調(diào)度中,用kvm_vcpu和KVM中的相關(guān)數(shù)據(jù)進行操作。kvm_vcpu結(jié)構(gòu)體中的字段較多,其中重要的成員如下:intvcpu_id;對應(yīng)vCPU的ID。第5章KVM內(nèi)核模塊解析5.3.3kvm_x86_ops結(jié)構(gòu)體kvm_x86_ops結(jié)構(gòu)體中包含了針對具體的CPU架構(gòu)進行虛擬化時的函數(shù)指針的調(diào)用,其定義在Linux內(nèi)核文件的arch/x86/include/asm/kvm_host.h中。該結(jié)構(gòu)體主要包含以下幾種類型的操作:(1)?CPUVMM狀態(tài)硬件初始化。(2)?vCPU創(chuàng)建與管理。(3)中斷管理。(4)寄存器管理。(5)時鐘管理。第5章KVM內(nèi)核模塊解析5.4KVM
內(nèi)核模塊重要流程的分析
作為VMM,KVM分為兩部分,分別是運行于Kernel模式的KVM內(nèi)核模塊和運行于User模式的QEMU模塊。這里的Kernel模式和User模式,實際上指的是VMX(一種針對虛擬化的CPU指令集)根模式下的特權(quán)級0和特權(quán)級3。另外,KVM將虛擬機所在的運行模式稱為Guest模式。所謂Guest模式,實際上指的是VMX的非根模式,其中內(nèi)核模塊的重要流程都在對應(yīng)根模式下面,主要的執(zhí)行流程圖如圖5-4所示。第5章KVM內(nèi)核模塊解析圖5-4KVM重要工作流程圖第5章KVM內(nèi)核模塊解析KVM工作流程:
初始化工作完成之后,QEMU線程以ioctl的方式向KVM內(nèi)核模塊發(fā)出運行vCPU的指示,后者執(zhí)行VMentry操作,將處理器由Kernel模式切換到Guest模式,中止宿主機軟件,轉(zhuǎn)而運行客戶軟件。注意,宿主機軟件被中止時,此操作正處于QEMU線程上下文,且正在執(zhí)行ioctl系統(tǒng)調(diào)用的Kernel模式處理程序??蛻糗浖谶\行過程中,如發(fā)生異?;蛲獠恐袛嗟仁录?,若執(zhí)行I/O操作,可能導(dǎo)致VMexit,將處理器狀態(tài)由Guest模式切換回Kernel模式。第5章KVM內(nèi)核模塊解析5.4.1初始化流程KVM模塊分為三個主要模塊:kvm.ko、kvm-intel.ko和kvm-amd.ko,這三個模塊在初始化階段的流程如圖5-5所示。
圖5-5KVM模塊初始化流程圖第5章KVM內(nèi)核模塊解析圖5-6KVM初始化執(zhí)行流程圖第5章KVM內(nèi)核模塊解析KVM的初始化步驟分為以下三步:(1)在平臺相關(guān)的KVM模塊中通過module_init宏正式進入KVM的初始化階段,并且執(zhí)行相關(guān)的硬件初始化準備。(2)進入kvm_main.c中的kvm_init函數(shù)進行正式的初始化工作,期間進行了一系列子操作。通過kvm_arch_init函數(shù)初始化KVM內(nèi)部的一些數(shù)據(jù)結(jié)構(gòu):注冊全局變量kvm_x86_ops、初始化MMU等數(shù)據(jù)結(jié)構(gòu)、初始化Timer定時器架構(gòu)。(3)進行后續(xù)的硬件初始化準備操作。第5章KVM內(nèi)核模塊解析圖5-7函數(shù)鏈表ModuleTypeList關(guān)系圖第5章KVM內(nèi)核模塊解析5.4.2虛擬機的創(chuàng)建KVM虛擬機創(chuàng)建和運行虛擬機分為用戶態(tài)和核心態(tài)兩個部分,用戶態(tài)主要提供應(yīng)用程序接口,為虛擬機創(chuàng)建上下文環(huán)境,在libkvm中提供訪問內(nèi)核字符設(shè)備/dev/kvm的接口;內(nèi)核態(tài)為添加到內(nèi)核中的字符設(shè)備?/dev/kvm,模塊加載進內(nèi)核后即可進行用戶空間的接口調(diào)用去創(chuàng)建虛擬機。在創(chuàng)建虛擬機過程中,kvm字符設(shè)備主要為客戶機創(chuàng)建kvm數(shù)據(jù)結(jié)構(gòu),創(chuàng)建該虛擬機的文件描述符及其相應(yīng)的數(shù)據(jù)結(jié)構(gòu),以及創(chuàng)建虛擬處理器及其相應(yīng)的數(shù)據(jù)結(jié)構(gòu)。KVM創(chuàng)建虛擬機的流程如圖5-8所示。第5章KVM內(nèi)核模塊解析圖5-8KVM創(chuàng)建虛擬機的流程圖第5章KVM內(nèi)核模塊解析創(chuàng)建虛擬機的流程:
首先聲明一個kvm_context_t變量用以描述用戶態(tài)虛擬機上下文信息,然后調(diào)用kvm_init()函數(shù)初始化虛擬機上下文信息;函數(shù)kvm_create()創(chuàng)建虛擬機實例,該函數(shù)通過ioctl系統(tǒng)調(diào)用創(chuàng)建虛擬機相關(guān)的內(nèi)核數(shù)據(jù)結(jié)構(gòu)并且返回虛擬機文件描述符給用戶態(tài)kvm_context_t數(shù)據(jù)結(jié)構(gòu);創(chuàng)建完內(nèi)核虛擬機數(shù)據(jù)結(jié)構(gòu)后,再創(chuàng)建內(nèi)核pit以及mmio等基本外設(shè)模擬設(shè)備,然后調(diào)用kvm_create_vcpu()函數(shù)來創(chuàng)建虛擬處理器。第5章KVM內(nèi)核模塊解析創(chuàng)建虛擬機過程涉及的函數(shù):(1)函數(shù)kvm_init():該函數(shù)在用戶態(tài)創(chuàng)建一個虛擬機上下文,用以在用戶態(tài)保存基本的虛擬機信息,這個函數(shù)是創(chuàng)建虛擬機第一個需要調(diào)用的函數(shù),函數(shù)返回一個kvm_context_t結(jié)構(gòu)體。該函數(shù)原型為:kvm_context_tkvm_init(structkvm_callbacks*callbacks,void*opaque);函數(shù)執(zhí)行的基本過程:打開字符設(shè)備dev/kvm,申請?zhí)摂M機上下文變量空間,初始化上下文的基本信息:設(shè)置fd文件描述符指向/dev/kvm、禁用虛擬機文件描述符、設(shè)置I/O事件回調(diào)函數(shù)結(jié)構(gòu)體、設(shè)置IRQ和PIT的標志位以及內(nèi)存頁面記錄的標志位。第5章KVM內(nèi)核模塊解析(2)函數(shù)kvm_create():該函數(shù)主要用于創(chuàng)建一個虛擬機內(nèi)核環(huán)境。該函數(shù)原型為intkvm_create(kvm_context_tkvm,unsignedlongphys_mem_bytes,void**phys_mem);這個函數(shù)首先調(diào)用kvm_create_vm()分配IRQ并且初始化為0,設(shè)置vcpu[0]的值為?-1,即不允許調(diào)度虛擬機執(zhí)行。然后通過ioctl系統(tǒng)調(diào)用ioctl(fd,KVM_CREATE_VM,0)來創(chuàng)建虛擬機內(nèi)核數(shù)據(jù)結(jié)構(gòu)structkvm。第5章KVM內(nèi)核模塊解析(3)內(nèi)核創(chuàng)建虛擬機kvm對象后,接著調(diào)用kvm_arch_create函數(shù)用于創(chuàng)建一些體系結(jié)構(gòu)相關(guān)的信息,主要包括kvm_init_tss、kvm_create_pit以及kvm_init_coalsced_mmio等信息。然后調(diào)用kvm_create_phys_mem創(chuàng)建物理內(nèi)存,函數(shù)kvm_create_irqchip用于創(chuàng)建內(nèi)核irq信息,通過系統(tǒng)調(diào)用ioctl(kvm->vm_fd,KVM_CREATE_IRQCHIP)。第5章KVM內(nèi)核模塊解析(4)函數(shù)kvm_create_vcpu():用于創(chuàng)建虛擬處理器。該函數(shù)原型為intkvm_create_vcpu(kvm_context_tkvm,intslot);參數(shù):kvm表示對應(yīng)用戶態(tài)虛擬機上下文,slot表示需要創(chuàng)建的虛擬處理器的個數(shù)。該函數(shù)通過ioctl系統(tǒng)調(diào)用ioctl(kvm->vm_fd,KVM_CREATE_VCPU,slot)創(chuàng)建屬于該虛擬機的虛擬處理器。該系統(tǒng)調(diào)用函數(shù):staticinitkvm_vm_ioctl_create_vcpu(struct*kvm,n)參數(shù)kvm為內(nèi)核虛擬機實例數(shù)據(jù)結(jié)構(gòu),n為創(chuàng)建的虛擬CPU的數(shù)目。第5章KVM內(nèi)核模塊解析(5)函數(shù)kvm_create_phys_mem():用于創(chuàng)建虛擬機內(nèi)存空間。該函數(shù)原型為void*kvm_create_phys_mem(kvm_context_tkvm,unsignedlongphys_start,unsignedlen,intlog,i
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 運動副 課程設(shè)計
- 足球課程設(shè)計的思路
- 通信原理matlab實驗課程設(shè)計
- 插齒機機械原理課程設(shè)計
- 送貨上門課程設(shè)計
- 郵件收發(fā)程序Java課程設(shè)計
- 裝配式建筑施工課程設(shè)計
- 物流會計做賬課程設(shè)計
- 2025年度工業(yè)機器人OEM定制與技術(shù)服務(wù)合同3篇
- 2024版大型廠房出租及配套設(shè)施租賃與管理服務(wù)合同3篇
- 新教材人教版高中物理選擇性必修第二冊全冊各章節(jié)課時練習題及章末測驗含答案解析(安培力洛倫茲力電磁感應(yīng)交變電流等)
- 初級養(yǎng)老護理員培訓全套
- 集中供熱管網(wǎng)系統(tǒng)一次網(wǎng)的調(diào)節(jié)方法
- GB/T 41095-2021機械振動選擇適當?shù)臋C器振動標準的方法
- MRP、MPS計劃文檔教材
- 甲狀腺疾病護理查房課件
- 安全安全帶檢查記錄表
- GB∕T 26520-2021 工業(yè)氯化鈣-行業(yè)標準
- 2022年浙江省紹興市中考數(shù)學試題及參考答案
- Listen-to-this-3-英語高級聽力-(整理版)
- 生活垃圾焚燒處理建設(shè)項目評價導(dǎo)則(2022)
評論
0/150
提交評論