單片機是stc8g1k08a,程序用的是一位大佬分享的,單片機直接和電腦usb連接,isp發送一個數據到單片機,就能接收到0-65536,但是接收到的是一樣的數據。頻率設置成30MHz,波特率是9600。是我哪里沒有設置好嗎,還是硬件這樣子連會有干擾呢
c85c220942cb60cf3b6d18c0cd4c065.jpg (277.58 KB, 下載次數: 0)
下載附件
2025-4-16 10:39 上傳
1dc88c2e6bca18114960530e64d1a7d.png (123.81 KB, 下載次數: 0)
下載附件
2025-4-16 11:16 上傳
//使用STC-ISP軟件的串口助手顯示,波特率9600,需要自動發送一個字符。文本模式接收顯示 0~65535
typedef unsigned char u8;
typedef unsigned short u16;
u8 code ASCII[16]={"0123456789ABCDEF"};
#include "STC8.H" //選擇頭文件,單片機STC8
#define FOSC 30000000UL /設置系統頻率,30M
u16 xdata Uart1_Byte[3]={0x5a9b,0xFFED,0x55};/需要打印的變量
bit Uart1_Flag=0; /這個標志位寫1 就開始打印
//串口初始化,根據設計需要,波特率來源選擇:定時器1、定時器2、BRT獨立波特率,以下配置都是12分頻。
void Uart1_Init()
{
AUXR&=0xBF; //定時器T1(16位自裝),STC15/STC8,定時器時鐘12T模式
AUXR&=0xFE; //定時器T1(16位自裝),STC15/STC8,串口1選擇定時器1為波特率發生器
TMOD&=0x0F; /定時器T1(16位自裝),STC15/STC8,設置定時器模式16位自動重裝
TL1=(65536-FOSC/9600/4/12); //定時器T1(16位自裝),STC15/STC8,設置定時初始值
TH1=(65536-FOSC/9600/4/12)>>8; //定時器T1(16位自裝),STC15/STC8,設置定時初始值
ET1=0; //定時器T1(16位自裝),STC15/STC8,不需要定時器1的中斷
TR1=1;//*/ //定時器T1(16位自裝),STC15/STC8,定時器1開始計時
//以下代碼,這三行是必須的。
SCON|=0x50; //8位數據,可變波特率。
ES = 1; //串口1中斷閘刀閉合,向CPU申請中斷。
EA=1; //總中斷閘刀閉合導通。
}
//串口發送函數。主函數調用,或者串口發送完中斷后馬上調用
void Uart1_Up_Data_Drive()
{
static u8 xdata count=0;
if(Uart1_Flag) //標志允許,發送一個字節
{
Uart1_Flag=0; //標志位翻轉,只允許發送一個字節
count++; //字節編號增加。
switch(count) //打印成十六進制顯示
{
case 1 : SBUF='\r';break; // 回車
case 2 : SBUF='\n';break; // 換行
case 3 : SBUF='0';break; // 0
case 4 : SBUF='x';break; // x
case 5 : SBUF=ASCII[Uart1_Byte[0]/256/16];break; //字節0
case 6 : SBUF=ASCII[Uart1_Byte[0]/256%16];break; //字節0
case 7 : SBUF=ASCII[Uart1_Byte[0]%256/16];break; //字節0
case 8 : SBUF=ASCII[Uart1_Byte[0]%256%16];break; //字節0
case 9 : SBUF=' ';break; // 空格
case 10 : SBUF='0';break; // 0
case 11 : SBUF='x';break; // x
case 12 : SBUF=ASCII[Uart1_Byte[1]/256/16];break; //字節1
case 13 : SBUF=ASCII[Uart1_Byte[1]/256%16];break; //字節1
case 14 : SBUF=ASCII[Uart1_Byte[1]%256/16];break; //字節1
case 15 : SBUF=ASCII[Uart1_Byte[1]%256%16];break; //字節1
case 16 : SBUF=' ';break; // 空格
case 17 : SBUF='0';break; // 0
case 18 : SBUF='x';break; // x
case 19 : SBUF=ASCII[Uart1_Byte[2]/256/16];break; //字節2
case 20 : SBUF=ASCII[Uart1_Byte[2]/256%16];break; //字節2
case 21 : SBUF=ASCII[Uart1_Byte[2]%256/16];break; //字節2
case 22 : SBUF=ASCII[Uart1_Byte[2]%256%16];break; //字節2
case 23 :count=0;break;//最后一步 沒有發送字節,串口TI不會置1,所以不再發送
}
}
}
//串口中斷,接收一個字節,馬上發送N個字節,發送數組顯示到電腦
void Uart1_Routine() interrupt 4
{
static char Uart1_ser_n=0; //用于接收計數
if(RI) //如果接收到一個字節
{
RI=0; //標志位清除
Uart1_Flag=1; //串口發送允許
if(SBUF==0x7f) //最低波特率9600,最高波特率9600,判斷連續多個0x7f
{
Uart1_ser_n++; //判斷連續多個0x7f
if(Uart1_ser_n>=10) //判斷連續多個0x7f
{
Uart1_ser_n=0; //清0
IAP_CONTR|=0xe0; //執行自動軟復位,可以做調試用,STC12、STC15、STC8
//ISP_CONTR|=0xe0; //執行自動軟復位,可以做調試用,STC89
}
}
else
{
Uart1_ser_n=0;
}
}
if(TI) //如果上一個字節發送完成了
{
TI=0; //標志位清除
Uart1_Flag=1; //串口發送允許
Uart1_Up_Data_Drive(); //執行串口發送下一個字節
}
}
void Uart1_Allot()
{
static u16 idata count;
count++;
if(count>50000)
{
count=0;
Uart1_Flag=1;
}
}
void main()
{
Uart1_Init();
while(1)
{
Uart1_Up_Data_Drive();
Uart1_Allot();
}
}
|