platform_device内存资源使用步骤
1.res = platform_get_resource(pdev,IORESOURCE_MEM,0);
platform_get_resource 返回资源对象
2.request_mem_region(res->,res->end - res->start + 1,DRIVER_NAME);
request_mem_region()宏,请求分配指定的I/O内存资源
#define request_mem_region(start,n,name) __request_region(&iomem_resource, (start), (n), (name))
注: 调用request_mem_region()不是必须的,但是建议使用。该函数的任务是检查申请的资源是否可用,
如果可用则申请成功,并标志为已经使用,其他驱动想再申请该资源时就会失败。
3.host->baseaddr = ioremap(res->,res->end - res->start + 1);//地址映射
void * __ioremap(unsigned long phys_addr, unsigned long size, unsigned long flags)
将一个IO地址空间映射到内核的虚拟地址空间上去,便于访问。
release_mem_region()宏,释放指定的I/O内存资源。
#define release_mem_region(start,n) __release_region(&iomem_resource, (start), (n))
platform_device中断资源使用步骤
1.host->irq = platform_get_irq(pdev,0);
2.ret = request_irq(host->irq,at91_mci_irq,IROF_SHARED,DRIVER_NAME,host);
外设时钟的开启
struct clk=clk_get(NULL,"adc");
clk.enable();
之后adc对应的时钟位就能时能。
struct clk *clk_get(struct device *dev, const char *id)
{
..........
list_for_each_entry(p, &clocks, list) {
if (p->id == idno &&
strcmp(id, p->name) == 0 &&
try_module_get(p->owner)) {
clk = p;
break;
}
}
.............................................
return clk;
}
clk_get从一个时钟list链表中以字符id名称来查找一个时钟clk结构体并且返回,最后调用clk.enable(),来时能对应的外设时钟源。