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);