转自:http://blog.csdn.net/zkami/article/details/2496770

usb_hcd_omap_probe (const struct hc_driver *driver) (dev/ohci/ohci-omap.c)
在模块初始化时被platform_driver_register()调用,用来初始化与ohci_hcd_omap_driver
相匹配的usb主控制器.
->usb_create_hcd(driver);   创建一个代表host-controller的数据结构(struct usb_hcd)并初始化 core/hcd.h 
        ->hcd = kzalloc(sizeof(*hcd) + driver->hcd_priv_size, GFP_KERNEL); 为struct usb_hcd分配一块内存  
        ->usb_bus_init (struct usb_bus *bus); (hcd.c) 初始化代表usb bus的数据结构(struct usb_bus)
        ->初始化struct usb_hcd的定时器,工作队列
->填充struct usb_hcd的rsrc_start字段:host-controller memory/io的起始物理地址
    rsrc_len字段:host-controller memory/io的长度
    regs字段:host-controller memory/io映射的内核虚拟地址。
->ohci_hcd_init(struct ohci_hcd *ohci);    (dev/ohci/ohci-mem.c)
->usb_add_hcd(struct usb_hcd *hcd,unsigned int irqnum, unsigned long irqflags)    (/core/hcd.h)
    完成struct usb_hcd剩余的初始化工作
        ->hcd_buffer_create(hcd):创建dmapool
        ->usb_register_bus(usb_bus):注册usb bus
        ->usb_alloc_dev(NULL, &hcd->self, 0): (core/usb.c)
            处理主控制器hcd上的根Hub(hcd->self.root_hub),这里做的就是为Root Hub申请了一个struct                usb_device结构体,并且初始化, 将返回值赋给指针rhdev. Root Hub的parent指针指向了Controller本身.
        ->ohci_omap_init:完成omap硬件的init工作  
            ->otg_get_transceiver();
            ->otg_set_host(ohci->transceiver, &ohci_to_hcd(ohci)->self);    
                针对OTG特性进行的初始化,后面分析
            ->ohci_init(struct ohci_hcd *ohci); (host/ohci-hcd.c)
                    ->为ohci->hcca分配空间
                    ->ohci_mem_init() 创建ohci->td_cache和ohci->ed_cache的dma_pool
        ->request_irq(irqnum, &usb_hcd_irq, irqflags,hcd->irq_descr, hcd)
           注册中断处理函数.其中中断号是irqnum, 中断服务程序是usb_hcd_irq(struct usb_hcd *hcd) (ohci-hcd.c).
           根据usb2.0 spec定义的中断类型有:usb_hcd_irq()根据具体类型执行相应操作,后面分析.
           #define OHCI_INTR_SO    (1 << 0)    /* scheduling overrun */
           #define OHCI_INTR_WDH    (1 << 1)    /* writeback of done_head */
           #define OHCI_INTR_SF    (1 << 2)    /* start frame */
           #define OHCI_INTR_RD    (1 << 3)    /* resume detect */
           #define OHCI_INTR_UE    (1 << 4)    /* unrecoverable error */
           #define OHCI_INTR_FNO    (1 << 5)    /* frame number overflow */
           #define OHCI_INTR_RHSC    (1 << 6)    /* root hub status change */
           #define OHCI_INTR_OC    (1 << 30)    /* ownership change */
           #define OHCI_INTR_MIE    (1 << 31)    /* master interrupt enable */
        ->ohci_omap_start(struct usb_hcd *hcd):启动OHCI
              ->ohci_run(struct ohci_hcd *ohci) (ohci-hcd.c)
                  Start an OHCI controller, set the BUS operational resets USB and controller
                  enable interrupts 根据spec写相应寄存器来启动OHCI HC
              ->ohci_stop(struct usb_hcd *hcd)
                  ohci_run失败的话,释放一些资源和已申请的中断, 释放ohci的ed/td cache以及ohci-hcca
        ->register_root_hub(struct usb_hcd) (core/hcd.c)
              ->usb_set_device_state(usb_device, usb_device_state)
                 是roothub的话仅将new_state赋给udev->state,否则根据usb_device_state作不同处理
              ->usb_get_device_descriptor(usb_dev, USB_DT_DEVICE_SIZE) 获取roothub的设备描述符
                      ->usb_get_descriptor(dev, USB_DT_DEVICE, 0, desc, size);返回设备描述符,后面分析
              ->usb_new_device(usb_dev)       配置并注册usb设备 (hub.c)
                      ->usb_configure_device(udev); (hub.c)    读取设备的配置信息
                          ->usb_get_configuration(udev);
                          ->usb_cache_string() 读取设备以下三个信息(字符描述符):product, manufacturer, serial
                          ->usb_configure_device_otg(udev);
                      ->usb_autoresume_device(udev->parent);  建立usb设备的父子关系
                      ->device_add(&udev->dev);   
                         注册usb设备: 将设备加载到总线上(添加到总线的设备队列中),并为该设备搜索与之匹配的驱动
                      ->usb_set_device_state(udev, USB_STATE_NOTATTACHED);
              ->usb_hc_died (hcd);
        ->usb_hcd_poll_rh_status(usb_hcd)    hcd.c
            获取“根Hub状态变化”的具体信息,并将该信息递交给usb_hcd->status_urb
                ->ohci_hub_status_data(usb_hcd, buf)
                    首先: 读取根Hub"状态变化信息",并将其存放于buffer中
                      ->ohci_root_hub_state_changes(ohci, changed, any_connected);
                      根据主控制器在设备接入前的状态(如SUSPEND),将主控制器状态设置为中断发生后的下一状态(如OPERATION), 并判断根Hub是否需要继续轮询(poll_rh等于表示需要继续轮询)
                          ->ohci_rh_suspend(ohci, 1);  pm方面以后分析
                          ->ohci_rh_resume(ohci);      pm方面以后分析
                          ->usb_hcd_resume_root_hub(ohci_to_hcd(ohci));    pm方面以后分析
                    然后: 将保存于buffer中的root hub"状态变化信息"传递给usb_hcd->status_urb并将该urb提交给root hub驱动层
                -> usb_hcd_unlink_urb_from_ep()
                -> usb_hcd_giveback_urb()
                -> mod_timer() 调整roothub定时器使其再次进入定时器队列

Linux USB Host-Controller的初始化代码框架分析【转】的更多相关文章

  1. linux USB HOST之EHCI和OHCI【转】

    转自:http://blog.csdn.net/ljzcom/article/details/8186914 版权声明:本文为博主原创文章,未经博主允许不得转载.   目录(?)[-] 2 关键数据结 ...

  2. Using a USB host controller security extension for controlling changes in and auditing USB topology

    Protecting computer systems from attacks that attempt to change USB topology and for ensuring that t ...

  3. Linux usb 3. Host 详解

    文章目录 1. 简介 2. Usb Core 驱动设备模型 2.1 Usb Device Layer 2.1.1 device (struct usb_device) 2.1.2 driver (st ...

  4. 转:USB主机控制器(Host Controller)--深入理解

    1. 主机控制器(Host Controller) • UHCI: Universal Host Controller Interface (通用主机控制接口, USB1.0/1.1)      • ...

  5. linux usb驱动记录(一)

    一.linux 下的usb驱动框架 在linux系统中,usb驱动可以从两个角度去观察,一个是主机侧,一个是设备侧.linux usb 驱动的总体框架如下图所示:   从主机侧看usb驱动可分为四层: ...

  6. Security arrangements for extended USB protocol stack of a USB host system

    Security arrangements for a universal serial bus (USB) protocol stack of a USB host system are provi ...

  7. Linux usb 6. HC/UDC 测试

    目录 1. 背景介绍 2. Device (gadget zero) 2.1 gadget zero 创建 2.2 SourceSink Function 2.3 Loopback Function ...

  8. Linux USB驱动框架分析(2)【转】

    转自:http://blog.chinaunix.net/uid-23046336-id-3243543.html   看了http://blog.chinaunix.net/uid-11848011 ...

  9. Linux USB驱动框架分析 【转】

    转自:http://blog.chinaunix.net/uid-11848011-id-96188.html 初次接触与OS相关的设备驱动编写,感觉还挺有意思的,为了不至于忘掉看过的东西,笔记跟总结 ...

随机推荐

  1. We are a team----sh_6666

    团队宣言:编程,我们是玩命的,玩命,我们是认真的. 团队简介: 团队名称:sh_6666队 团队博客链接:http://www.cnblogs.com/sh-6666/ 人物简介: 剧团导演:吴小勇 ...

  2. ElasticSearch 2 (31) - 信息聚合系列之时间处理

    ElasticSearch 2 (31) - 信息聚合系列之时间处理 摘要 如果说搜索是 Elasticsearch 里最受欢迎的功能,那么按时间创建直方图一定排在第二位.为什么需要使用时间直方图? ...

  3. MySQL基础(二):视图、触发器、函数、事务、存储过程

    一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. 视图和上一篇学到的临时表搜索类似. ...

  4. Python进阶-配置文件

    一. 什么是配置文件?为什么要做配置文件? 将所有的代码和配置都变成模块化可配置化,这样就提高了代码的重用性,不再每次都去修改代码内部,这个就是我们逐步要做的事情,可配置化 二. 配置文件长啥样? 配 ...

  5. 11Java网络编程

    十一.网络编程       11.1 网络通信协议 网络通信协议:通信协议是对计算机必须遵守的规则,只有遵守这些规则,计算机之间才能进行通信.这就好比在道路中行驶的汽车一定要遵守交通规则一样,协议中对 ...

  6. c++11 追踪返回类型

    c++11 追踪返回类型 返回类型后置:使用"->"符号,在函数名和参数列表后面指定返回类型. #define _CRT_SECURE_NO_WARNINGS #includ ...

  7. 【洛谷P4955 】[USACO14JAN]越野滑雪越野滑雪

    题目链接:ヾ(≧∇≦*)ゝ 对于每一个点可以向它右边的点和下面的点连边,权值就为两个点的高度差 然后再把所有的边按边权从小到大排序,并查集加点 最后判断当前集合是否涵盖所有的航点,如果是,就输出最后一 ...

  8. 【刷题】BZOJ 4945 [Noi2017]游戏

    Description http://www.lydsy.com/JudgeOnline/upload/Noi2017D2.pdf Solution 字符串里的'x'看起来很烦,于是考虑枚举这些'x' ...

  9. bzoj1008/luogu3197 越狱 (快速幂)

    算$m^n-m*(m-1)^{n-1}$,就是总的减去不越狱的,不越狱就每次都选一个和上一个不一样的

  10. Json对象和Json字符串的区别

    说白了,字符串都是带引号的. 尤其是在使用springmvc的时候,后台@RequestBody接受的是一个json格式的字符串,一定是一个字符串.  参考这个博客还可以: https://blog. ...