天天看点

platform_device内存,中断,时钟

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(),来时能对应的外设时钟源。