ioremap,英文词语

更新时间:2022-10-25 16:15:25 阅读: 评论:0

名词解释

void * __ioremap(unsigned long phys_addr, unsigned long size, unsigned long flags)

void *ioremap(unsigned long phys_addr, unsigned long size)

入口: phys_addr:要映射的起始的IO地址;

size:要映射的空间的大小;

flags:要映射的IO空间的和权限有关的标志;

phys_addr:是要映射的物理地址,

size:是要映射的长度,

S3C2410的long是32位而非64位。

功能:将一个IO地址空间映射到内核的虚拟地址空间上去,便于访问;

实现:对要映射的IO地址空间进行判断,低PCI/ISA地址不需要重新映射,也不允许用户将IO地址空间映射到正在使用的RAM中,最后申请一个 vm_area_struct结构,调用remap_area_pages填写页表,若填写过程不成功则释放申请的vm_area_struct空间;

ioremap 依靠 __ioremap实现,它只是在__ioremap中以第三个参数为0调用来实现.

ioremap是内核提供的用来映射外设寄存器到主存的函数,我们要映射的地址已经从pci_dev中读了出来(上一步),这样就水到渠成的成功映射了而不会和其他地址有冲突。映射完了有什么效果呢,我举个例子,比如某个网卡有100 个寄存器,他们都是连在一块的,位置是固定的,假如每个寄存器占4个字节,那么一共400个字节的空间被映射到内存成功后,ioaddr就是这段地址的开头(注意ioaddr是虚拟地址,而mmio_start是物理地址,它是BIOS得到的,肯定是物理地址,而保护模式下CPU不认物理地址,只认虚拟地址),ioaddr+0就是第一个寄存器的地址,ioaddr+4就是第二个寄存器地址(每个寄存器占4个字节),以此类推,我们就能够在内存中访问到所有的寄存器进而操控他们了。

A new I/O memory access mechanism

Most reasonably current cards for the PCI bus (and others) provide one or more I/O memory regions to the bus. By accessing tho regions, the processor can communicate with the peripheral and make things happen. A look at /proc/iomem will show the I/O memory regions which have been registered on a given system.

Advertiment

To work with an I/O memory region, a driver is suppod to map that region with a call to ioremap(). The return value from ioremap() is a magic cookie which can be pasd to a t of accessor functions (with names like readb() or writel()) to actually move data to or from the I/O memory. On some architectures (notably x86), I/O memory is truly mapped into the kernel's memory space, so tho accessor functions turn into a straightforward pointer dereference. Other architectures require more complicated operations.

There have been some longstanding problems with this scheme. Drivers written for the x86 architecture have often been known to simply dereference I/O memory address directly, rather than using the accessor functions. That approach works on the x86, but breaks on other architectures. Other drivers, knowing that I/O memory address are not real pointers, store them in integer variables; that works until they encounter a system with a physical address space which doesn't fit into 32 bits. And, in any ca, readb() and friends perform no type checking, and thus fail to catch errors which could be found at compile time.

The 2.6.9 kernel will contain a ries of changes designed to improve how the kernel works with I/O memory. The first of the is a new __iomem annotation ud to mark pointers to I/O memory. The annotations work much like the __ur markers, except that they reference a different address space. As with __ur, the __iomem marker rves a documentation role in the kernel code; it is ignored by the compiler. When checking the code with spar, however, developers will e a whole new t of warnings caud by code which mixes normal pointers with __iomem pointers, or which dereferences tho pointers.

The Next Step is the addition of a new t of accessor functions which explicitly require a pointer argument. The functions are:

unsigned int ioread8(void __iomem *addr); unsigned int ioread16(void __iomem *addr); unsigned int ioread32(void __iomem *addr); void iowrite8(u8 value, void __iomem *addr); void iowrite16(u16 value, void __iomem *addr); void iowrite32(u32 value, void __iomem *addr);By default, the functions are simply wrappers around readb() and friends. The explicit pointer type for the argument will generate warnings, however, if a driver pass in an integer type.

There are string versions of the operations:

extern void ioread8_rep(void __iomem *port, void *buf, unsigned long count);All of the other variants are defined as well, of cour.

There is actually one other twist to the functions. Some drivers have to be able to u either I/O memory or I/O ports, depending on the architecture and the device. Some such drivers have gone to considerable lengths to try to avoid duplicating code in tho two cas. With the new accessors, a driver which finds it needs to work with x86-style ports can call:

void __iomem *ioport_map(unsigned long port, unsigned int count);The return value will be a cookie which allows the mapped ports to be treated as if they were I/O memory; functions like ioread8() will automatically do the right thing. For PCI devices, there is a new function:

void __iomem *pci_iomap(struct pci_dev *dev, int ba, unsigned long maxlen);For this function, the ba can be either a port number or an I/O memory address, and the right thing will be done.

As of 2.6.9-rc2, there are no in-tree urs of the new interface. That can be expected to change soon as patches get merged and the kernel janitors get to work. For more information on the new I/O memory interface and the motivation behind it, e this explanation from Linus

本文来自csdn博客

本文发布于:2022-10-25 16:15:25,感谢您对本站的认可!

本文链接:http://www.wtabcd.cn/fanwen/fan/78/373934.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:ioremap
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图