51单片机CPU的内部结构及工作原理

发布者:Serene123最新更新时间:2015-03-26 来源: diangon关键字:51单片机  CPU  内部结构 手机看文章 扫描二维码
随时随地手机看文章

从上图中我们可以看到,在虚线框内的就是CPU的内部结构了,8位的MCS-51单片机的CPU内部有数术逻辑单元ALU(Arithmetic Logic Unit)、累加器A(8位)、寄存器B(8位)、程序状态字PSW(8位)、程序计数器PC(有时也称为指令指针,即IP,16位)、地址寄存器AR(16位)、数据寄存器DR(8位)、指令寄存器IR(8位)、指令译码器ID、控制器等部件组成。

1、运算器(ALU)的主要功能
A)算术和逻辑运算,可对半字节(一个字节是8位,半个字节就是4位)和单字节数据进行操作。
B)加、减、乘、除、加1、减1、比较等算术运算。
C)与、或、异或、求补、循环等逻辑运算。
D)位处理功能(即布尔处理器)。
由于ALU内部没有寄存器,参加运算的操作数,必须放在累加器A中。累加器A也用于存放运算结果。
例如:执行指令 ADD  A,B  
执行这条指令时,累加器A中的内容通过输入口In_1输入ALU,寄存器B通过内部数据总线经输入口In_2输入ALU,A+B的结果通过ALU的输出口Out、内部数据总线,送回到累加器A。

2、程序计数器PC
PC的作用是用来存放将要执行的指令地址,共16位,可对64K ROM直接寻址,PC低8位经P0口输出,高8位经P2口输出。也就是说,程序执行到什么地方,程序计数器PC就指到哪里,它始终是跟蹿着程序的执行。我们知道,用户程序是存放在内部的ROM中的,我们要执行程序就要从ROM中一个个字节的读出来,然后到CPU中去执行,那么ROM具体执行到哪一条呢?这就需要我们的程序计数器PC来指示。
程序计数器PC具有自动加1的功能,即从存储器中读出一个字节的指令码后,PC自动加1(指向下一个存储单元)。
3、指令寄存器IR
指令寄存器的作用就是用来存放即将执行的指令代码。
在这里我们先简单的了解下CPU执行指令的过程,首先由程序存储器(ROM)中读取指令代码送入到指令寄存器,经译码器译码后再由定时与控制电路发出相应的控制信号,从而完成指令的功能。关于指令在单片机内部的执行过程,我们在后面将会以另一节课来进行详细的讲解。
4、指令译码器ID
用于对送入指令寄存器中的指令进行译码,所谓译码就是把指令转变成执行此指令所需要的电信号。当指令送入译码器后,由译码器对该指令进行译码,根据译码器输出的信号,CPU控制电路定时地产生执行该指令所需的各种控制信号,使单片机正确的执行程序所需要的各种操作。
5、地址寄存器AR(16位)
AR的作用是用来存放将要寻址的外部存储器单元的地址信息,指令码所在存储单元的地址编码,由程序计数器PC产生,而指令中操作数所在的存储单元地址码,由指令的操作数给定。从上图中我们可以看到,地址寄存器AR通过地址总线AB与外部存储器相连。
6、数据寄存器DR
用于存放写入外部存储器或I/O端口的数据信息。可见,数据寄存器对输出数据具有锁存功能。数据寄存器与外部数据总线DB直接相连。
7、程序状态字PSW
用于记录运算过程中的状态,如是否溢出、进位等。
例如,累加器A的内容83H,执行:
ADD A,#8AH   ;累加器A与立即数8AH相加,并把结果存放在A中。
指令后,将产生和的结果为[1]0DH,而累加器A只有8位,只能存放低8位,即0DH,元法存放结果中的最高位B8。为些,在CPU内设置一个进位标志位C,当执行加法运算出现进位时,进位标志位C为1。
8、时序部件
由时钟电路和脉冲分配器组成,用于产生微操作控制部件所需的定时脉冲信号。

关键字:51单片机  CPU  内部结构 引用地址:51单片机CPU的内部结构及工作原理

上一篇:51单片机程序进行软件加密和硬件解密的方法
下一篇:单片机汇编语言和最常用的高级语言分析

推荐阅读最新更新时间:2024-03-16 13:56

AVR笔记2:定义F_CPU
1.warning: #warning F_CPU not defined for util/delay.h 2.warning: F_CPU redefined 3.c:/winavr-20100110/lib/gcc/../../avr/include/util/delay.h:86:1: warning: this is the location of the previous definition 出现以上三种错误的解决办法是将#define F_CPU 1000000 放在在#include util/delay.h 语句之前,如下: #define F_CPU 1000000 #include avr/i
[单片机]
AT89S51单片机对数字电压表的设计
利用单片机AT89S51与ADC0809设计一个数字电压表,能够测量0-5V之间的直流电压值,四位数码显示,但要求使用的元器件数目最少。 1. 电路原理图 图1.28.1 2. 系统板上硬件连线 a) 把“单片机系统”区域中的P1.0-P1.7与“动态数码显示”区域中的ABCDEFGH端口用8芯排线连接。 b) 把“单片机系统”区域中的P2.0-P2.7与“动态数码显示”区域中的S1S2S3S4S5S6S7S8端口用8芯排线连接。 c) 把“单片机系统”区域中的P3.0与“模数转换模块”区域中的ST端子用导线相连接。 d) 把“单片机系统”区域中的P3.1与“模数转换模块”区域中的OE端子用导线相连接。 e) 把“单片机系
[单片机]
AT89S<font color='red'>51单片机</font>对数字电压表的设计
51单片机汉字液晶子程序 液晶屏分为4行*12列汉字
/*写汉字液晶子程 液晶屏分为4行*12列汉字,全部使用模拟接口方式。 /* TGLCMLIMIT64A接口程序(模拟方式) ;*************************************************************************** ;连线图: ;*LCM---89C52* *LCM---89C52* *LCM-------89C52* *LCM----------89C52* * ;*DB0---P0.0* *DB4---P0.4* *D/I-------P2.6* *CS1----------P2.4* * ;*DB1---P0.1* *DB5---P0.5*
[单片机]
基于51单片机的气泵控制程序
用stc89c52单片机来控制气泵,带有2种工作模式,端口可自行修改 #include reg52.h sbit a=P1^5;//闪烁灯 sbit b=P1^4;//气泵 sbit c=P3^7;//状态指示灯 sbit ss1=P3^2;//一分钟工作模式 sbit ss4=P3^3;//四分钟工作模式 unsigned int q,w,e,r,y,u,i,n,m,l,h; csh();//初始化子程序声明 ys();//延时子程序 ys2();//延时子程序2声明 void main() { csh();//初始化 while(1) //死循环 一号 { if(ss1==0){n=1;} //判定一分钟工作模式接通启动二号
[单片机]
电子时钟(51单片机定时器,1602液晶)
电路图: 代码: #include reg52.h #include stdlib.h #include stdio.h #include intrins.h #define uint unsigned int #define uchar unsigned char uint num,A_num,x=0; uint h,m,s,year=2012,month=1,day=22,lcd_x=0,lcd_y=0; uchar code Zifu = 0123456789 ; sbit beep = P2^3; sbit LCD_EN = P3^4; sbit LCD_RS = P3
[单片机]
电子时钟(<font color='red'>51单片机</font>定时器,1602液晶)
AT89C51单片机驱动液晶显示汉字C语言
此程序的完整工程文件下载:http://www.51hei.com/f/8952lkj_c.rar 上图是 原理图 及其仿真效果. /******************************************************************* AT89C51 单片机 驱动 液晶显示 汉字C语言 ****************************************************************/ #include AT89x51.h #define uchar unsigned char /************************************
[单片机]
AT89C<font color='red'>51单片机</font>驱动液晶显示汉字C语言
51单片机+编码器+42步进电机的源程序
前几天帮别做一个51的小东西需要编码器,结果发现网上编码器的程序比较不好找,自己根据别人一个巧妙的思路写了一个读编码器读数的程序,用LCD1602显示出来。里边还有使用L298N驱动42步进电机部分,可以参考一下。 单片机源程序如下: #include reg52.h typedef unsigned char uchar; typedef unsigned int uint; //LCD1602定义 #define LCD1602_DB P0 //LCD1602数据总线 sbit LCD1602_RS = P2^7; //RS端 sbit LCD1602_RW = P2^6; //RW端 sb
[单片机]
采用二维模糊控制器和C8051单片机实现室内自然采光系统的设计
1、 引言 从远古的篝火、油灯到蜡烛、白炽灯,再到今天千家万户的荧光灯,人类已经基本适应了人工光源的室内照明环境。但是由于千万年来的环境影响,自然光仍然是人类最习惯、感觉最舒适的光源,自然采光一直受到建筑师和照明设计师的高度重视。当今社会建筑的节能环保需求更对自然采光照明提出了进一步的要求。《建筑采光设计标准》 中的国家技术经济政策指出: 建筑设计要充分利用天然光,创造良好的光环境。 对室内照明自然采光的研究具有重要的意义: (1) 资料表明,照明用电占整个商业建筑能耗的25 - 40% ,而自然采光在特定的情况下可以节省52% 的照明用电,大大节约了能源。 (2) 相关研究表明,人在自然光条件下工作,可以增加满意度和提高工作
[单片机]
采用二维模糊控制器和C80<font color='red'>51单片机</font>实现室内自然采光系统的设计
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved