博客專(zhuān)欄

EEPW首頁(yè) > 博客 > Linux物理地址和虛擬地址

Linux物理地址和虛擬地址

發(fā)布人:美男子玩編程 時(shí)間:2024-10-12 來(lái)源:工程師 發(fā)布文章

在 Linux 系統(tǒng)中,物理地址和虛擬地址是操作系統(tǒng)內(nèi)存管理的重要概念。理解它們對(duì)于操作系統(tǒng)、內(nèi)存管理、以及應(yīng)用程序開(kāi)發(fā)來(lái)說(shuō)非常關(guān)鍵。以下是對(duì) Linux 物理地址和虛擬地址的詳細(xì)說(shuō)明,以及相關(guān)的示例。


1


物理地址 (Physical Address)

物理地址是指計(jì)算機(jī)實(shí)際內(nèi)存(RAM)中的一個(gè)具體位置。它是硬件層面上內(nèi)存的唯一標(biāo)識(shí),用于直接訪問(wèn)物理內(nèi)存單元。物理地址由內(nèi)存控制器直接管理,通常不能被應(yīng)用程序直接訪問(wèn)。


特點(diǎn)

  • 物理地址是直接指向物理內(nèi)存的地址,是唯一的。

  • 在現(xiàn)代操作系統(tǒng)中,用戶態(tài)程序無(wú)法直接使用物理地址,只能通過(guò)操作系統(tǒng)內(nèi)核間接地訪問(wèn)物理內(nèi)存。

  • 物理地址通常用于硬件級(jí)別的操作,如內(nèi)存映射 I/O。


2


虛擬地址 (Virtual Address)

虛擬地址是操作系統(tǒng)為每個(gè)進(jìn)程分配的地址空間中的一個(gè)位置。每個(gè)進(jìn)程都有自己獨(dú)立的虛擬地址空間,虛擬地址通過(guò)頁(yè)表映射到物理地址。


特點(diǎn)

  • 虛擬地址允許操作系統(tǒng)為每個(gè)進(jìn)程提供隔離的地址空間,增加了安全性和穩(wěn)定性。

  • 操作系統(tǒng)通過(guò)內(nèi)存管理單元(MMU)將虛擬地址映射到物理地址,通常使用頁(yè)表實(shí)現(xiàn)。

  • 虛擬地址使得內(nèi)存管理更加靈活,可以實(shí)現(xiàn)內(nèi)存分頁(yè)、內(nèi)存交換等功能。


3


物理地址與虛擬地址的關(guān)系

虛擬地址和物理地址之間的映射關(guān)系由操作系統(tǒng)的內(nèi)存管理單元(MMU)負(fù)責(zé)。



MMU 通過(guò)頁(yè)表將虛擬地址轉(zhuǎn)換為物理地址,頁(yè)表保存了虛擬地址到物理地址的映射信息。不同的進(jìn)程可以有相同的虛擬地址,但它們映射到的物理地址可能不同。


  • 頁(yè) (Page): 虛擬內(nèi)存和物理內(nèi)存被劃分為相同大小的塊,稱(chēng)為頁(yè)。

    常見(jiàn)的頁(yè)大小為 4 KB。

  • 頁(yè)表 (Page Table): 頁(yè)表是一個(gè)數(shù)據(jù)結(jié)構(gòu),存儲(chǔ)了虛擬地址與物理地址的映射。


頁(yè)表示例:

假設(shè)有一個(gè)虛擬地址 0xB8000000,通過(guò)頁(yè)表,它可能被映射到物理地址 0x12000000。這個(gè)過(guò)程是透明的,應(yīng)用程序只需要處理虛擬地址,操作系統(tǒng)和硬件負(fù)責(zé)完成地址轉(zhuǎn)換。


4


虛擬地址的應(yīng)用實(shí)例

在應(yīng)用程序中,開(kāi)發(fā)人員通常只與虛擬地址打交道。以下是一個(gè)簡(jiǎn)單的 C 程序示例,演示如何使用虛擬地址訪問(wèn)內(nèi)存。


#include <stdio.h>#include <stdlib.h> int main() {    int *ptr = (int *)malloc(sizeof(int));    if (ptr == NULL) {        fprintf(stderr, "內(nèi)存分配失??!n");        return 1;    }     *ptr = 42;    printf("虛擬地址: %p, 值: %dn", (void*)ptr, *ptr);     free(ptr);    return 0;}


在這個(gè)示例中,malloc() 函數(shù)分配了一塊內(nèi)存,并返回該內(nèi)存塊的虛擬地址。該地址在程序的虛擬地址空間中有效,指向一個(gè)內(nèi)存位置。通過(guò)打印指針 ptr 的值,可以看到虛擬地址。


5


物理地址的應(yīng)用實(shí)例

物理地址的直接使用通常僅限于操作系統(tǒng)內(nèi)核或驅(qū)動(dòng)程序開(kāi)發(fā)。在內(nèi)核編程中,開(kāi)發(fā)人員可以通過(guò)一些內(nèi)核 API 來(lái)獲取物理地址。例如,通過(guò) virt_to_phys() 函數(shù)可以將虛擬地址轉(zhuǎn)換為物理地址。


#include <linux/kernel.h>#include <linux/module.h>#include <linux/slab.h> int init_module(void) {    void *vaddr;    unsigned long paddr;     vaddr = kmalloc(4096, GFP_KERNEL);    if (!vaddr) {        printk("內(nèi)存分配失敗n");        return -ENOMEM;    }     paddr = virt_to_phys(vaddr);    printk("虛擬地址: %p, 物理地址: %lxn", vaddr, paddr);     kfree(vaddr);    return 0;} void cleanup_module(void) {    printk("模塊卸載n");} MODULE_LICENSE("GPL");


這個(gè)內(nèi)核模塊分配了一塊內(nèi)存,并將其虛擬地址轉(zhuǎn)換為物理地址。virt_to_phys() 函數(shù)只在內(nèi)核態(tài)有效,用戶態(tài)程序無(wú)法直接調(diào)用。


6


物理地址和虛擬地址的優(yōu)缺點(diǎn)

虛擬地址的優(yōu)點(diǎn)

  • 每個(gè)進(jìn)程擁有獨(dú)立的虛擬地址空間,提高了安全性和穩(wěn)定性。

  • 虛擬地址空間可以大于實(shí)際物理內(nèi)存,通過(guò)交換技術(shù)(paging),虛擬內(nèi)存可以被分配給更大的地址空間。


物理地址的優(yōu)點(diǎn)

  • 直接對(duì)應(yīng)物理內(nèi)存,訪問(wèn)速度快,無(wú)需經(jīng)過(guò)地址轉(zhuǎn)換。

  • 在操作系統(tǒng)內(nèi)核和驅(qū)動(dòng)程序中,物理地址通常用于直接訪問(wèn)硬件資源。


物理地址和虛擬地址是 Linux 系統(tǒng)內(nèi)存管理的重要概念。虛擬地址提供了更靈活和安全的內(nèi)存管理方式,使得每個(gè)進(jìn)程擁有獨(dú)立的地址空間。而物理地址則直接映射到實(shí)際的內(nèi)存位置,通常用于內(nèi)核級(jí)別的操作。理解這兩個(gè)概念及其應(yīng)用,對(duì)于系統(tǒng)編程和操作系統(tǒng)的深入理解非常關(guān)鍵。

*博客內(nèi)容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀點(diǎn),如有侵權(quán)請(qǐng)聯(lián)系工作人員刪除。



關(guān)鍵詞: Linux

相關(guān)推薦

技術(shù)專(zhuān)區(qū)

關(guān)閉