`
javatome
  • 浏览: 822903 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Linux那些事儿之我是UHCI(7)主机控制器的初始化(一)

 
阅读更多

好了,usb_alloc_dev,多么熟悉啊,在讲hub驱动时这就是那个八大函数的第一个.这里做的就是为Root Hub申请了一个struct usb_device结构体,并且初始化,将返回值赋给指针rhdev.回顾这个函数我们可以知道,Root Hubparent指针指向了Controller本身.

1585,确定rhdevspeed,UHCIOHCI都是源于曾经的USB1.1,EHCI才是来自USB2.0.只有USB2.0才定义了高速的设备,以前的设备只有两种速度,低速和全速.也只有EHCI的驱动才定义了一个flag,HCD_USB2.所以咱们这里记录的rhdev->speed就是USB_SPEED_FULL.不过我需要再次提醒一下,hcd->driver在咱们的故事里就是那个hc_driver,uhci_driver,有且只有这一个driver.

1593,device_init_wakeup.也是咱们在hub驱动中见过的.第二个参数是1就意味着我们把Root HubWakeup能力打开了.正如注释里说的那样,你要是看不惯,你可以在自己的driver里面把它关掉.

1598,如果hc_driver中有reset函数,就调用它,咱们的uhci_driver里面显然是有的.回去看它的定义,知道它就是uhci_init.所以这时候就要调用这个函数了,显然它的名字告诉我们它的作用是做一些初始化.它来自drivers/usb/host/uhci-hcd.c:

483 static int uhci_init(struct usb_hcd *hcd)

484 {

485 struct uhci_hcd *uhci = hcd_to_uhci(hcd);

486 unsigned io_size = (unsigned) hcd->rsrc_len;

487 int port;

488

489 uhci->io_addr = (unsigned long) hcd->rsrc_start;

490

491 /* The UHCI spec says devices must have 2 ports, and goes on to say

492 * they may have more but gives no way to determine how many there

493 * are. However according to the UHCI spec, Bit 7 of the port

494 * status and control register is always set to 1. So we try to

495 * use this to our advantage. Another common failure mode when

496 * a nonexistent register is addressed is to return all ones, so

497 * we test for that also.

498 */

499 for (port = 0; port < (io_size - USBPORTSC1) / 2; port++) {

500 unsigned int portstatus;

501

502 portstatus = inw(uhci->io_addr + USBPORTSC1 + (port * 2));

503 if (!(portstatus & 0x0080) || portstatus == 0xffff)

504 break;

505 }

506 if (debug)

507 dev_info(uhci_dev(uhci), "detected %d ports/n", port);

508

509 /* Anything greater than 7 is weird so we'll ignore it. */

510 if (port > UHCI_RH_MAXCHILD) {

511 dev_info(uhci_dev(uhci), "port count misdetected? "

512 "forcing to 2 ports/n");

513 port = 2;

514 }

515 uhci->rh_numports = port;

516

517 /* Kick BIOS off this hardware and reset if the controller

518 * isn't already safely quiescent.

519 */

520 check_and_reset_hc(uhci);

521 return 0;

522 }

可恶!又出来一个新的结构体.struct uhci_hcd,很显然,这是uhci特有的.

371 struct uhci_hcd {

372

373 /* debugfs */

374 struct dentry *dentry;

375

376 /* Grabbed from PCI */

377 unsigned long io_addr;

378

379 struct dma_pool *qh_pool;

380 struct dma_pool *td_pool;

381

382 struct uhci_td *term_td; /* Terminating TD, see UHCI bug */

383 struct uhci_qh *skelqh[UHCI_NUM_SKELQH]; /* Skeleton QHs */

384 struct uhci_qh *next_qh; /* Next QH to scan */

385

386 spinlock_t lock;

387

388 dma_addr_t frame_dma_handle; /* Hardware frame list */

389 __le32 *frame;

390 void **frame_cpu; /* CPU's frame list */

391

392 enum uhci_rh_state rh_state;

393 unsigned long auto_stop_time; /* When to AUTO_STOP */

394

395 unsigned int frame_number; /* As of last check */

396 unsigned int is_stopped;

397 #define UHCI_IS_STOPPED 9999 /* Larger than a frame # */

398 unsigned int last_iso_frame; /* Frame of last scan */

399 unsigned int cur_iso_frame; /* Frame for current scan */

400

401 unsigned int scan_in_progress:1; /* Schedule scan is running */

402 unsigned int need_rescan:1; /* Redo the schedule scan */

403 unsigned int dead:1; /* Controller has died */

404 unsigned int working_RD:1; /* Suspended root hub doesn't

405 need to be polled */

406 unsigned int is_initialized:1; /* Data structure is usable */

407 unsigned int fsbr_is_on:1; /* FSBR is turned on */

408 unsigned int fsbr_is_wanted:1; /* Does any URB want FSBR? */

409 unsigned int fsbr_expiring:1; /* FSBR is timing out */

410

411 struct timer_list fsbr_timer; /* For turning off FBSR */

412

413 /* Support for port suspend/resume/reset */

414 unsigned long port_c_suspend; /* Bit-arrays of ports */

415 unsigned long resuming_ports;

416 unsigned long ports_timeout; /* Time to stop signalling */

417

418 struct list_head idle_qh_list; /* Where the idle QHs live */

419

420 int rh_numports; /* Number of root-hub ports */

421

422 wait_queue_head_t waitqh; /* endpoint_disable waiters */

423 int num_waiting; /* Number of waiters */

424

425 int total_load; /* Sum of array values */

426 short load[MAX_PHASE]; /* Periodic allocations */

427 };

写代码的人永远都不会体会到我们读代码人的痛苦,我真的觉得如果这些变态的数据结构再多出现几个的话我就不想看了.我的忍耐是有底线的,我甚至怀疑今年那部号称十足的悲剧的电影<<十分爱>>中女主角之所以说出那句经典的那些男人只知道女人的底裤在哪里,永远都不知道女人的底线在哪里,总是想挑战女人的极限.”是不是因为当时她也在看Linux内核代码?

分享到:
评论

相关推荐

    Linux那些事儿1-9合集

    由复旦fudan_abc写的,风趣的文笔,深入浅出地讲解了Linux内核相关...Linux那些事儿之我是EHCI主机控制器 Linux那些事儿之我是PCI Linux那些事儿之我是SCSI硬盘 Linux那些事儿之我是Block层 linux那些事儿之我是Sysfs

    Linux那些事儿

    Linux那些事儿之我是EHCI控制器 Linux那些事儿之我是PCI Linux那些事儿之我是SCSI硬盘 Linux那些事儿之我是Block层 Linux那些事儿之我是Sysfs 今天本人将9个单独的文档整理出来,做成了一个单独的文档,配有书签,...

    Linux那些事儿之我是UHCI

    写一下UHCI吧,也顺便怀念一下...虽然离开 Intel一年多了,但我总觉得也许有一天我还会回到 Intel.所 以关于 Intel的东西,我多少会关注一下.我挺怀念 Intel的,虽然钱也不多,但是那时候毕竟刚毕 业,对钱的问题也没想太多.

    linux那些事儿(EHCI Block SCSI Sysfs PCI USB U 盘 UHCI Hub)

    Linux那些事儿之我是EHCI主机控制器.pdf Linux那些事儿之我是Block层.pdf Linux那些事儿之我是SCSI硬盘.pdf Linux那些事儿之我是Sysfs.pdf Linux那些事儿之我是PCI.pdf Linux那些事儿之我是USB core.pdf Linux 那些...

    linux的那些事儿全集

    Linux那些事儿之我是EHCI主机控制器 Linux那些事儿之我是Hub Linux那些事儿之我是PCI Linux那些事儿之我是SCSI硬盘 Linux那些事儿之我是Sysfs Linux那些事儿之我是UHCI Linux那些事儿之我是USB core Linux那些事儿之...

    Linux那些事儿系列.rar

    》包括《Linux那些事儿之我是Hub》、《Linux那些事儿之我是Sysfs》《Linux那些事儿之我是UHCI》、《Linux那些事儿之我是USB core》、《Linux那些事儿之我是U盘》,令人叹为观止的一个linux系列书籍。只能说,江山代...

    linux那些事全集

    Linux那些事儿之我是U盘 Linux那些事儿之我是USB_core Linux那些事儿之我是UHCI Linux那些事儿之我是Sysfs Linux那些事儿之我是SCSI硬盘 ...Linux那些事儿之我是EHCI主机控制器 Linux那些事儿之我是Block层

    Linux那些事儿.rar

    Linux那些Linux那些事儿之我是SCSI硬盘,Linux那些事儿之我是Block层,Linux那些事儿之我是EHCI主机控制器,Linux那些事儿之我是HUB,Linux那些事儿之我是PCI,Linux那些事儿之我是Sysfs,Linux那些事儿之我是UHCI,...

    Linux那些事儿 系列之2 Block+EHCI+PCI+SCSI

    Linux那些事儿之我是EHCI主机控制器.pdf Linux那些事儿之我是PCI.pdf Linux那些事儿之我是SCSI硬盘.pdf 注: 之前有人已经上传了《Linux那些事儿 系列》,其已经包含了:hub,sysfs,UHCI,usb core,U盘,此处,先...

    Linux那些事儿系列

    本人整理的fudan_abc的专栏中以完结的文章,在此向原作者表示感谢,给...内容包括:linux那些事儿之我是U盘,linux那些事儿之我是USB,linux那些事儿之我是HUB,linux那些事儿之我是UHCI,linux那些事儿之我是Sysfs。

    Linux那些事儿之我是XXX全集.rar

    Linux那些事儿之我是XXX全集 包含USB core U盘 UHCI PCI SCSI硬盘 Block Hub EHCI 。 想学驱动的童鞋,不妨看看。该书主要是进行源代码的分析

    linux那些事儿之我是USB.zip

    里面包含Linux那些事的九个文档,Block层,ECHI主机控制,HUB,PCI,SCSI硬盘,Sysfs,UHCI,USB+core,U盘等九个文档,内容详细,而且全面都有书签,适合系统学习!

    微信生活缴费商业项目标准版

    Linux那些Linux那些事儿之我是SCSI硬盘,Linux那些事儿之我是Block层,Linux那些事儿之我是EHCI主机控制器,Linux那些事儿之我是HUB,Linux那些事儿之我是PCI,Linux那些事儿之我是Sysfs,Linux那些事儿之我是UHCI,...

    Linux那些事系列

    Linux那些事儿之我是Hub Linux那些事儿之我是Sysfs Linux那些事儿之我是UHCI Linux那些事儿之我是USB core Linux那些事儿之我是U盘 Linux那些事之我是HUB1

    usb那些事的全集

    2 Linux那些事儿之我是EHCI主机控制器 3 Linux那些事儿之我是HUB 4 Linux那些事儿之我是PCI 5 Linux那些事儿之我是SCSI硬盘 6 Linux那些事儿之我是Sysfs 7 Linux那些事儿之我是UHCI 8 Linux那些事儿之我是USB+core 9...

    linux那些事儿.rar

    linux那些事儿,Block层,EHCI主机控制器,Hub,PCI,SCSI硬盘,Sysfs,UHCI,USB core,U盘等文档。

    Linux那些事儿[完整版]自己整理

    我是U盘 说的是2.6.10的内核 我是Sysfs 说的是2.6.10的内核 戏说USB 说的是2.6.22的内核 我是Hub/UHCI/EHCI 说的是2.6.22.1的内核

    LINUX那些事儿 linux经典之作

    作者用通俗幽默的语言简述了linux的相关知识点,很容易掌握的,建议大家好好学哦 我是U盘 说的是2.6.10的内核 我是Sysfs 说的是2.6.10的内核 戏说USB 说的是2.6.22的内核 我是Hub/UHCI/EHCI 说的是2.6.22.1的内核 ...

    Linux那些事儿(包括Hub, Sysfs, UHCI, USB, U盘5个部分)

    一个很经典的东东,里面的很多东西都很有启发性,值得看看

Global site tag (gtag.js) - Google Analytics