ARM Linux S3C2440 之时钟分析

发布时间:2024-06-11  

S3c2440 时钟 & 电源管理时钟由三部分组成:  Clock control ,USB control, 和 Power control 

Clock control 部分可以产生时钟FCLK,提供ARM内核,HCLK 提供 AHB 总线外设,还有 PLCK APB 总线外设。 s3c2440 有两个内置的PLLS 锁相环,一个提供给 FCLK,HCLK,和PCLK,另一个提供给USB时钟(48MHZ)。Clock control 可以不使用PLL,而降低的时钟,通过软件设置,时能各中种外设,从而可以降低功耗。

Power control部分,用于电能管理,有四种工作模式:Normal mode, Slow mode, Idle mode, Sleep mode.


linux 入口时,在start_kernel()中调用 setup_arch(), 会进行平台体系相关初始化:


  1. smdk_2440_map_io()  --> s3c24xx_init_io() -->  s3c_init_cpu() -> s3c244x_init_clocks()  


  1. void __init s3c244x_init_clocks(int xtal)  

  2. {  

  3. /* initialise the clocks here, to allow other things like the 

  4. * console to use them, and to add new ones after the initialisation 

  5. */  

  6. s3c24xx_register_baseclocks(xtal);       //向系统注册基本时钟: FCLK,HCLK, PCLK   

  7. s3c244x_setup_clocks();                       //设置基本时钟的参数   

  8. s3c2410_baseclk_add();                      //添加其他外设的时钟   

  9. }  


系统将所有外设的时钟通过一个叫做struct clk的结构体来进行描述:


  1. struct clk {  

  2. struct list_head      list;  

  3. struct module        *owner;  

  4. struct clk           *parent;  

  5. const char           *name;  

  6. int      id;  

  7. int      usage;  

  8. unsigned long         rate;  

  9. unsigned long         ctrlbit;  

  10.   

  11. int    (*enable)(struct clk *, int enable);  

  12. int    (*set_rate)(struct clk *c, unsigned long rate);  

  13. unsigned long    (*get_rate)(struct clk *c);  

  14. unsigned long    (*round_rate)(struct clk *c, unsigned long rate);  

  15. int    (*set_parent)(struct clk *c, struct clk *parent);  

  16. };  


将所有时钟分成两类,一类是开启,一类关闭; 分别至于 两个数组中


  1. struct clk init_clocks[];   struct clk init_clocks_disable[];  


最后一一注册

注册时钟是通过这个函数注册的 


  1. /* initialise the clock system */  

  2.   

  3. int s3c24xx_register_clock(struct clk *clk)  

  4. {  

  5.     if (clk->enable == NULL)  

  6.         clk->enable = clk_null_enable;  

  7.   

  8.     /* add to the list of available clocks */  

  9.   

  10.     /* Quick check to see if this clock has already been registered. */  

  11.     BUG_ON(clk->list.prev != clk->list.next);  

  12.   

  13.     spin_lock(&clocks_lock);  

  14.     list_add(&clk->list, &clocks);  

  15.     spin_unlock(&clocks_lock);  

  16.   

  17.     return 0;  

  18. }  

linux 中 s3c2440 时钟的初始化:


  1. MACHINE_START(S3C2440, "SMDK2440")  

  2. /* Maintainer: Ben Dooks  */  

  3. .phys_io = S3C2410_PA_UART,  

  4. .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc,  

  5. .boot_params = S3C2410_SDRAM_PA + 0x100,  

  6.   

  7.   

  8. .init_irq = s3c24xx_init_irq,  

  9. .map_io = smdk2440_map_io,  

  10. .init_machine = smdk2440_machine_init,  

  11. .timer = &s3c24xx_timer,  

  12. MACHINE_END  


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>