ZYNQ7000 時(shí)鐘配置方法
掃描二維碼
隨時(shí)隨地手機(jī)看文章
為了將ZYNQ的PS測(cè)的兩個(gè)核運(yùn)行頻率提升到1GHZ,同時(shí)正確的配置我的時(shí)鐘定時(shí)器以及時(shí)間戳,需要了解ZYNQ的時(shí)鐘管理系統(tǒng)和配置方法。
1.ZYNQ PS側(cè)的時(shí)鐘子系統(tǒng)及默認(rèn)配置
PS_CLK:系統(tǒng)晶振的時(shí)鐘,這個(gè)是PS端的的時(shí)鐘來(lái)源,經(jīng)過(guò)一個(gè)叫PLL的鎖相環(huán)功能部件,輸出到ARM PLL和I/O PLL以及DDR PLL,后續(xù)的子部件均由這三個(gè)時(shí)鐘源輸出。
這里對(duì)于cpu的時(shí)鐘源選擇,由寄存器ARM_CLK_CTRL(0XF8000120)控制,該寄存器時(shí)鐘源選擇的描述如下:
這里cpu的時(shí)鐘源可以選擇是IO還是DDR還是ARM的PLL,關(guān)于CPU后續(xù)時(shí)鐘的配置,cpu6x4x3x2x1x這些時(shí)鐘的配置,有一張更清晰的圖,如下:
這里經(jīng)過(guò)選擇以后,可以控制輸出到arm端的分頻系數(shù),這個(gè)分頻系數(shù)在13:8位,然后通過(guò)24~27位,選擇是否使能cpu各個(gè)分頻的時(shí)鐘。
這里各個(gè)部件的時(shí)鐘源都是可以選擇的,比如QSPI,可以選擇是IO還是DDR還是ARM的PLL,然后再去配置自己的時(shí)鐘,在節(jié)能模式下,可以優(yōu)化時(shí)鐘的配置,達(dá)到降低功耗的目的,這里不去深究,我的目的就是正確的配置時(shí)鐘。
比如我的PS_CLK是33.3MHZ,經(jīng)過(guò)PLL的倍頻,到了1333MHZ,然后經(jīng)過(guò)6bit的可編程分頻系數(shù),也就是ARM_CLK_CTRL的13:8位,這里假設(shè)是2,這個(gè)系數(shù)只能是2,4或者更大的數(shù),不能寫(xiě)1或者3.
這之后假如各個(gè)cpux的時(shí)鐘都使能了,得到的結(jié)果就是cpu6x4x = 1333MHZ/2 = 667MHZ,這也是默認(rèn)的CPU主頻,其于依照倍數(shù)關(guān)系自然可以確認(rèn)。
這里還要注意的就是有一個(gè)CLK_621_TRUE,這個(gè)是控制cpu測(cè)的各個(gè)時(shí)鐘的倍頻關(guān)系,如果設(shè)置為1,則倍頻關(guān)系為6:2:1,否則為421關(guān)系,即4:2:1,這個(gè)默認(rèn)我們都是配置621模式。
2.設(shè)置ZYNQ CPU工作在1GHZ
由上面的配置信息可知,要提高CPU的工作頻率,有兩個(gè)方法,第一是降低分頻系數(shù),及上圖中的6bit programmable divider,這是由ARM_CLK_CTRL控制的寄存器,第二是提高前面三個(gè)的PLL輸出頻率,由于分頻系數(shù),一般都設(shè)置為最低的2,所以要提高cpu的頻率,只有想辦法提高前面PLL的輸出頻率,默認(rèn)是輸出1333MHZ,I/O是1G,DDR是1066MHZ;如下圖中的配置:
這里對(duì)應(yīng)的fdiv是40,有沒(méi)有辦法可以設(shè)置更高的fdiv,辦法肯定是有的,zynq對(duì)時(shí)鐘部分提供了可編程的特性,在手冊(cè)中有program model的介紹,這里對(duì)fdiv有一個(gè)配置表:
各個(gè)時(shí)鐘源,無(wú)論arm pll還是io pll還是ddr pll,都需要遵照這個(gè)表中的數(shù)據(jù)去配置,加入我要將arm cpu的運(yùn)行頻率提高為1GHZ,由于前面提到的divider是2,那么pll輸出過(guò)來(lái)的頻率需要為2GHZ。
由于PS_CLK為33.3,那就需要fdiv的倍頻系數(shù)為60,這樣可以達(dá)到,這個(gè)數(shù)值,芯片是支持的,只需要配置pll cp為2,pll res為4,lock cnt為250,那么配置這些只需要如下兩個(gè)寄存器:
ARM_PLL_CTRL----0xF8000100
ARM_PLL_CFG ---- 0xF8000110
其中ARM_PLL_CTRL:
其中18:12位,就是設(shè)置fdiv的值,這個(gè)值理論上最小為1最大為66,設(shè)置60已經(jīng)接近極限了,下面的幾個(gè)位是用來(lái)配置的時(shí)候重啟以及設(shè)置旁路模式,也需要關(guān)注一下;
ARM_PLL_CFG
這個(gè)寄存器就是需要按照上面的表,當(dāng)fdiv為60的時(shí)候,pll_cp和pll_res以及l(fā)ock_cnt的值填寫(xiě)進(jìn)去。
整體配置思路如下:
設(shè)置
ARM_CLK_CTRL----0xF8000120
設(shè)置分頻為2,選擇arm PLL,使能各個(gè)倍頻輸出
ARM_PLL_CTRL----0xF8000100
設(shè)置FDIV為60
ARM_PLL_CFG ---- 0xF8000110
設(shè)置LOCK PLL_CP PLL_RES分別為250,2,4
具體過(guò)程:
step1:確認(rèn)該寄存器可以解鎖鎖定
step2:設(shè)置以上三個(gè)寄存器
step3:將PLL設(shè)置為旁路模式
step4:重啟PLL,reset置位
step5:重啟PLL,reset清零
step6:設(shè)置為非旁路模式,使得pll輸出工作
經(jīng)過(guò)測(cè)試,我校準(zhǔn)了udelay,測(cè)試了時(shí)間戳和sleep等接口,均準(zhǔn)確:
CPU Freq Get Test!
cpu freq = 1000.00 Mhz
Sleep[tick] 5S:[5000.000000]ms
Sleep[timestamp] 1S:[994.901318]ms
udelay[100ms]:[100.012590]ms
udelay[100us]:[100.224000]us
CPU頻率的計(jì)算公式:
cpu frequency = PS_CLK*FDIV/DIVIDER*1.0
3.定時(shí)器的時(shí)鐘來(lái)源
在cortex a9的官方手冊(cè),以及zynq7000 ug585手冊(cè)中,時(shí)鐘定時(shí)器的來(lái)源為cpu3x2x,所以當(dāng)主頻改變?yōu)?GHZ的時(shí)候,cpu2x3x的頻率也需要修改為499MHZ,這樣系統(tǒng)的定時(shí)器功能才正常。





