51单片机内部资源及编程.ppt
文本预览下载声明
【例6-4】用8051单片机的串行口外接串入并出的芯片CD4094扩展并行输出口控制一组发光二极管,使发光二极管从左至右延时轮流显示。 CD4094是一块8位的串入并出的芯片,带有一个控制端STB,当STB=0时,打开串行输入控制门,在时钟信号CLK的控制下,数据从串行输入端DATA一个时钟周期一位依次输入;当STB=1,打开并行输出控制门,CD4094中的8位数据并行输出。使用时,8051串行口工作于方式0,8051的TXD接CD4094的CLK,RXD接DATA,STB用P1.0控制,8位并行输出端接8个发光二极管。如图所示。 8051 RXD TXD P1.0 DATA CLK STB 设串行口采用查询方式,显示的延时依靠调用延时子程序来实现。程序如下: 汇编程序: ORG 0000H LJMP MAIN ORG 0100H MAIN:MOV SCON,#00H MOV A,#01H CLR P1.0 START:MOV SBUF,A LOOP:JNB TI,LOOP SETB P1.0 ACALL DELAY CLR TI RL A CLR P1.0 SJMP START DELAY:MOV R7,#05H LOOP2:MOV R6,#0FFH LOOP1:DJNZ R6,LOOP1 DJNZ R7,LOOP2 RET END C语言程序: #include reg51.h //包含特殊功能寄存器库 sbit P1_0=P1^0; void main() { unsigned char i,j; SCON=0x00; j=0x01; for (; ;) { P1_0=0; SBUF=j; while (!TI) { ;} P1_0=1;TI=0; for (i=0;i=254;i++) {;} j=j*2; if (j= =0x00) j=0x01; } } 【例6-5】 用8051单片机的串行口外接并入串出的芯片CD4014扩展并行输入口,输入一组开关的信息。 CD4014是一块8位的并入串出的芯片,带有一个控制端P/S,当P/S=1时,8位并行数据置入到内部的寄存器;当P/S=0时,在时钟信号CLK的控制下,内部寄存器的内容按低位在前从QB串行输出端依次输出;使用时,8051串行口工作于方式0,8051的TXD接CD4094的CLK,RXD接QB,P/S用P1.0控制,另外,用P1.1控制8并行数据的置入。如图所示。 8051 RXD TXD P1.0 QB CLK P/S P1.1 K0 K7 K 串行口方式0数据的接收,用SCON寄存器中的REN位来控制,采用查询RI的方式来判断数据是否输入。程序如下: 汇编程序: ORG 0000H LJMP MAIN ORG 0100H MAIN:SETB P1.1 START:JB P1.1,START SETB P1.0 CLR P1.0 MOV SCON,#10H LOOP:JNB RI,LOOP CLR RI MOV A,SBUF …… C语言程序: #include reg51.h //包含特殊功能寄存器库 sbit P1_0=P1^0; sbit P1_1=P1^1; void main() { unsigned char i; P1_1=1; while (P1_1= =1) {;} P1_0=1; P1_0=0; SCON=0x10; while (!RI) {;} RI=0; i=SBUF; …… } 2.利用方式1实现点对点的双机通信 要实现甲与乙两台单片机点对点的双机通信,线路只须将甲机的TXD与乙机的RXD相连,将甲机的RXD与乙机的TXD相连,地线与地线相连。 【例6-6】 用汇编语言编程通过串行实现将甲机的片内RAM中30H~3FH单元的内容传送到乙机的片内RAM的40H~4FH单元中。 8051 8051 甲机 RXD TXD GND TXD RXD GND 乙机 线路连接如图 甲、乙两机都选择方式1:8位异步通信方式,最高位用作奇偶校验,波特率为1200bps,甲机发送,乙机接收,因此甲机的串口控制字为40H,乙机的串口控制字为50H。 由于选择的是方式1,波特率由定时/计数器T1的溢出率和电源控制寄存器PCON中的SMOD位决定。则须对定时/计数器T1初始化。 设SMOD=0,甲、乙两机的振荡频率为12MHZ,由于波特率为1200。定时/计数器T1选择为方式2,则初值为: 初值=256 - fosc×2SMOD /(12×波特率×32) =
显示全部