时钟合成芯片-CDCE913-Linux驱动调试-(1)

1. 芯片简介

    CDCE913的芯片手册可在 TI 官网下载,地址:http://www.ti.com.cn/product/cn/CDCE913?keyMatch=CDCE913&tisearch=Search-CN-technicaldocument&usecase=part-number

    CDCE913的功能框图:
在这里插入图片描述
  CDCE913芯片支持 I2C 通信,其Linux驱动在内核中已支持,驱动源码路径:\drivers\clk\clk-cdce925.c
在这里插入图片描述
    驱动说明:
    多个PLL的时钟合成器(CDCE913/925/937/949)驱动程序。
    这个驱动程序总是将Y1连接到输入时钟,Y2/Y3连接到PLL1,Y4/Y5到PLL2,等等。锁相环的频率设定以 ”先到先得“ 为基础。芯片使用标准的clk框架满足客户对任何频率输出的请求。此外,该设备可以通过devicetree配置和激活。

    使用方式,期望输入10M,输出10M
在这里插入图片描述

2. 设备树中I2C节点和时钟配置

    TI 用于 CDCE925 的 Linux 驱动程序介绍:
    http://www.ti.com.cn/tool/cn/CDCE925SW-LINUX

    设备树配置说明文件:\linux-at91\Documentation\devicetree\bindings\clock\ti,cdce925.txt
在这里插入图片描述
    对于设备树中时钟相关的配置不是很熟,在论坛中找到相关介绍,如下。

    时钟的提供者与使用者:
在这里插入图片描述
根据上面的图示,以及sama5d2.dtsi文件中时钟节点的定义进行修改:
文件: \linux-at91\arch\arm\boot\dts\sama5d2.dtsi
修改如下:
在这里插入图片描述

文件:\linux-at91\arch\arm\boot\dts\at91-sama5d27_som1.dtsi
修改如下:
在这里插入图片描述
在这里插入图片描述

3. 设备树中的时钟一些解释


    以 s3c2440.dtsi 为例:

xti: xti_clock {
		compatible = "fixed-clock";
		clock-frequency = <12000000>;//晶振
		clock-output-names = "xti";
		#clock-cells = <0>;
	};

	clocks: clock-controller@4c000000 {
		compatible = "samsung,s3c2440-clock";
		reg = <0x4c000000 0x20>;//时钟控制寄存器
		#clock-cells = <1>;
	};

    参考文档:
     Documentation/devicetree/bindings/clock/clock-bindings.txt
     Documentation/devicetree/bindings/clock/samsung,s3c2410-clock.txt

    a. 设备树中定义了各种时钟, 在文档中称之为"Clock providers", 比如:

        clocks: clock-controller@4c000000 {
                compatible = “samsung,s3c2440-clock”;
                reg = <0x4c000000 0x20>;
                #clock-cells = <1>; // 想使用这个clocks时要提供1个u32来指定它, 比如选择这个clocks中发出的LCD时钟、PWM时钟
                };

    b. 设备需要时钟时, 它是"Clock consumers", 它描述了使用哪一个"Clock providers"中的哪一个时钟(id), 比如:

        fb0: fb@4d000000{
            compatible = “jz2440,lcd”;
            reg = <0x4D000000 0x60>;
            interrupts = <0 0 16 3>;
            clocks = <&clocks HCLK_LCD>; // 使用clocks即clock-controller@4c000000中的HCLK_LCD
        };

    c. 驱动中获得/使能时钟:

	// 确定时钟个数
	int nr_pclks = of_count_phandle_with_args(dev->of_node, "clocks",
						"#clock-cells");
	// 获得时钟
	for (i = 0; i < nr_pclks; i++) {
		struct clk *clk = of_clk_get(dev->of_node, i);
	}
	// 使能时钟
	clk_prepare_enable(clk);
	// 禁止时钟
	clk_disable_unprepare(clk);
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

heat.huang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值