博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
s3c2440实验---定时器
阅读量:5105 次
发布时间:2019-06-13

本文共 1630 字,大约阅读时间需要 5 分钟。

  定时器实验

 时钟是同步工作系统的同步节拍。

 

 一、时钟的获得有很多种方式

  1、外部直接输入时钟信号

  2、外部晶振+内部时钟发生器(低频单片机)

  3、外部晶振+内部时钟发生器+PLL+内部分频器

 

  二、定时器内部结构

  1、总时钟系统

  

    详细说明:在2440刚刚开机的时候,由于PLL尚未开启,FCLK即等于外部输入时钟(12MHz),如果想提供时钟频率,则要开启PLL。PLL分为

MPLL和UPLL。其中UPLL是控制USB的,这与本实验无关。MPLL分为三种时钟FCLK(CPU核时钟)、HCLK(AHB总线设备时钟)、PCLK(APK总线设备时钟)。

    

 

  2、实验内容:用定时器0实现led灯按固定时间闪烁

    

  如上图所示:定时器0获得时钟频率的路线是:PCLK->预分频器->分频器->MUX电路->控制逻辑单元->定时器0

 

三、实验前分析

  通过上述路线,可知接下来我们要进行如下步骤:

  1、获得PCLK时钟(由于PCLK是MPLL分出来的,所以我们要先设置MPLL的值,然后通过分频(寄存器CLKDIV)来进行对PCLK的设置)

  

  

 

 

  2、设置预分频器(TCFG0)

  3、设置分频器(TCFG1)

  4、设置MUX电路(默认)

  5、设置控制单元 (TCNTB0)

  在第一次使用定时器时,需要将“手动更新”位置1,使得TCNTB0寄存器的数值装入TCNT0中。之后就可以通过自动重装载将数字自动装入寄存器中。

 

四、核心代码分析

  1、初始化时钟  

    void init_timer(void)

    {
      //第一步:配置FCLK:HCLK:PCLK
      CLKDIVN = 0x03;

 

      /* 如果HDIVN非0,CPU的总线模式应该从“fast bus mode”变为“asynchronous bus mode” */

      __asm__(
      "mrc p15, 0, r1, c1, c0, 0\n" /* 读出控制寄存器 */
      "orr r1, r1, #0xc0000000\n" /* 设置为“asynchronous bus mode” */
      "mcr p15, 0, r1, c1, c0, 0\n" /* 写入控制寄存器 */
      );
      //第二步:配置MPLL
      MPLLCON = FCLK; //200MHz
      //第三步:设置定时器0 此时PCLK为50MHz
      TCFG0 = 99; //预分频器
      TCFG1 = 0x03; //分频器
      TCNTB0 = 31250; //定时时间
      TCON |= (1<<1);
      TCON = 0x09;

      //定时器0使能

      INTMSK &= (~(1<<10));

    }

  

  2、当定时器时间结束后发生中断

  

    void irq_timer(void)

    {
  
      if(INTOFFSET == 10)
      {
        GPFDAT &= (~(1<<4));
      }
     SRCPND = (1<<INTOFFSET);
     INTPND = INTPND;

      }

 

五、总结

  在定时器中,定时器0的时钟配置是重点。从PLL到定时器0,中间需要配置的内容不少。特别是在第一次设置重装载值得时候要手动更新。通过写博客,加深了我对s3c2440定时器的认识。我要坚持继续写下去。☀   

 

 

 

 

 

 

 

    

转载于:https://www.cnblogs.com/liuzheng1101/p/5303878.html

你可能感兴趣的文章
网站搭建(二)
查看>>
VS2010插件
查看>>
[转]win7下修改C盘USERS文件下的名称
查看>>
HowTo:freeswitch在多网卡服务器下如何配置
查看>>
C语言中隐藏结构体定义的方法
查看>>
“父窗口拖动的时候Popup不随着父窗口移动”问题的解决方案
查看>>
Android源码:(一) 安卓2.1到4.4操作系统通用的Actionbar实现的tab导航例子。
查看>>
Ubuntu 下安装 CCNx0.8.2
查看>>
UVA-227 Puzzle(模拟)
查看>>
基于ruby的watir自动化测试 笔记一
查看>>
FTP服务器FileZilla Server配置及使用方法
查看>>
python radix算法实现
查看>>
globals和locals的区别
查看>>
delphi 动态数组
查看>>
JDK动态代理和CGLIB的区别
查看>>
js 日期证有效性验的通用方法
查看>>
PHP日常排错
查看>>
2142134
查看>>
【软件需求工程与建模 - 小组项目】第6周 - 成果展示3 - 软件设计规格说明书V4.1...
查看>>
Delphi子窗体随主窗体大小而变化
查看>>