ioremap和ioremap_nocache函数笔记
ioremap - 將一個(gè)IO地址空間映射到內(nèi)核的虛擬地址空間上去
void * __ioremap(unsigned long phys_addr, unsigned long size, unsigned long flags)
入口: phys_addr:要映射的起始的IO地址;
size:要映射的空間的大小;
flags:要映射的IO空間的和權(quán)限有關(guān)的標(biāo)志;
?
void *ioremap(unsigned long phys_addr, unsigned long size)
phys_addr:是要映射的物理地址
size:是要映射的長度,單位是字節(jié)
頭文件:io.h
ioremap 依靠 __ioremap實(shí)現(xiàn),它只是在__ioremap中以第三個(gè)參數(shù)為0調(diào)用來實(shí)現(xiàn).
ioremap是內(nèi)核提供的用來映射外設(shè)寄存器到主存的函數(shù):舉個(gè)例子,比如某個(gè)驅(qū)動(dòng)設(shè)備有100 個(gè)寄存器,他們都是連在一塊的,位置是固定的,假如每個(gè)寄存器占4個(gè)字節(jié),那么一共400個(gè)字節(jié)的空間被映射到內(nèi)存成功后,ioaddr就是這段地址的開頭(注意ioaddr是虛擬地址,而mmio_start是物理地址,它是BIOS得到的,肯定是物理地址,而保護(hù)模式下CPU不認(rèn)物理地址,只認(rèn)虛擬地址),ioaddr+0就是第一個(gè)寄存器的地址,ioaddr+4就是第二個(gè)寄存器地址(每個(gè)寄存器占4個(gè)字節(jié)),以此類推。
ioremap_nocache - 把內(nèi)存映射到CPU空間
void __iomem * ioremap_nocache (unsigned long phys_addr, unsigned longsize); ?
phys_addr:要映射的物理地址?
size:要映射資源的大小?
ioremap_nocache進(jìn)行一系列平臺(tái)相關(guān)的操作使得CPU可以通過readb/readw/readl/writeb/writew/writel等IO函數(shù)進(jìn)行訪問。
注:返回的地址不保證可以作為虛擬地址直接訪問。
調(diào)用ioremap_nocache()函數(shù)之后,返回一個(gè)線性地址,此時(shí)CPU 可以訪問設(shè)備的內(nèi)存(已經(jīng)將其映射到了線性地址空間中了),此時(shí)CPU可以使用訪問內(nèi)存的指令訪問設(shè)備的內(nèi)存空間(host bridge 判斷訪問物理內(nèi)存還是設(shè)備中的內(nèi)存),此時(shí)我們就可以像訪問內(nèi)存一樣來訪問設(shè)備的內(nèi)存(寄存器)。
總結(jié)
以上是生活随笔為你收集整理的ioremap和ioremap_nocache函数笔记的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: COVID-19 AI-related
- 下一篇: 在Ubuntu18.04下 安装MPV视