Linux时钟管理clk_get函数透彻分析

硬件资源越来越庞大和复杂,内核的另一个挑战就是要便捷的管理这些资源。同时,面对如此之多的平台不同的CPU

,管理机制需要统一适用,这就需要对资源的管理抽象到更加通用的层次。CPU中各个模块都需要时钟驱动,内核需

要一种机制能通用所有的平台,方便的管理CPU上所有的clk资源。这里分析Linux对clk的管理。


通常操作为以下几步:

1.定义struct clk *clk;
2.获取需要操作的clock结构体 clk=clk_get(&pdev->dev, "pclk"); /* 第一个参数一般取NULL */
3.设置频率 clk_set_rate(clk); /* 返回时钟频率 */
4.产生时钟 clk_enable(clk);

5.停止时钟clk_disable(clk);


我们下面重点分析clk_get这个函数。

struct clk定义如下:



分析clk_get这个函数:

clk_get函数定义在linux-3.4.2\drivers\clk\Clkdev.c 文件中,内容如下:



这个函数有两个参数,struct device *dev这个结构非常复杂,下面有它的具体定义,一般我们设置成NULL

,第二个人参数是我们需要设置硬件上的那部分时钟,比如adc,iis,dma等。




我们继续分析clk_get里面的调用关系,调用了clk_get_sys这个函数,第一个参数我们开始设置成NULL了,

第二个参数是我们需要设置硬件相关时钟的名字。



clk_get_sys里面通过clk_find函数;来查找我们传入的硬件名称,并返回clk_lookup类型的一个指针,

clk_find函数里面就是我们最终需要查看的内容。



list_for_each_entry函数从clocks的链表中的表头,它受clocks_lock保护,开始查找和我们传入的硬件名称相比较,

如果找到了就返回一个指向该硬件clk_lookup类型的指针。


clk_get函数到此为止分析完毕,这里补充一点,那就是第二个参数在哪里定义的呢,这里我的内核版本是

Linux-3.4.2定义在 linux-3.4.2\arch\arm\plat-samsung\Clock.c中,内容如下:

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. <span style="font-size:18px;">struct clk clk_xtal = {  
  2.     .name       = "xtal",  
  3.     .rate       = 0,  
  4.     .parent     = NULL,  
  5.     .ctrlbit    = 0,  
  6. };  
  7.   
  8. struct clk clk_ext = {  
  9.     .name       = "ext",  
  10. };  
  11.   
  12. struct clk clk_epll = {  
  13.     .name       = "epll",  
  14. };  
  15.   
  16. struct clk clk_mpll = {  
  17.     .name       = "mpll",  
  18.     .ops        = &clk_ops_def_setrate,  
  19. };  
  20.   
  21. struct clk clk_upll = {  
  22.     .name       = "upll",  
  23.     .parent     = NULL,  
  24.     .ctrlbit    = 0,  
  25. };  
  26.   
  27. struct clk clk_f = {  
  28.     .name       = "fclk",  
  29.     .rate       = 0,  
  30.     .parent     = &clk_mpll,  
  31.     .ctrlbit    = 0,  
  32. };  
  33.   
  34. struct clk clk_h = {  
  35.     .name       = "hclk",  
  36.     .rate       = 0,  
  37.     .parent     = NULL,  
  38.     .ctrlbit    = 0,  
  39.     .ops        = &clk_ops_def_setrate,  
  40. };  
  41.   
  42. struct clk clk_p = {  
  43.     .name       = "pclk",  
  44.     .rate       = 0,  
  45.     .parent     = NULL,  
  46.     .ctrlbit    = 0,  
  47.     .ops        = &clk_ops_def_setrate,  
  48. };  
  49.   
  50. struct clk clk_usb_bus = {  
  51.     .name       = "usb-bus",  
  52.     .rate       = 0,  
  53.     .parent     = &clk_upll,  
  54. };  
  55.   
  56.   
  57. struct clk s3c24xx_uclk = {  
  58.     .name       = "uclk",  
  59. };</span>  

转载:http://blog.csdn.net/qq_21792169/article/details/51085111
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值