我对platform总线的理解

学习驱动一定要掌握驱动的模型,以下是我自己的理解,有些地方不是讲得很明白,希望高手多多指教。

bus_dev_drv模型

dev:(属于不稳定的部分)
platform_device_register(&led_dev);
static struct resource led_resource[] = {
platform_device_unregister(&led_dev);


static struct resource led_resource[] = {

    [0] = {
        .start = 0x56000010,           //gpio_con gpio_dat两个寄存器占八个字节
        .end   = 0x56000010 + 8 - 1,//所以需要映射长八个字节
        .flags = IORESOURCE_MEM,
    },
    [1] = {
        .start  = 8,
        .end   = 8,
        .flags = IORESOURCE_IRQ,
    }
};

static void led_release(struct device * dev)
{
}

static struct platform_device led_dev = {
.name         = "myled",
.id       = -1,
.num_resources    = ARRAY_SIZE(led_resource),
.resource     = led_resource,
.dev = { 
.release = led_release, 
},
};


drv:(稳定的部分)
struct platform_driver led_drv = {
.probe = led_probe,
.remove = led_remove,
.driver = {
.name = "myled",
}
};


platform_driver_register(&led_drv);
platform_driver_unregister(&led_drv);
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
res = platform_get_resource(pdev, IORESOURCE_IRQ, 0);//这两个函数用开获取资源

tips:在这里这个结构体里面的name必须和dev里面的name一致,只有相同的时候才会调用led_probe
其他的跟写普通的字符设备驱动是不变的



这里建讲解一个小的技巧,当映射多个连续的地址时候,我们定义成结构体,映射成结构体的地址
struct s3c_ts_regs {
unsigned long adccon;
unsigned long adctsc;
unsigned long adcdly;
unsigned long adcdat0;
unsigned long adcdat1;
unsigned long adcupdn;
};


 struct s3c_ts_regs    *s3c_ts_regs;   /* 定义结构体指针,结构体成员必须是4字节对齐 */
  s3c_ts_regs = ioremap(0x58000000, sizeof(struct s3c_ts_regs));
   

你可能感兴趣的:(我对platform总线的理解)