twl4030_usb.c 解析

这个芯片名字是叫TPS65930,但是驱动的名字却是TWL4030,估计是同一个芯片,前后代的关系吧。
这是一个MFD芯片,multi-function device(多功能设备),集合了ldo,audio,gpio,usb phy, clock, vibrator, adc,thermal detect 等功能于一体的芯片。
 
下面是一个twl4030 usb部分的驱动分析。
 
1.init()/exit()
    static int __init twl4030_usb_init(void)
    {
        return platform_driver_register(&twl4030_usb_driver);
    }
    subsys_initcall(twl4030_usb_init);      //这里用了subsys_initcall().
    static void __exit twl4030_usb_exit(void)
    {
        platform_driver_unregister(&twl4030_usb_driver);
    }
    module_exit(twl4030_usb_exit);

struct twl4030_usb_driver :
    static struct platform_driver twl4030_usb_driver = {
        .probe        = twl4030_usb_probe,
        .remove        = __exit_p(twl4030_usb_remove),
        .driver        = {
            .name    = "twl4030_usb",      //驱动名
            .owner    = THIS_MODULE,
        },
    };

2. twl4030_usb_probe():
    static int __devinit twl4030_usb_probe(struct platform_device *pdev)
    {
        struct twl4030_usb_data *pdata = pdev->dev.platform_data;   //这个platform_data 来自board-omap3evm.c
        struct twl4030_usb    *twl;
        int            status, err;
        if (!pdata) {
            dev_dbg(&pdev->dev, "platform_data not available\n");
            return -EINVAL;
        }
        twl = kzalloc(sizeof *twl, GFP_KERNEL);
        if (!twl)
            return -ENOMEM;
        twl->dev        = &pdev->dev;
        twl->irq        = platform_get_irq(pdev, 0);     //获取中断
        twl->otg.dev        = twl->dev;
        twl->otg.label        = "twl4030";
        twl->otg.set_host    = twl4030_set_host;       
        twl->otg.set_peripheral    = twl4030_set_peripheral;
        twl->otg.set_suspend    
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个 SQL 语句有一些可优化的地方,可以考虑以下几点: 1. 尽可能使用 JOIN 代替子查询。例如,第一个子查询中的 `pub_ports` 表可以通过 JOIN 进行连接。 2. 避免使用 `array_agg` 和 `unnest` 函数。这些函数需要进行大量的数组转换操作,非常耗费资源。如果可以,可以考虑使用其他方式将数组数据按逗号拼接。 3. 在使用 GROUP BY 时,只选择必要的列。不需要 GROUP BY 的列可以在外部查询中进行选择。 4. 对于多个表的连接,可以考虑使用合适的索引来提高查询性能。 下面是优化后的 SQL 语句: ``` SELECT pot.pot_type_name, ttpw.ttpw_addr AS twlPortName, ttpw.ttpw_addr_code AS twlPortCode, tmrGroup.tmr_material_name, array_to_string(ids, ',') AS ids, tms_whe.twl_leave_stock FROM ( SELECT ttpw_tmr_id, array_agg(DISTINCT tmr.tmr_id) AS ids, ttpw_addr, ttpw_addr_code, pot_type_name, tmrGroup.tmr_material_name FROM tms_transport_plan_work ttpw JOIN tms_material_ref tmr ON tmr.tmr_id = ttpw.ttpw_tmr_id JOIN tms_material_ref tmrGroup ON tmrGroup.tmr_id = tmr.parent_tmr_id JOIN pub_ports pot ON pot.pot_regcd = ttpw.ttpw_addr_code AND pot.pot_cnname = ttpw.ttpw_addr WHERE ttpw_plan_amount > 0 GROUP BY ttpw_tmr_id, ttpw_addr, ttpw_addr_code, pot_type_name, tmrGroup.tmr_material_name ) AS info LEFT JOIN ( SELECT twl_material_id, twl_port_code, SUM(twl_leave_stock) AS twl_leave_stock FROM tms_whe_control WHERE pot_type_name = '合作港口' GROUP BY twl_material_id, twl_port_code ) AS tms_whe ON tms_whe.twl_material_id = ANY(ids) AND tms_whe.twl_port_code = twlPortCode ORDER BY twlPortName ``` 这个 SQL 语句使用了 JOIN 来代替子查询,并避免了使用 `array_agg` 和 `unnest` 函数。同时,只选择必要的列进行 GROUP BY,使用合适的索引来优化查询性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值