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

串口通信的單片機程序


beep    bit   p3.7                ;蜂鳴器定義

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

;***********  主程序開始    *******************
        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,定時器1作為波特率發(fā)生器
;波特率設(shè)置為   2400  ;

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

51單片機串口調(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;
/*使用定時器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單片機IO口模擬串口通訊C源程
  • 下一篇: 沒有了
  • 發(fā)表評論   告訴好友   打印此文  收藏此頁  關(guān)閉窗口  返回頂部
    熱點文章
     
    推薦文章
     
    相關(guān)文章
    網(wǎng)友評論:(只顯示最新5條。)
    關(guān)于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 機電之家 | 會員助手 | 免費鏈接

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

    主辦:杭州市高新區(qū)(濱江)機電一體化學會
    中國行業(yè)電子商務(wù)100強網(wǎng)站

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