SylixOS 基于ZYNQ的时钟频率修改详解
admin
2023-03-16 03:41:13
0
  1. 概述

    本文档以ZYNQ7000平台为例,详细介绍如何去修改ZYNQ的时钟频率。

     

  2. 时钟频率修改流程

    ZYNQ7000的时钟频率修改流程,如图 2.1所示。具体步骤如下:

    步骤一:解除ZYNQ7000的寄存器写锁定;

    步骤二:向对应寄存器写入我们需要设置的PLL倍频值和PLL配置参数;

    步骤三:进行PLL的旁路模式转换和软件重启,使我们刚刚设置的PLL倍频值和PLL配置参数生效;

    步骤四:重新使寄存器处于写锁定状态。

    SylixOS 基于ZYNQ的时钟频率修改详解

    2.1 ZYNQ7000的时钟频率修改流程图

    ZYNQ7000的ARM_PLL_CLK时钟频率修改的具体的代码实现如程序清单 2.1所示。不同平台的解除和锁定写锁定的方式可能不同,对于ZYNQ7000平台,需要写入0xDF0D到SLCR_UNLOCK寄存器解除写锁定,写入0x767B到SLCR_LOCK寄存器可以使相关寄存器的写操作无效。

    程序清单 21 ZYNQ7000的时钟频率修改代码

/*********************************************************************************************************
** 函数名称: zynqPllFeedBackSet
** 功能描述: zynq的ARM_PLL_CLK时钟倍频设置
** 输 入  : NONE
** 输 出  : NONE
** 返  回  : NONE
*********************************************************************************************************/
VOID  zynqPllFeedBackSet (VOID)
{
    UINT32  uiClkCtrl;
    UINT32  uiFeedBackDiv;
    UINT32  uiNum;

    uiNum = read32(ZYNQ_SLCR + SLCR_LOCKSTA);
    if (0 != uiNum) {
       write32(SLCR_UNLOCK_MAGIC, ZYNQ_SLCR + SLCR_UNLOCK);             /*  写入0xDF0D,解除写锁定      */
       uiNum = 0;
    }

    /*
     * 设置ARM_PLL的倍频值
     */
    uiClkCtrl      = read32(ZYNQ_SLCR + ARM_PLL_CTL);
    uiFeedBackDiv  = uiClkCtrl &~ XZYNQ_SLCR_ARM_PLL_CTRL_PLL_FDIV_MASK;
    uiFeedBackDiv |= (SLCR_FEED_BACK_DIV_VALUE << XZYNQ_SLCR_ARM_PLL_CTRL_PLL_FDIV_OFFSET);
    write32(uiFeedBackDiv, ZYNQ_SLCR + ARM_PLL_CTL);

    /*
     * 设置ARM_PLL的配置参数
     */
    uiClkCtrl      = read32(ZYNQ_SLCR + ARM_PLL_CTL);
    write32(SLCR_ARM_PLL_CFG, ZYNQ_SLCR + ARM_CLK_CFG);

    /*
     * 进行PLL的旁路模式转换和软件重启,使我们刚刚设置的PLL倍频值和PLL配置参数生效
     */
    write32(SLCR_ARM_PLL_CTRL_BYPASS_FORCE | uiClkCtrl, ZYNQ_SLCR + ARM_PLL_CTL);
    write32(SLCR_ARM_PLL_CTRL_RESET | uiClkCtrl, ZYNQ_SLCR + ARM_PLL_CTL);
    read32(ZYNQ_SLCR + PLL_STATUS);
    write32(uiClkCtrl &~ SLCR_ARM_PLL_CTRL_RESET, ZYNQ_SLCR + ARM_PLL_CTL);
    write32(uiClkCtrl &~ SLCR_ARM_PLL_CTRL_BYPASS_FORCE, ZYNQ_SLCR + ARM_PLL_CTL);

    if (0 == uiNum) {
        write32(SLCR_LOCK_MAGIC, ZYNQ_SLCR + SLCR_LOCK);                /*  写入0x760B,打开写锁定      */
        uiNum = 1;
    }
}




  1. PLL的频率设置

    ZYNQ7000的时钟频率设置的参数列表,如图 3.1所示。其中PLL_FDIV为PLL的倍频值,PLL CP、PLL RES、LOCK CNT为PLL的配置参数。

    SylixOS 基于ZYNQ的时钟频率修改详解

    SylixOS 基于ZYNQ的时钟频率修改详解

    3.1 PLL频率的参数设置列表

  2. 免责声明

    内部交流文档,仅针对ZNYQ相关平台,若发现相关错误或者建议,请及时联系文档创建者进行修订和更新。

上一篇:weblogic部署war

下一篇:jdk1.8新特性

相关内容

热门资讯

今日重大通报“天天微友.有挂吗... 您好:天天微友这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
玩家分享攻略“微乐捉鸡麻将.究... 网上科普关于“微乐捉鸡麻将有没有挂”话题很是火热,小编也是针对微乐捉鸡麻将作*弊开挂的方法以及开挂对...
今日重磅消息“想游中心五.究竟... 您好:想游中心五这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游...
终于明白“神赚棋牌.开挂器?”... 终于明白“神赚棋牌.开挂器?”必胜开挂神器您好,神赚棋牌这个游戏其实有挂的,确实是有挂的,需要了解加...
柯建铭自爆常跟赖清德报告“大罢... 海峡导报综合报道 民进党今年“7·26”“8·23”两次“大罢免”遭遇滑铁卢,作为发起人的台民意机构...
终于明白“白金岛放炮罚.究竟有... 终于明白“白金岛放炮罚.究竟有挂吗?”太坑了原来有挂您好,白金岛放炮罚这个游戏其实有挂的,确实是有挂...
获得黄金王冠后,特朗普回赠李在... 据韩联社12月24日报道,韩国总统室秘书室长姜勋植周三在社交媒体上发布了美国总统特朗普赠送给李在明的...
玩家分享攻略“微乐龙江麻将.辅... 玩家分享攻略“微乐龙江麻将.辅助器?”必胜开挂神器您好,微乐龙江麻将这个游戏其实有挂的,确实是有挂的...
【第一财经】“闲来麻将.到底有... 有 亲,根据资深记者爆料闲来麻将是可以开挂的,确实有挂(咨询软件无需打开...
最新引进“花城牌舍.辅助开挂神... 有 亲,根据资深记者爆料花城牌舍是可以开挂的,确实有挂(咨询软件无需打开...