機(jī)電之家資源網(wǎng)
單片機(jī)首頁(yè)|單片機(jī)基礎(chǔ)|單片機(jī)應(yīng)用|單片機(jī)開(kāi)發(fā)|單片機(jī)文案|軟件資料下載|音響制作|電路圖下載 |嵌入式開(kāi)發(fā)
培訓(xùn)信息
贊助商
51單片機(jī)串口通信軟件程序集
51單片機(jī)串口通信軟件程序集
 更新時(shí)間:2009-9-11 16:46:01  點(diǎn)擊數(shù):0
【字體: 字體顏色

串口通信的單片機(jī)程序


beep    bit   p3.7                ;蜂鳴器定義

        org 00h
      jmp main
        org 23h                       ;串行中斷入口地址
      jmp com_int                     ;串行中斷服務(wù)程序

;***********  主程序開(kāi)始    *******************
        org 30h
  main:  mov sp,#30h                ;設(shè)置堆棧
             lcall rest             ;初始化
             lcall comm             ;串口初始化
             jmp $                  ;原地等待

;  *************   初始化   *********************
   rest:      mov p0,#00h             ;禁止數(shù)碼管顯示
             mov p2,#255
             clr  beep                ;禁止蜂鳴器
             mov p1,#255              ;禁止LED顯示
             RET                      ;返回

; **************  串口初始化   *****************
;設(shè)置串行口工作方式1,定時(shí)器1作為波特率發(fā)生器
;波特率設(shè)置為   2400  ;

comm:         mov tmod,#20h          ;設(shè)置定時(shí)器T1工作方式2
              mov tl1,#0f3h             ;定時(shí)器計(jì)數(shù)初值,波特率 2400
              mov th1,#0f3h            ;定時(shí)器重裝值
              setb ea                       ;允許總的中斷
              setb es                       ;允許串行中斷
              mov pcon,#00h          ;波特率不倍增
              mov scon,#50h          ;設(shè)置串口工作方式1,REN = 1 允許接收
              setb tr1                       ;定時(shí)器開(kāi)始工作
              ret                               ;返回
;***************  串口中斷服務(wù)程序   ***********
;  如果接收  0FF  表示上位機(jī)需要聯(lián)機(jī)信號(hào),單片機(jī)發(fā)送 0FFH作為
;  應(yīng)答信號(hào),如果接收到 數(shù)字 1~ n,表示相應(yīng)的功能;
;  這里,如果收到 1 ,則單片機(jī)向計(jì)算機(jī)發(fā)送字符  'H';
;            如果收到 2 ,則單片機(jī)向計(jì)算機(jī)發(fā)送字符  'e';
;            如果收到其他的數(shù)據(jù),則發(fā)送    'J';
com_int:  clr es                        ;禁止串行中斷
                clr ri                          ;清除接收標(biāo)志位
                mov a,sbuf               ;從緩沖區(qū)取出數(shù)據(jù)
                mov p1,a
                mov dptr,#tab
                cjne a,#0ffh,in_1      ;檢查數(shù)據(jù)
                mov sbuf,#255          ;收到聯(lián)機(jī)信號(hào),發(fā)送聯(lián)機(jī)信號(hào)
                jnb ti,$                      ;等待發(fā)送完畢
                clr ti                          ;清除發(fā)送標(biāo)志
                setb es                     ;允許串行中斷
                reti                            ;中斷返回
      in_1: cjne a,#1H, in_2         ;如果收到1
                movc a,@a+dptr
                mov sbuf,a             ;發(fā)送 'h'
                jnb ti,$                      ;等待發(fā)送完畢
                clr  ti                         ;清除發(fā)送中斷標(biāo)志
                setb es                     ;允許串行中斷
                reti                            ;中斷返回
      in_2: cjne a,#2,in_3         ;接收到  2
                movc a,@a+dptr
                mov sbuf,a             ;發(fā)送 'e'
                jnb ti,$                      ;等待發(fā)送完畢
                clr  ti                         ;清除發(fā)送中斷
                setb es                     ;允許串行中斷
                reti                            ;中斷返回
      in_3:     mov a,#03h
                movc a,@a+dptr
                mov sbuf,a             ;發(fā)送 'j'
                jnb ti,$                      ;等待發(fā)送完畢
                clr ti                          ;清除發(fā)送中斷標(biāo)志
                setb es                     ;允許串行中斷
                reti                            ;返回
tab:    db '2','h','e','j'
  end

51單片機(jī)串口調(diào)試程序一例

/*定義為中斷方式串口處理*/
#define INTERSENDSTR
/*不為8032系列芯片 */
//#define CHIP_8032

#include <absacc.h>
#include <reg51.h>
#include <string.h>
#include "err.h"


#ifdef INTERSENDSTR
unsigned char xdata sSendComBuf[256],sRecComBuf[256];
unsigned char data bOut,bIn,bSout,bSin;
#else
#define DEFSENDCHAR TI=0;SBUF=ACC;while(!TI);TI=0;
#endif
//bps設(shè)置 9600就是 PSetBps(96)(11.0592Mhz)

unsigned char  PSetBps(unsigned int bps) SMALL
{
unsigned int t1;
unsigned char t2;
#ifdef INTERSENDSTR
/*如果使用中斷方式發(fā)送數(shù)據(jù),必須等待發(fā)送數(shù)據(jù)完畢才能更換波特率 */
while(bSin!=bSout)
{
;
}
ES=0;
#endif

#ifdef CHIP_8032
if(3456%bps)
{
return ERR_SET_BPS;
}
t1=3456/bps;
t1--;t1=~t1;
RCAP2H=t1/256;RCAP2L=t1;
T2MOD=0x00;
/*使用定時(shí)器2做波特率發(fā)生器 */
T2CON=0x34;/*TF2=0;EXF2=0;RCLK=1;TCLK=1;EXEN2=0;TR2=1;C/T2=0;CP/RL2=0
*/
#else
t1=576/bps;
if((576%bps)||((t1==0))||(t1>=2*256))
{
return ERR_SET_BPS;
}
if(t1>256)
{
PCON=00;
t2=256-(288/bps);
}
else
{
PCON=0x80;
t2=256-t1;
}
TH1=t2;TL1=t2;
TR1=1;
#endif
/*模式3*/
SM0=0;
RI=0;TI=0;
REN=1;
SM1=1;
SM2=1;
#ifdef INTERSENDSTR
bOut=bIn;
bSout=bSin;
ES=1;
#endif
return OK;
}
void PSendChar(unsigned char ch) SMALL
{

#ifdef INTERSENDSTR
unsigned char tch;

tch=bSin+1;
while(tch==bSout)
{
;
}
sSendComBuf[bSin]=ch;
ES=0;
if((bSout==bSin))
{
SBUF=sSendComBuf[bSin];
bSin++;
}
else
{
bSin++;              
}
ES=1;
#else
ACC=ch;
DEFSENDCHAR;
#endif
}
unsigned char PGetChar() SMALL
{
unsigned char ch;
#ifdef  INTERSENDSTR
ch=sRecComBuf[bOut];
bOut++;
return ch;
#else
ch=SBUF;
RI=0;
#endif
}
bit PCharInCom() SMALL
{
#ifdef  INTERSENDSTR
if(bIn!=bOut)
{
return 1;
}
return 0;
#else
return RI;
#endif
}
void PSendString(unsigned char *st) SMALL
{
while(*st)
{
PSendChar(*st);
st++;
}
}
void PSendArray(unsigned char  *st,unsigned int  len) SMALL
{
unsigned int ii;
for(ii=0;ii<len;ii++)
{
PSendChar(st[ii]);
}
}
#ifdef  INTERSENDSTR
void PSerialInt() interrupt 4
{
if(RI)
{
sRecComBuf[bIn]=SBUF;
bIn++;
RI=0;
}
if(TI)
{
TI=0;
if(bSout!=bSin)
{
bSout++;
}
if(bSout!=bSin)
{
SBUF=sSendComBuf[bSout];
}
}
}
#endif

  • 上一篇: 51單片機(jī)IO口模擬串口通訊C源程
  • 下一篇: 沒(méi)有了
  • 發(fā)表評(píng)論   告訴好友   打印此文  收藏此頁(yè)  關(guān)閉窗口  返回頂部
    熱點(diǎn)文章
     
    推薦文章
     
    相關(guān)文章
    網(wǎng)友評(píng)論:(只顯示最新5條。)
    關(guān)于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 機(jī)電之家 | 會(huì)員助手 | 免費(fèi)鏈接

    點(diǎn)擊這里給我發(fā)消息66821730(技術(shù)支持)點(diǎn)擊這里給我發(fā)消息66821730(廣告投放) 點(diǎn)擊這里給我發(fā)消息41031197(編輯) 點(diǎn)擊這里給我發(fā)消息58733127(審核)
    本站提供的機(jī)電設(shè)備,機(jī)電供求等信息由機(jī)電企業(yè)自行提供,該企業(yè)負(fù)責(zé)信息內(nèi)容的真實(shí)性、準(zhǔn)確性和合法性。
    機(jī)電之家對(duì)此不承擔(dān)任何保證責(zé)任,有侵犯您利益的地方請(qǐng)聯(lián)系機(jī)電之家,機(jī)電之家將及時(shí)作出處理。
    Copyright 2007 機(jī)電之家 Inc All Rights Reserved.機(jī)電之家-由機(jī)電一體化網(wǎng)更名-聲明
    電話:0571-87774297 傳真:0571-87774298
    杭州濱興科技有限公司提供技術(shù)支持

    主辦:杭州市高新區(qū)(濱江)機(jī)電一體化學(xué)會(huì)
    中國(guó)行業(yè)電子商務(wù)100強(qiáng)網(wǎng)站

    網(wǎng)站經(jīng)營(yíng)許可證:浙B2-20080178-1