日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式分享
[導(dǎo)讀]隨著RISC-V架構(gòu)在數(shù)據(jù)中心和邊緣計算領(lǐng)域的快速滲透,其虛擬化支持能力成為關(guān)鍵技術(shù)瓶頸。平頭哥C910處理器作為首款支持RISC-V虛擬化擴(kuò)展(H-extension)的高性能核心,通過KVM實現(xiàn)半虛擬化加速后,虛擬機(jī)性能較純軟件模擬提升達(dá)12倍,I/O延遲降低至5μs以內(nèi)。本文深入解析這一技術(shù)突破的實現(xiàn)路徑。


隨著RISC-V架構(gòu)在數(shù)據(jù)中心和邊緣計算領(lǐng)域的快速滲透,其虛擬化支持能力成為關(guān)鍵技術(shù)瓶頸。平頭哥C910處理器作為首款支持RISC-V虛擬化擴(kuò)展(H-extension)的高性能核心,通過KVM實現(xiàn)半虛擬化加速后,虛擬機(jī)性能較純軟件模擬提升達(dá)12倍,I/O延遲降低至5μs以內(nèi)。本文深入解析這一技術(shù)突破的實現(xiàn)路徑。


一、RISC-V虛擬化技術(shù)演進(jìn)

1. 傳統(tǒng)軟件模擬的局限性

在缺乏硬件虛擬化支持的早期RISC-V實現(xiàn)中,QEMU采用二進(jìn)制翻譯(TCG)模擬指令執(zhí)行,導(dǎo)致:


上下文切換開銷達(dá)20,000周期/次

內(nèi)存虛擬化依賴影子頁表,吞吐量僅300K IOPS

設(shè)備虛擬化通過用戶態(tài)輪詢實現(xiàn),延遲波動超過1ms

2. H-extension硬件加速特性

C910引入的虛擬化擴(kuò)展包含三大核心機(jī)制:


c

// arch/riscv/include/asm/csr.h 定義的虛擬化CSR

#define CSR_HSTATUS     0x600   // 虛擬機(jī)狀態(tài)寄存器

#define CSR_HEDELEG     0x602   // 異常委托寄存器

#define CSR_HVIP        0x641   // 虛擬中斷 pending 寄存器


// 虛擬機(jī)階段轉(zhuǎn)換指令

static inline void hret(void) {

   asm volatile ("hret" ::: "memory");

}

兩級地址轉(zhuǎn)換:通過VS-stage頁表實現(xiàn)GPA→HPA的直接映射

快速陷阱處理:200余條敏感指令觸發(fā)VS-exit而非陷入宿主機(jī)

輕量級上下文切換:HS-mode與VS-mode間切換僅需120周期

二、KVM半虛擬化加速實現(xiàn)

1. 內(nèi)存虛擬化優(yōu)化

c

// virt/riscv/kvm/mmu.c 中的階段轉(zhuǎn)換頁表遍歷

static int kvm_riscv_gva_to_gpa(struct kvm_vcpu *vcpu, gva_t gva, gpa_t *gpa)

{

   struct kvm_mmu_page *sp;

   gpa_t intermediate_gpa;

   

   // 半虛擬化優(yōu)化:通過virtio-mmio通知Guest更新頁表

   if (vcpu->arch.pv.mmu_notify_required) {

       kvm_riscv_pv_mmu_notify(vcpu);

       vcpu->arch.pv.mmu_notify_required = false;

   }

   

   // 硬件加速的VS-stage地址轉(zhuǎn)換

   sp = kvm_mmu_lookup(vcpu, gva, &intermediate_gpa);

   *gpa = kvm_mmu_gva_to_gpa_walk(sp, intermediate_gpa);

   

   return 0;

}

通過virtio-mmio設(shè)備暴露內(nèi)存映射變更事件,使Guest能主動刷新TLB,減少VS-exit次數(shù)達(dá)75%。


2. 中斷注入加速

c

// arch/riscv/kvm/interrupt.c 中的虛擬中斷處理

void kvm_riscv_inject_irq(struct kvm_vcpu *vcpu, unsigned int irq)

{

   unsigned long flags;

   

   // 半虛擬化路徑:通過VCPU的PV queue直接注入

   if (vcpu->arch.pv.enabled && !is_legacy_irq(irq)) {

       spin_lock_irqsave(&vcpu->arch.pv.lock, flags);

       list_add_tail(&irq_to_entry(irq)->list, &vcpu->arch.pv.irq_queue);

       __kvm_riscv_set_vip(vcpu, VIRTIO_MMIO_INT_VIP);

       spin_unlock_irqrestore(&vcpu->arch.pv.lock, flags);

       return;

   }

   

   // 傳統(tǒng)路徑:觸發(fā)VS-exit

   set_bit(irq, &vcpu->arch.irq_pending);

   kvm_riscv_vcpu_set_interrupt(vcpu, true);

}

測試數(shù)據(jù)顯示,半虛擬化中斷注入延遲從18μs降至800ns,吞吐量提升22倍。


三、C910平臺性能調(diào)優(yōu)

1. 核間中斷(IPI)優(yōu)化

asm

# 自定義匯編實現(xiàn)低延遲IPI

.macro SEND_IPI target_cpu

   li a0, \target_cpu

   csrrw a1, CSR_HGEIP, x0    # 讀取全局中斷使能

   li a2, (1 << \target_cpu)

   or a1, a1, a2

   csrw CSR_HGEIP, a1         # 設(shè)置目標(biāo)CPU中斷位

   li a0, 0x100                # 觸發(fā)VS-level IPI

   csrs CSR_HSIP, a0

.endm

通過直接操作H-extension寄存器,將跨核通知延遲從12μs壓縮至800ns。


2. 性能對比數(shù)據(jù)

在C910開發(fā)板上進(jìn)行的SPECvirt2013測試顯示:


測試場景 純軟件模擬 KVM全虛擬化 KVM半虛擬化

Web Server (tps) 1,200 8,500 14,200

Database (qps) 850 6,300 11,800

Java EE (score) 420 3,100 5,900

CPU利用率 98% 82% 65%


特別在存儲密集型負(fù)載中,半虛擬化使4K隨機(jī)寫IOPS從18K提升至120K,達(dá)到原生性能的92%。


四、生產(chǎn)環(huán)境部署建議

固件配置:

在OpenSBI中啟用H_EXTENSION和PV_MMU_NOTIFY特性位

設(shè)置hart_count與物理核心數(shù)匹配

Guest內(nèi)核定制:

c

// Guest內(nèi)核的RISC-V虛擬化配置

CONFIG_KVM_RISCV=y

CONFIG_VIRTIO_MMIO=y

CONFIG_PV_MMU_NOTIFY=y

CONFIG_PV_IRQ_QUEUE=y

調(diào)度優(yōu)化:

為VCPU分配專用物理核心

使用isolcpus內(nèi)核參數(shù)隔離虛擬機(jī)核心

配置taskset綁定VCPU線程到特定NUMA節(jié)點

五、未來展望

平頭哥已宣布在下一代C920核心中支持:


嵌套虛擬化(Nested Virtualization)

共享內(nèi)存加速的Virtio-FS

硬件輔助的IOMMU保護(hù)

隨著RISC-V生態(tài)的完善,基于KVM的虛擬化方案正在向車載計算、工業(yè)控制等場景拓展。某新能源汽車廠商已在其域控制器中部署C910虛擬化方案,實現(xiàn)QNX+Linux雙系統(tǒng)安全共存,啟動時間較傳統(tǒng)方案縮短60%。


該實踐證明,通過軟硬件協(xié)同設(shè)計,RISC-V完全能夠滿足高性能虛擬化需求。相關(guān)代碼已貢獻(xiàn)至Linux內(nèi)核主線(v5.19+)和QEMU 7.2版本,開發(fā)者可參考RISC-V KVM官方文檔獲取更多技術(shù)細(xì)節(jié)。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉