2440 时钟设置

article/2025/11/9 3:43:04

首先需要知道时钟的概念:
1、是用来同步系统信号;
就举例来说:
如果你cpu用i2c传输一个数据给从机设备,那么你传输数据时从设备怎么知道数据有没有到达,多久检测一次数据线??这个就需要时钟同步,起的作用就是我cpu传输一位数据就有一位时钟触发从设备;
2、
2440soc这么多器件时钟是如何分配??
目的
配置cpu时钟为 400M AHB 100M APB 50M

2440系统时钟分配:
晶振->锁相环(主MPLL)->分频得到 Fclk Hclk Pclk ;
在这里插入图片描述
2440时钟:
Operating Frequency
· Fclk Up to 400MHz cpu运行时钟
· Hclk Up to 136MHz 给AHB总线上挂载的设备提供时钟
· Pclk Up to 68MHz 给APH总线挂载的设备停工时钟;

时钟来源:

在这里插入图片描述
由上图可知:
时钟来源可以有两个:
1、外部引脚提供时钟信号 EXTCLK
2、晶振提供时钟信号 XTIpll
经过OM[3:2]配置数据那种时钟源如下图(使用的板子是将OM[3:2]都接地,所以是晶振(12M)提供时钟):
在这里插入图片描述
3、经过主锁相环(MPLL)->FCLK(给cpu ARM920T)->HDIVN->HCLK AHB总线
主锁相环(MPLL)->FCLK(给cpu ARM920T)->->PDIVN->PCLK APB总线
Usb锁相环(UPLL)单独给usb评率配置;

如何设置cpu等其他外围器件的时钟?
1、步骤
(1)OM硬件接地已经确定;需要配置MPLL,配置MPLL需要用到P:M:S看下什么是PMS
这个是锁相环PLL 晶振输入对应输出评率时 MPS的取值对应表;
如我们晶振12M要输出FCLK400M M:P:S=92:1:1
在这里插入图片描述
利用公式:
Mpll = (2 * m * Fin) / (p * 2S)
m = (MDIV + 8), p = (PDIV + 2), s = SDIV
得到对应的MPLL值写入MPLLCON寄存器;
在这里插入图片描述
(2)配置HDIVN PDIVN 是在CLKDIVN寄存器中
在这里插入图片描述
我们目的是配置cpu时钟为 400M , AHB=100M , APB=50M
通过配置HDIVN配置为10,确定CADMIVN==0 得到HCLK
通过配置PDIV配置为1 得到PCLK

之后就是代码了:


.text
.global _start
_start:/* 关闭看门狗 */ldr r0, =53000000ldr r1, =0str r1,[r0]/* 设置 CLKDIVN=0x4C000014  HCLK =FCLK/4  PCLK=HCLK/2* HDIVN[2:1] =10  PDIVN[0] = 1
*/ldr r0, =0x4C000014  //吧0x4C000014存入r0 ldr r1, =0x5str r1, [r0]              //r1的值0x5写入0x4C000014/* 设置锁定时间 locktime 0x4C000000  默认锁定时间 */ldr r0, =0x4C000000ldr r1, =0xFFFFFFFFstr r1, [r0]
/* 设置cpu 工作模式 */	mrc p15,0,r0,c1,c0,0orr r0,r0,#0xc0000000mcr p15,0,r0,c1,c0,0
/*设置锁相环输出频率为 400M */ldr r0, =0x4C000004ldr r1, =(92<<12)|(1<<4)|(1<<0)str r1, [r0]/* 设置内存: sp 栈 *//* 分辨是nor/nand启动* 写0到0地址, 再读出来* 如果得到0, 表示0地址上的内容被修改了, 它对应ram, 这就是nand启动* 否则就是nor启动*//*mov r1, #0ldr r0, [r1] /* 读出原来的值备份 */str r1, [r1] /* 0->[0] */ ldr r2, [r1] /* r2=[0] */cmp r1, r2   /* r1==r2? 如果相等表示是NAND启动 */*/ldr sp, =0x4096 /* 先假设是nor启动 */b mainmoveq sp, #4096  /* nand启动 */streq r0, [r1]   /* 恢复原来的值 */halt:b halt

c代码测试程序: 通过不同的频率查看led闪烁的时间间隔;


/* 配置输出方式寄存器*/
#define GPFCON   (*(volatile unsigned int *)0x56000050)  
#define GPFDAT   (*(volatile unsigned int *)0x56000054)  void delay(int cnt)
{while(cnt--);
}int main(void)
{GPFCON = 0x500;GPFDAT =0;delay(100000);GPFDAT =0xF0;delay(100000);GPFDAT =0;delay(100000);GPFDAT =0xF0;	return 0;}
all:arm-linux-gcc -c -o led_on.o led_on.carm-linux-gcc -c -o clock.o clock.Sarm-linux-ld -Ttext 0 clock.o led_on.o -o led_on.elfarm-linux-objcopy -O binary -S led_on.elf led_on.binarm-linux-objdump -D led_on.elf > led_on.dis
clean:rm *.bin *.o *.elf *.dis

http://chatgpt.dhexx.cn/article/ZDxFDjkW.shtml

相关文章

FL2440开发板简介及其烧录

目录 FL2440开发板简介 FL2440开发板 FL2440硬件资源列表 开发板存储系统&#xff1a; FL2440开发板烧录 FL2440烧录流程&#xff1a; 烧录准备工作 烧录文件: 硬件准备&#xff1a; 烧录过程 J-link操作&#xff1a; u-boot下烧录&#xff1a; 开发板启动流程&…

大数据分析平台和工具,主要有哪些?

1.Disco Disco最初由诺基亚开发&#xff0c;这是一种分布式计算框架&#xff0c;与Hadoop一样&#xff0c;它也基于MapReduce。它包括一种分布式文件系统以及支持数十亿个键和值的数据库。 支持的操作系统&#xff1a;Linux和OSX。 2.HPCC 作为Hadoop之外的一种选择&#x…

大数据分析平台的搭建方式有哪些

随着大数据时代的到来&#xff0c;数据价值的概念逐渐深入人心&#xff0c;许多企业开始搭建自己的大数据分析平台&#xff0c;以便在数据洪流中把握行业未来的发展方向。做任何事情之前&#xff0c;首先要设定目标和思路&#xff0c;然后根据确定的目标、思路和实际情况制定可…

目前大数据技术平台有很多,主要可以分为哪几类?

大数据的处理过程可以分为大数据采集、存储、结构化处理、隐私保护、挖掘、结果展示(发布)等&#xff0c;各种领域的大数据应用一般都会涉及到这些基本过程&#xff0c;但不同应用可能会有所侧重。对于互联网大数据而言&#xff0c;由于其具有独特完整的大数据特点&#xff0c;…

有哪些好的数据来源或者大数据平台?

分享下我自己平时收集的..共100多个O_O 网站分析类&#xff1a; 百度指数 - 以百度海量网民行为数据为基础的数据分享平台 Google趋势 - 了解 Google中热度上升的搜索 360指数 - 基于360搜索的大数据分享平台 Alexa - 网站排名 Google Analytics - Google出品&#xff0c;可…

大数据平台的软件有哪些?

查询引擎 一、Phoenix 简介&#xff1a;这是一个Java中间层&#xff0c;可以让开发者在Apache HBase上执行SQL查询。Phoenix完全使用Java编写&#xff0c;代码位于GitHub上&#xff0c;并且提供了一个客户端可嵌入的JDBC驱动。 Phoenix查询引擎会将SQL查询转换为一个或多个H…

[BigData]16家大数据分析平台

&#xfeff;&#xfeff; 对今天的企业来说&#xff0c;数据分析已经成为生死攸关的选择。我们分析一些著名的供应商&#xff0c;从Hadoop创业者到传统的数据库市场参与者。 革命 – 这个词汇十分准确地描述了我们所处的这个数据分析的时代。企业一方面紧紧握住大量不同类型的…

大数据网站汇总(数据搜集、大数据竞赛、)

一. 国家级大数据平台 1.1 国家大数据平台&#xff1a; 数据_中国政府网 (www.gov.cn) 1.2 司法大数据平台&#xff1a;中国司法大数据服务网 (court.gov.cn) 1.3 中国经济社会大数据研究平台&#xff1a;中国经济社会大数据研究平台 (cnki.net) 1.4 中国知网CNKI-总库&a…

linux cat命令的作用,Linux命令cat使用详解

cat命令功能&#xff1a; cat命令主要用来实现查看文件、创建文件、及合并、追加文件内容等功能。 cat命令主要参数&#xff1a; -n 或 –number&#xff1a;对输出文档的行数进行编号&#xff0c;从1开始。 -b 或 –number-nonblank&#xff1a;和 -n 功能相似&#xff0c;不同…

Windows 中使用 Linux 命令

如果要在 Windows 中运行 Linux 命令&#xff0c;那么 Cygwin 是一个推荐的工具。Cygwin 创建于 1995 年&#xff0c;旨在提供一个原生运行于 Windows 中的 POSIX 兼容环境。Cygwin 是由 Red Hat 员工和许多其他志愿者维护的自由开源软件。 二十年来&#xff0c;Windows 用户使…

设置 linux 命令别名

前言&#xff1a; 在操作 linux 的时候可能会碰到一些非常长的命令&#xff0c;这个命令平时用的比较频繁&#xff0c;每次输入执行感觉非常麻烦有木有。如果把一段长的命令设置成一个短的别名&#xff0c;是不是很方便&#xff1f; 1. alias 命令引入 找台 linux 机器执行一…

Linux命令之-telnet

使用telnet测试端口连通性 telnet命令是TELNET协议的用户接口&#xff0c;它支持两种模式&#xff1a;命令模式和会话模式&#xff0c;虽然telnet支持许多命令&#xff0c;但大部分情况下&#xff0c;我们只是使用它查看目标主机是否打开了某端口&#xff08;默认是23&#xf…

Linux 命令执行流程

今天继续给大家介绍Linux基础知识&#xff0c;本文主要内容是Linux命令执行的流程&#xff0c;不仅介绍了当我们键入一个Linux命令时系统的执行流程&#xff0c;还介绍了Linux系统中内部命令与外部命令的区别、PATH环境变量的作用等等。 Linux的命令执行流程如下&#xff1a; 1…

Linux命令之sync

概述 sync 命令可以强制将内存中的文件缓冲写入磁盘&#xff0c;更新块信息。 在 linux/unix 系统中&#xff0c;在文件或数据处理过程中一般先放到内存缓冲区中&#xff0c;等到适当的时候再写入磁盘&#xff0c;以提高系统的运行效率。这样虽然可以提高磁盘写入数据的效率&a…

Linux命令:scp

目录 简介 一、语法 二、示例 2.1 将本地文件复制到远程主机目录 2.2 将本地目录复制到远程主机目录 2.3 将远程主机的文件复制到本机 2.4 复制远程主机目录到本机 简介 今天我们来介绍一个Linux命令&#xff1a;scp scp — secure copy (remote file copy program)&am…

使用node.js构建一个web服务器(适合自学)

使用node.js构建一个web服务器 先介绍node.js的安装&#xff0c;再介绍使用node.js构建一个简单的web服务器&#xff0c;最后通过一个简单的示例&#xff0c;演示网页与服务器之间的数据交互的实现。 WEB服务器 WEB服务器也称为WWW服务器。WWW(World Wide Web、翻译成中文&a…

node-php-server 游戏服务器框架

做游戏服务器8年多了&#xff0c;用过lua, 用过C, 用过nodejs ,最近用的是php,有些人会说php不是用在web开发吗&#xff0c;怎么能用在游戏服务器的业务逻辑开发&#xff0c;php 怎么跟客户端通信&#xff0c;肯定有很多人不解。 其实很多时候&#xff0c;技术原理都是都是相通…

如何快速用node在本地搭建一个服务器

众所周知&#xff0c;服务器是通过安装特殊的软件&#xff08;或者运行特殊的代码&#xff09;来提供网络服务的机器。那么我们的电脑可不可以弄成一个服务器&#xff0c;来供他人访问呢&#xff1f; 答案是可以的&#xff0c;这里我们需要安装一下node.js这个软件。传送门&am…

通过node启动服务器必须的会的几个命令

1 首先通过cd 目录 切换到当前目录下 2 通过node app.js 启动服务器(或者nodemon apo.js) 3 通过ctrl c来关闭服务器&#xff01;

用node.js搭建自己的服务器

前提要点&#xff1a; 1、首先让我们了解一下什么是服务器和客户端吧&#xff01; 服务器是提供网络服务的机器&#xff0c;通过安装特殊的软件&#xff08;或者是运行某段特殊的代码&#xff09;来提供服务。 客户端与服务器&#xff1a;提供服务的是服务器&#xff0c;享受服…