汇编语言

合集下载

汇编语言的名词解释

汇编语言的名词解释

汇编语言的名词解释1. 什么是汇编语言?汇编语言(Assembly Language)是一种低级计算机语言,用于直接控制计算机硬件操作的编程语言。

它是由一系列符号化的指令组成,每条指令对应着一条特定的机器码(二进制代码)。

汇编语言与计算机体系结构紧密相关,不同的计算机体系结构使用不同的汇编语言。

与高级语言相比,汇编语言更接近底层硬件,并且更加直观。

通过使用特定的助记符和操作码,程序员可以直接操作寄存器、内存和其他硬件资源。

尽管汇编语言通常比高级语言更难以理解和编写,但它可以提供更高的性能和对底层硬件的更好控制。

2. 汇编指令集2.1 指令在汇编语言中,指令是最基本的操作单位。

每条指令执行一个特定的操作,并且可能包含一个或多个操作数。

2.2 寄存器寄存器是位于CPU内部的小型存储单元,用于临时存储数据和执行算术逻辑运算。

不同架构的计算机具有不同数量和类型的寄存器。

例如,x86架构的计算机有通用寄存器、段寄存器、标志寄存器等。

2.3 内存内存是计算机中用于存储程序和数据的地方。

在汇编语言中,内存可以通过地址来访问。

地址可以是直接指定的常数,也可以是通过寄存器间接指定的。

2.4 操作数操作数是指令所操作的数据。

它可以是立即数(常数)、寄存器、内存位置或者两个操作数之间的运算结果。

2.5 标志位标志位是一组二进制标志,用于表示某些特殊状态或条件。

例如,零标志位(ZF)用于表示上一条指令执行结果是否为零。

3. 汇编语言与机器码汇编语言与机器码之间存在一对一的映射关系。

每条汇编指令都对应着一个特定的机器码,它由一串二进制数字表示,并被计算机硬件直接执行。

汇编语言使用助记符(Mnemonic)来代替复杂而难以记忆的二进制代码。

例如,MOV指令用于将数据从一个位置复制到另一个位置,在x86架构中对应着机器码89。

编写汇编语言程序时,程序员需要将高级语言代码转换为汇编指令。

这可以通过手动编写汇编指令来完成,也可以通过汇编器(Assembler)自动将高级语言代码转换为汇编指令。

汇编语言是一种什么程序设计语言

汇编语言是一种什么程序设计语言

汇编语言是一种什么程序设计语言汇编语言,也称为汇编程序设计语言,是一种低级的程序设计语言,用于编写计算机程序。

它与机器语言一一对应,使用助记符(mnemonics)表示计算机的指令和操作码(opcode),并且能够直接控制计算机硬件。

汇编语言是一种面向机器的语言,与高级语言相比,更加接近计算机底层的指令集和硬件结构。

使用汇编语言编程可以对计算机进行细粒度的控制,使程序在执行效率和内存管理方面具有更高的优势。

与高级语言相比,汇编语言具有以下特点:1. 直接操作硬件:汇编语言充分利用了计算机的底层硬件资源,可以直接访问寄存器、内存地址和输入输出设备等,对硬件资源有较好的掌控能力。

2. 高效性:由于汇编语言可以直接操作硬件,在性能要求较高的场景下,能够比高级语言更加高效地利用计算机的资源。

3. 灵活性:汇编语言具有更高的灵活性,可以编写特定的指令序列来实现特定的功能,适用于一些对实时性要求较高、底层接口较复杂的应用场景。

然而,汇编语言也存在一些局限性和不足之处:1. 可读性差:汇编语言以助记符和操作码为基础,相较于高级语言,可读性较差,需要开发者具备深入的底层计算机知识。

2. 开发效率低:由于汇编语言编写的代码需要详细地指明操作码和寄存器等硬件细节,编写复杂程序会消耗更多的时间和精力。

3. 可移植性差:汇编语言对于不同的计算机和处理器架构存在差异,不同的平台需要编写不同的汇编语言代码,因此可移植性较差。

总结而言,汇编语言是一种底层的程序设计语言,具有直接操作硬件、高效性和灵活性等特点。

但由于可读性差、开发效率低和可移植性差等限制,现在在软件开发领域中使用较为有限,更多地被用于编写底层驱动程序、操作系统和嵌入式系统等领域。

汇编语言缩写与英文

汇编语言缩写与英文

汇编语言缩写与英文汇编语言(Assembly Language)是一种低级编程语言,由机器语言指令和符号助记符组成,用于与计算机硬件直接交互。

在汇编语言中,缩写常常被使用,以减少代码的长度和提高代码的可读性。

本文将介绍一些常见的汇编语言缩写及其对应的英文。

一、数据传输指令1. MOV - MoveMOV指令用于将数据从一个位置移动到另一个位置。

例如,将数据从内存移动到寄存器,或者从寄存器移动到内存时,可以使用MOV指令。

2. LDR - LoadLDR指令用于从内存中加载数据。

通常,LDR指令用于将数据加载到寄存器中。

3. STR - StoreSTR指令用于将数据存储到内存中。

通常,STR指令用于将寄存器中的数据存储到内存地址中。

二、算术运算指令1. ADD - AddADD指令用于将两个操作数相加,并将结果保存到目标操作数中。

2. SUB - SubtractSUB指令用于将两个操作数相减,并将结果保存到目标操作数中。

3. MUL - MultiplyMUL指令用于将两个操作数相乘,并将结果保存到目标操作数中。

4. DIV - DivideDIV指令用于将两个操作数相除,并将结果保存到目标操作数中。

三、逻辑运算指令1. AND - Bitwise ANDAND指令用于对两个操作数执行按位与操作,并将结果保存到目标操作数中。

2. OR - Bitwise OROR指令用于对两个操作数执行按位或操作,并将结果保存到目标操作数中。

3. XOR - Bitwise XORXOR指令用于对两个操作数执行按位异或操作,并将结果保存到目标操作数中。

四、跳转指令1. JMP - JumpJMP指令用于无条件跳转到指定的地址。

2. JZ - Jump if ZeroJZ指令用于在操作数为零时跳转到指定的地址。

3. JNZ - Jump if Not ZeroJNZ指令用于在操作数不为零时跳转到指定的地址。

五、堆栈指令1. PUSH - PushPUSH指令用于将数据压栈。

汇编语言

汇编语言

汇编语言汇编语言实质上是机器语言的符号表示,即用助记符(指令功能的英文缩写)代替了机器语言指令的二进制代码。

用汇编语言按着规定的语法规则编写的程序称为汇编语言源程序(*.asm)。

汇编语言源程序中的汇编指令与指令的机器码(目标代码)是一一对应的。

汇编语言2高级语言是面向过程的语言,它不依赖于特定的机器,独立于机器,高级语言编写的程序由一系列编程语句和相应的语法规则构成,编程方法更适合于人们的思维习惯,易于理解和阅读,程序本身具有可移植性,通用性强高级语言的缺点是编译程序和解释程序复杂,占用内存空间大,与汇编语言程序相比,经编译后产生的目标程序长,执行速度慢高级语言3汇编语言上机处理过程4汇编语言汇编语言的程序格式伪指令程序设计基本方法5汇编语言的程序格式汇编语言程序的结构汇编语言语句类型及格式汇编语言的数据与表达式6源程序的一般格式STACK SEGMENT┇STACK ENDSDATA SEGMENT┇DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATA,SS:STACKSTART:…┇CODE ENDSEND START7例题一个两字相加的程序。

DATA SEGMENT ;定义数据段DATA1 DW 1234H ;定义被加数DATA2 DW 5678H ;定义加数DATA ENDS ;数据段结束ESEG SEGMENT ;定义附加段SUM DW 2 DUP(?);定义存放结果区ESEG ENDS ;附加段结束CODE SEGMENT ;定义代码段;下面的语句说明程序中定义的各段分别用哪个段寄存器寻址ASSUME CS:CODE, DS:DATA,ES:ESEGSTART:MOV AX,DSEG ;START为程序开始执行的启动标号MOV DS,AX ;初始化DSMOV AX,ESEGMOV ES,AX ;初始化ESLEA SI,SUM ;存放结果的偏移地址送SIMOV AX,DATA1 ;取被加数ADD AX,DATA2 ;两数相加MOV ES:[SI],AX ;和送附加段的SUM单元中HLTCODE ENDS ;代码段结束END START ;源程序结束8源程序的结构特点汇编语言程序通常由若干段组成,段由伪指令SEGMENT与ENDS定义,各段顺序任意,段的数目按需要确定,原则上不受限制。

汇编语言例子

汇编语言例子

汇编语言例子汇编语言什么是汇编语言汇编语言(Assembly Language)是一种低级机器语言的抽象表示,它使用特定的助记符来代表机器指令,而不是直接书写二进制代码。

通过汇编语言,程序员可以更容易地理解、编写和调试与硬件相关的程序。

汇编语言的基本特点•与机器语言一一对应:汇编语言的指令和机器指令之间存在一一对应的关系,每个汇编指令对应一个特定的机器指令。

•与硬件密切相关:汇编语言直接操作底层硬件,程序员需要了解计算机的底层架构和寄存器的使用。

•可读性较高:相比于机器码,汇编语言使用助记符和符号,更易于阅读和理解。

汇编语言的应用领域•嵌入式系统开发:由于汇编语言可以直接操作底层硬件,因此在嵌入式系统开发中经常使用汇编语言编写关键部分的代码。

•驱动程序开发:由于驱动程序需要和硬件进行直接的交互,所以在某些特定的情况下,使用汇编语言可以提高驱动程序的性能。

•反汇编和逆向工程:通过反汇编工具,可以将目标文件或可执行文件转换为汇编语言代码,这对于进行逆向工程和软件破解非常有用。

汇编语言的常见指令和示例•mov指令:用于将数据从一个地方移动到另一个地方,常用于寄存器之间或内存和寄存器之间的数据传输。

例如:mov eax, ebx表示将ebx的值移动到eax寄存器中。

•add指令:用于执行加法操作,常用于寄存器之间或内存和寄存器之间的数据相加。

例如:add eax, ebx 表示将eax寄存器中的值与ebx寄存器中的值相加,并将结果存储回eax寄存器。

•jmp指令:用于无条件跳转到指定的地址,用于实现程序的控制流程。

例如:jmp 0x100 表示无条件跳转到地址0x100处执行。

•cmp指令:用于比较两个操作数的大小关系,并根据比较结果设置标志位(如ZF、SF等)来影响后续的条件跳转指令。

例如:cmp eax, ebx 表示比较eax和ebx的值。

•inc和dec指令:分别用于将操作数的值增加1或减去1。

20个简单汇编语言程序

20个简单汇编语言程序

20个简单汇编语言程序汇编语言是一种底层编程语言,其语法简洁、速度快,被广泛应用于嵌入式系统和设备驱动程序的开发。

本文将介绍20个简单的汇编语言程序,帮助读者了解该语言的基本语法和用法,以便更好地进行编程。

1. 程序1:将两个数相加并显示结果。

这个程序演示了如何使用汇编语言进行简单的算术操作。

2. 程序2:计算并显示斐波那契数列。

这个程序展示了如何使用循环和条件语句来求解数学问题。

3. 程序3:判断一个数是否是素数。

这个程序演示了如何使用分支语句来进行逻辑判断。

4. 程序4:将一个字符串逆序输出。

这个程序展示了如何使用栈来实现字符串逆序。

5. 程序5:计算一个字符串的长度。

这个程序展示了如何使用循环和计数器来确定字符串的长度。

6. 程序6:将一个字符串转换为大写。

这个程序演示了如何使用位运算来进行字符转换。

7. 程序7:计算一个数的阶乘。

这个程序展示了如何使用循环和累加运算来求解阶乘。

8. 程序8:判断一个字符串是否是回文。

这个程序演示了如何使用循环和栈来进行字符串回文判断。

9. 程序9:实现快速排序算法。

这个程序展示了如何使用递归和分区操作来进行快速排序。

10. 程序10:实现冒泡排序算法。

这个程序演示了如何使用循环和比较操作来进行冒泡排序。

11. 程序11:计算一个数组的平均值。

这个程序展示了如何使用循环和累加运算来求解平均值。

12. 程序12:查找一个数组中的最大值。

这个程序演示了如何使用循环和比较操作来进行最大值查找。

13. 程序13:判断一个数是否是回文。

这个程序展示了如何使用循环和取余操作来进行数字回文判断。

14. 程序14:实现字符串拼接操作。

这个程序演示了如何使用循环和指针操作来进行字符串拼接。

15. 程序15:实现矩阵乘法运算。

这个程序展示了如何使用循环和累加运算来进行矩阵乘法。

16. 程序16:计算一个数的平方根。

这个程序演示了如何使用二分法和近似计算来求解平方根。

17. 程序17:实现字符串匹配操作。

汇编语言的类型

汇编语言的类型汇编语言是一种低级语言,它是由机器指令和汇编指令组成的。

汇编语言是一种直接操作计算机硬件的语言,它可以直接控制计算机的各种硬件资源,如CPU、内存、I/O等。

汇编语言的类型主要有以下几种:1. x86汇编语言x86汇编语言是一种基于Intel x86架构的汇编语言,它是目前最为流行的汇编语言之一。

x86汇编语言可以直接操作CPU的寄存器、内存和I/O端口等硬件资源,它可以实现高效的程序设计和优化。

x86汇编语言的语法比较复杂,需要掌握大量的指令和寄存器,但是它可以实现非常高效的程序设计和优化。

2. ARM汇编语言ARM汇编语言是一种基于ARM架构的汇编语言,它是嵌入式系统和移动设备上最为流行的汇编语言之一。

ARM汇编语言可以直接操作CPU的寄存器、内存和I/O端口等硬件资源,它可以实现高效的程序设计和优化。

ARM汇编语言的语法比较简单,但是需要掌握大量的指令和寄存器。

3. MIPS汇编语言MIPS汇编语言是一种基于MIPS架构的汇编语言,它是嵌入式系统和网络设备上常用的汇编语言之一。

MIPS汇编语言可以直接操作CPU的寄存器、内存和I/O端口等硬件资源,它可以实现高效的程序设计和优化。

MIPS汇编语言的语法比较简单,但是需要掌握大量的指令和寄存器。

4. AVR汇编语言AVR汇编语言是一种基于AVR架构的汇编语言,它是嵌入式系统和单片机上常用的汇编语言之一。

AVR汇编语言可以直接操作CPU 的寄存器、内存和I/O端口等硬件资源,它可以实现高效的程序设计和优化。

AVR汇编语言的语法比较简单,但是需要掌握大量的指令和寄存器。

5. PowerPC汇编语言PowerPC汇编语言是一种基于PowerPC架构的汇编语言,它是IBM和苹果电脑上常用的汇编语言之一。

PowerPC汇编语言可以直接操作CPU的寄存器、内存和I/O端口等硬件资源,它可以实现高效的程序设计和优化。

PowerPC汇编语言的语法比较复杂,需要掌握大量的指令和寄存器,但是它可以实现非常高效的程序设计和优化。

汇编语言的类型

汇编语言的类型汇编语言是一种底层的编程语言,它与计算机硬件密切相关,常用于控制硬件的操作。

汇编语言的类型也有多种,下面将分别介绍。

1. x86汇编语言x86汇编语言是一种广泛使用的汇编语言,主要用于Intel和AMD 处理器。

它是一种基于寄存器的汇编语言,通过寄存器来访问内存和其他设备。

x86汇编语言非常灵活,可以用来编写各种类型的应用程序,包括操作系统、驱动程序、安全软件等。

2. ARM汇编语言ARM汇编语言是一种使用ARM处理器的汇编语言。

ARM处理器是一种低功耗的处理器,广泛应用于移动设备和嵌入式系统。

ARM 汇编语言是基于寄存器的汇编语言,也可以通过其他方式来访问内存和其他设备。

ARM汇编语言通常用于编写嵌入式系统的驱动程序和操作系统。

3. MIPS汇编语言MIPS汇编语言是一种使用MIPS处理器的汇编语言。

MIPS处理器是一种高性能的处理器,常用于路由器、交换机和数字信号处理器等。

MIPS汇编语言是基于寄存器的汇编语言,也可以通过其他方式来访问内存和其他设备。

MIPS汇编语言通常用于编写嵌入式系统的驱动程序和操作系统。

4. AVR汇编语言AVR汇编语言是一种使用AVR微控制器的汇编语言。

AVR微控制器是一种低功耗的微控制器,广泛应用于嵌入式系统、电子设备和工业控制等领域。

AVR汇编语言主要基于寄存器,也可以通过其他方式来访问内存和其他设备。

AVR汇编语言通常用于编写嵌入式系统的驱动程序和操作系统。

5. SPARC汇编语言SPARC汇编语言是一种使用SPARC处理器的汇编语言。

SPARC处理器是一种高性能的处理器,常用于服务器和超级计算机等。

SPARC汇编语言主要基于寄存器,也可以通过其他方式来访问内存和其他设备。

SPARC汇编语言通常用于编写操作系统和高性能计算程序等。

总结汇编语言的类型有很多种,不同的汇编语言适用于不同的处理器和应用场景。

汇编语言虽然比高级语言难以学习和使用,但它可以直接控制硬件,因此在某些特定的应用领域中有着不可替代的作用。

汇编语言


1.1.2 汇编语言
汇编指令-用能反映机器指令功能的单 词或词组来代替机器指令的操作码,用 相应的符号表示CPU内部资源和内存的 操作数 例:汇编指令: movl %esp,%ebp 二进制机器指令为: 1000100111100101 十六进制机器指令为: 89 E5
1.1.2 汇编语言
汇编语言是汇编指令集、伪指令集及其 使用规则的统称。 用汇编语言编写的程序称作汇编语言程 序,或汇编语言源程序 汇编语言源程序必须经过翻译才能变成 可执行的机器语言程序,这个翻译过程 称作汇编。
1.2.3 学习Linux环境的汇编语言 学习Linux环境的汇编语言
Linux是GNU的一员,遵循公共版权许 可证(GPL) ,是一款免费的操作系统 Linux是计算机爱好者自己的操作系统 自由的思想,开放的源码 GNU项目为Linux系统提供了丰富的程 序开发环境。我们可以使用的有GNU 汇编器gas,连接器ld、调试器gdb以及 C语言编译器gcc等
1.1.4 汇编语言的主要特性
与机器的相关性 执行的高效性 编写源程序的繁琐性 调试的复杂性 硬件控制的直接性
1.2.1 汇编语言的主要应用
程序要求具有较快的执行时间,或者只 能占用较小的存储容量 程序与计算机硬件密切相关,程序要直 接有效地控制硬件 大型软件需要提高性能、优化处理的部 分 没有合适的高级语言的时候 系统的底层软件、加密解密软件、分析 和防治计算机病毒等
1.1.3 高级语言与汇编语言
高级程序设计语言(high-level language, HLL)使用接近于人类自然语言的语法 习惯及数学表达形式 可读性、可移植性好,编写和调试程序 相对容易,编程效率高 产生的目标程序的效率不高,很难对硬 件直接加以控制

汇编语言的名词解释

汇编语言的名词解释汇编语言是一种低级编程语言,用于编写计算机程序。

它是一种符号化的机器语言表示形式,通过汇编程序翻译成机器指令,以便能够被计算机执行。

在汇编语言中,使用各种名词来描述不同的概念和操作。

1. 汇编语言 (Assembly language)汇编语言是一种使用助记符(Mnemonics)和符号(Symbol)来代替二进制代码的编程语言。

它直接对应于计算机的指令集体系结构,可以通过助记符和符号来描述计算机的操作、寄存器、内存地址等信息。

2. 指令 (Instruction)指令是汇编语言中最基本的单位,用于指示计算机执行某种操作。

指令通常以助记符的形式表示,例如MOV、ADD、JMP等。

一个指令包含操作码(Opcode)和操作数(Operand),操作码表示需要执行的操作,操作数则提供了操作所需的数据或地址。

3. 寄存器 (Register)寄存器是用于存储和操作数据的高速内存单元。

汇编语言使用寄存器来进行计算、传输数据和控制程序流程等操作。

通常,寄存器具有特定的名称和功能,例如AX、BX、CX等通用寄存器,以及SP、BP、SI、DI等特殊用途寄存器。

4. 内存地址 (Memory Address)内存地址指示了计算机内存中存储数据的位置。

在汇编语言中,使用内存地址来读取和存储数据。

内存地址可以通过直接给出地址值或使用标号(Label)来表示。

5. 标志位 (Flag)标志位是用于记录计算机运算过程中的条件结果的特殊寄存器。

在汇编语言中,标志位可用于控制程序的跳转、判断条件和处理中断等操作。

6. 宏指令 (Macro)宏指令是一种能够扩展和简化程序的代码片段。

它可以在汇编语言中定义和调用,类似于高级编程语言中的函数或宏定义。

宏指令能够减少代码重复和提高程序的可维护性。

7. 伪指令 (Pseudo-Instruction)伪指令是汇编语言中的一种特殊指令,用于给汇编程序提供附加的信息和指导。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Code Warrior 5.0Target : MC9S12XS128Crystal: 16.000Mhz============================================本程序主要包括以下功能:1.设定系统工作在xxMHZ bus clock时钟下;2.测试龙丘最小系统开发板超频性能:如果LED闪烁,说明芯片正常工作;否则,说明芯片没有正常工作,请检查系统设计;3.也可以测试清华大学最小系统板的超频性能,LED计数,根据灯亮可以读取系统循环了多少次************************************************************************************ *****/#include <hidef.h> /* common defines and macros */#include <MC9S12XS128.h> /* derivative information */#pragma LINK_INFO DERIVATIVE "mc9s12xs128"void delayms(int ms){int ii,jj;if (ms<1) ms=1;for(ii=0;ii<ms;ii++)for(jj=0;jj<3338;jj++); //40MHz--1ms}void SetBusCLK_16M(void){CLKSEL=0X00; // disengage PLL to systemPLLCTL_PLLON=1; // turn on PLLSYNR=0x00 | 0x01; // VCOFRQ[7:6];SYNDIV[5:0]// fVCO= 2*fOSC*(SYNDIV + 1)/(REFDIV + 1)// fPLL= fVCO/(2 × POSTDIV)// fBUS= fPLL/2// VCOCLK Frequency Ranges VCOFRQ[7:6]// 32MHz <= fVCO <= 48MHz 00// 48MHz < fVCO <= 80MHz 01// Reserved 10// 80MHz < fVCO <= 120MHz 11REFDV=0x80 | 0x01; // REFFRQ[7:6];REFDIV[5:0]// fREF=fOSC/(REFDIV + 1)// REFCLK Frequency Ranges REFFRQ[7:6]// 1MHz <= fREF <= 2MHz 00// 2MHz < fREF <= 6MHz 01// 6MHz < fREF <= 12MHz 10// fREF > 12MHz 11// pllclock=2*osc*(1+SYNR)/(1+REFDV)=32MHz;POSTDIV=0x00; // 4:0, fPLL= fVCO/(2xPOSTDIV)// If POSTDIV = $00 then fPLL is identical to fVCO (divide by one)._asm(nop); // BUS CLOCK=16M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_32M(void){CLKSEL=0X00; // disengage PLL to systemPLLCTL_PLLON=1; // turn on PLLSYNR =0x40 | 0x03; // pllclock=2*osc*(1+SYNR)/(1+REFDV)=64MHz;REFDV=0x80 | 0x01;POSTDIV=0x00;_asm(nop); // BUS CLOCK=32M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_40M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x04;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=80MHz;_asm(nop); //BUS CLOCK=40M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_48M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x05;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=96MHz;_asm(nop); //BUS CLOCK=48M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_64M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x07;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=128MHz;_asm(nop); //BUS CLOCK=64M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_80M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x09;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=160MHz;_asm(nop); //BUS CLOCK=80M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_88M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0a;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=176MHz;_asm(nop); //BUS CLOCK=88M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_96M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0b;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=192MHz;_asm(nop); //BUS CLOCK=96M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_104M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0c;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=208MHz;_asm(nop); //BUS CLOCK=104M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_120M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0d;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=240MHz;_asm(nop); //BUS CLOCK=120M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void main(void) {/* put your own code here */unsigned char LedCnt=0;SetBusCLK_96M(); // 此处选择待设定的总线频率DDRB=0xff;DDRA=0x01;PORTA=0XFE;PORTB=0XFE;EnableInterrupts;for(;;) {LedCnt=(LedCnt>0XFE?0:++LedCnt);delayms(500); // 修改延时以修改数据发送频率//低电平灯亮用这句,注释掉下面那句PORTB=~LedCnt; // 测试清华版系统板PORTA_PA0=~PORTA_PA0; // 测试龙丘最小系统板//PORTB_BIT7=~PORTB_BIT7;//高电平灯亮用这句,注释掉上面那句//PORTB=LedCnt;} /* wait forever *//* please make sure that you never leave this function */ }。

相关文档
最新文档