久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1366|回復: 5
收起左側

程序寫入51單片機后,單片機沒有按照預期運行

[復制鏈接]
回帖獎勵 10 黑幣 回復本帖可獲得 1 黑幣獎勵! 每人限 1 次
ID:1112757 發表于 2024-4-3 19:40 | 顯示全部樓層 |閱讀模式
如圖所示,本人使用的江協科技的51單片機,燒錄成功后單片機沒有按照程序運行。蜂鳴器持續響起,LED全亮。
IMG_20240403_154237_edit_7563114578532.jpg

本人排查了好久都沒有找到問題,望各位專家解答。
部分代碼如下:
main.c:
  1. #include <REGX52.H>
  2. #include "Delay.h"
  3. #include "ADC0832.h"
  4. #include<stdio.h>
  5. #include "uart.h"
  6. #define uchar unsigned char
  7. #define uint unsigned int
  8. #define false 0
  9. #define true 1
  10. unsigned int AD_X;
  11. unsigned int AD_Y;

  12. //Unicode
  13. char Unicode_latitude[10*latitude_Length]='0';
  14. char Unicode_N_S[10*N_S_Length];
  15. char Unicode_longitude[10*longitude_Length];
  16. char Unicode_E_W[10*E_W_Length];


  17. void errorLog(int num)//解析錯誤
  18. {
  19.         
  20.         while (1)
  21.         {
  22.                   Uart1Sends("ERROR");
  23.                 Uart1Send(num+0x30);
  24.                 Uart1Sends("\r\n");
  25.         }
  26. }

  27. void parseGpsBuffer()//獲得GPS數據
  28. {
  29.         char *subString;
  30.         char *subStringNext;
  31.         char i = 0;
  32.         if (Save_Data.isGetData)
  33.         {
  34.                 Save_Data.isGetData = false;
  35.                 //Uart1Sends("**************\r\n");
  36.                 //Uart1Sends(Save_Data.GPS_Buffer);

  37.                
  38.                 for (i = 0 ; i <= 6 ; i++)
  39.                 {
  40.                         if (i == 0)
  41.                         {
  42.                                 if ((subString = strstr(Save_Data.GPS_Buffer, ",")) == NULL)
  43.                                         errorLog(1);        //解析錯誤
  44.                         }
  45.                         else
  46.                         {
  47.                                 subString++;
  48.                                 if ((subStringNext = strstr(subString, ",")) != NULL)
  49.                                 {
  50.                                         char usefullBuffer[2];
  51.                                         switch(i)
  52.                                         {
  53.                                                 case 1:memcpy(Save_Data.UTCTime, subString, subStringNext - subString);break;        //獲取UTC時間
  54.                                                 case 2:memcpy(usefullBuffer, subString, subStringNext - subString);break;        //獲取UTC時間
  55.                                                 case 3:memcpy(Save_Data.latitude, subString, subStringNext - subString);break;        //獲取緯度信息
  56.                                                 case 4:memcpy(Save_Data.N_S, subString, subStringNext - subString);break;        //獲取N/S
  57.                                                 case 5:memcpy(Save_Data.longitude, subString, subStringNext - subString);break;        //獲取經度信息
  58.                                                 case 6:memcpy(Save_Data.E_W, subString, subStringNext - subString);break;        //獲取E/W

  59.                                                 default:break;
  60.                                         }

  61.                                         subString = subStringNext;
  62.                                         Save_Data.isParseData = true;
  63.                                         if(usefullBuffer[0] == 'A')
  64.                                                 Save_Data.isUsefull = true;
  65.                                         else if(usefullBuffer[0] == 'V')
  66.                                                 Save_Data.isUsefull = false;

  67.                                 }
  68.                                 else
  69.                                 {
  70.                                         errorLog(2);        //解析錯誤
  71.                                 }
  72.                         }


  73.                 }
  74.         }
  75. }
  76. /***
  77. void printGpsBuffer()//輸出GPS數據
  78. {
  79.         if (Save_Data.isParseData)
  80.         {
  81.                 Save_Data.isParseData = false;
  82.                
  83.                 Uart1Sends("Save_Data.UTCTime = ");
  84.                 Uart1Sends(Save_Data.UTCTime);
  85.                 Uart1Sends("\r\n");

  86.                 if(Save_Data.isUsefull)
  87.                 {
  88.                         Save_Data.isUsefull = false;
  89.                         Uart1Sends("Save_Data.latitude = ");
  90.                         Uart1Sends(Save_Data.latitude);
  91.                         Uart1Sends("\r\n");


  92.                         Uart1Sends("Save_Data.N_S = ");
  93.                         Uart1Sends(Save_Data.N_S);
  94.                         Uart1Sends("\r\n");

  95.                         Uart1Sends("Save_Data.longitude = ");
  96.                         Uart1Sends(Save_Data.longitude);
  97.                         Uart1Sends("\r\n");

  98.                         Uart1Sends("Save_Data.E_W = ");
  99.                         Uart1Sends(Save_Data.E_W);
  100.                         Uart1Sends("\r\n");
  101.                 }
  102.                 else
  103.                 {
  104.                         Uart1Sends("GPS DATA is not usefull!\r\n");
  105.                 }
  106.                
  107.         }
  108. }
  109. ***/
  110. //ASCLL-Unicode
  111. void ASCII_TO_Unicode(char *ASCII,char *Unicode)
  112. {
  113.     int length;
  114.     int i = 0;
  115.     int j = 0;
  116.         memset(Unicode,'\0',sizeof(Unicode));
  117.     length = strlen(ASCII);

  118.     for(i=0;i<length;i++)
  119.     {
  120.         Unicode[j++] = '0';
  121.         Unicode[j++] = '0';

  122.         Unicode[j++] = (ASCII[i] / 16) + 0x30;
  123.         Unicode[j++] = (ASCII[i] % 16) + 0x30;
  124.     }

  125. }
  126. void main()
  127. {
  128.         Uart_Init();
  129.         Delay(10000);
  130.         //clrStruct();
  131.         while(1)
  132.         {
  133.                 AD_X=ADC0832(1);
  134.     AD_Y=ADC0832(0);
  135.                 parseGpsBuffer();
  136.                 //ASCII_TO_Unicode(Save_Data.E_W,Unicode_E_W);
  137.                 //printGpsBuffer();
  138.                 if((AD_X<=47  ||  AD_X>=126) || (AD_Y>=141 ||  AD_Y<=57))
  139.                 {
  140.                                 //----------------為什么是下面這些AT指令呢,請看群共享文件SIM900A重要的信息指令文件------------
  141.                         ASCII_TO_Unicode(Save_Data.latitude,Unicode_latitude);
  142.                         ASCII_TO_Unicode(Save_Data.longitude,Unicode_longitude);
  143.                                 Uart1Sends("AT\r\n");
  144.                                 Delay(2000);//延時大約2秒
  145.                                 //Uart1Sends("AT+CSCS=\"UCS2\"\r\n");
  146.                                 //Delay(2000);//延時大約2秒
  147.                                 Uart1Sends("AT+CMGF=1\r\n");
  148.                                 Delay(2000);//延時2秒
  149.                         Uart1Sends("AT+CSCA?\n");
  150.                                 Delay(2000);//延時2秒
  151.                         Uart1Sends("AT+CSMP=17,167,0,25\r\n");
  152.                                 Delay(2000);//延時2秒
  153.                                 //Uart1Sends("AT+CMGS=\"00310039003100360037003500340036003700320034\"\r\n");//此處修改為對方的電話號,電話話的UNICON編碼,可使用我們配套的
  154.                                                                                                                                                                                 //資料包中的 中文轉UNICON編碼工具來獲取。特別注意:那個軟件
  155.                                                                                                                                                                                 //獲得的unicon 編碼待有空格,實際中要去掉,否則模塊會報錯
  156.                                 Uart1Sends("AT+CMGS=\"19167546724\"\r\n");
  157.                                 Delay(2000);//延時2秒
  158.                                 Uart1Sends("4F7F7528800553EF80FD64545012FF0C8BF7524D5F8063075B9A573070B9655152A9FF01");//修改信息內容,內容可為中文、英文和數字,但都是對應的unicon 編碼。        
  159.                         Uart1Sends(Unicode_latitude);
  160.                         Uart1Sends("004E0053");
  161.                         Uart1Sends(Unicode_longitude);
  162.                         Uart1Sends("00450057");
  163.                         /***
  164.                         Uart1Sends("使用者可能摔倒,請前往");
  165.                         Uart1Sends(Save_Data.N_S);
  166.                         Uart1Sends(Save_Data.latitude);
  167.                         Uart1Sends(Save_Data.E_W);
  168.                         Uart1Sends(Save_Data.longitude);
  169.                         Uart1Sends("進行救助!");
  170.                         ***/
  171.                         Uart1Send(0x1a);
  172.                                 Delay(8000);//延時10秒
  173.                 }
  174.                 Delay(100);
  175.         }
  176. }
復制代碼
uart.c:
  1. #include "uart.h"
  2. //以下是開機后發送到手機的內容,發送的號碼在程序中修改。        
  3. unsigned int  rec_data_len_uart=0;    //標記Buffer_Uart0接收數組
  4. unsigned char idata Buffer_Uart0_Rec[25]={0};                 //Uart0中斷接收數組
  5. //注意,無論接收到信號還是發送完信號,都會進中斷服務程序的
  6. char idata gpsRxBuffer[gpsRxBufferLength];
  7. unsigned char RX_Count = 0;
  8. _SaveData Save_Data;

  9. void Uart_Init()                                                                     
  10. {
  11.         SCON = 0X50;  //UART方式1;8位UART
  12.         REN  = 1;     //允許串行口接收數據
  13.         PCON = 0x00;  //SMOD=0;波特率不加倍
  14.         TMOD = 0x20;  //T1方式2,用于產生波特率
  15.         TH1  = 0xFD;  //裝初值
  16.         TL1  = 0xFD;
  17.         TR1  = 1;     //啟動定時器1
  18.         EA   = 1;     //打開全局中斷控制
  19.         ES   = 1;     //打開串行口中斷        
  20. }

  21. void Uart1Sends(unsigned char *p)                                //·¢?í×?·?′?
  22. {        
  23.          while(*p)
  24.          {
  25.                  SBUF=*(p++);
  26.                 while(TI==0)
  27.                 {

  28.                 };
  29.                 TI=0;
  30.         }   
  31. }

  32. void Uart1Send(unsigned char c)                                //·¢?íò???×?·?
  33. {
  34.     TI=0;   
  35.     SBUF=c;   
  36.     while(TI==0);   
  37.     TI=0;   
  38. }
  39. /***
  40. void Serial_interrupt() interrupt 4
  41. {
  42.         unsigned char temp_rec_data_uart0;        
  43.         temp_rec_data_uart0 = SBUF;//讀取接收數據               
  44.         RI=0;//接收中斷信號清零,表示將繼續接收                        
  45.         Buffer_Uart0_Rec[rec_data_len_uart]=temp_rec_data_uart0;        //接收數據
  46.         rec_data_len_uart++;
  47.         if(rec_data_len_uart>24)
  48.         {
  49.                 rec_data_len_uart=0;         //從頭開始接收數據
  50.         }        
  51. }
  52. ***/
  53. /*串行通訊中斷,收發完成將進入該中斷*/
  54. void RECEIVE_DATA(void) interrupt 4 using 3                          
  55. {
  56.         unsigned char temp = 0;
  57.     char i = 0;
  58.    
  59.     ES=0;
  60.     temp = SBUF;
  61.     RI = 0;
  62.    
  63.     if(temp == ')
  64.     {
  65.         RX_Count = 0;   
  66.     }
  67.             
  68.     if(RX_Count <= 5)
  69.     {
  70.              gpsRxBuffer[RX_Count++] = temp;
  71.         if(temp == '\n')                                       
  72.         {
  73.             memset(Save_Data.GPS_Buffer, 0, GPS_Buffer_Length);      //=?||
  74.             memcpy(Save_Data.GPS_Buffer, gpsRxBuffer, RX_Count);     // mph||
  75.             Save_Data.isGetData = true;
  76.             RX_Count = 0;
  77.             memset(gpsRxBuffer, 0, gpsRxBufferLength);      //??Σ
  78.         }
  79.             
  80.         if(RX_Count >= 75)
  81.         {
  82.             RX_Count = 75;
  83.             gpsRxBuffer[RX_Count] = '\0';//ìí?ó?áê?·?
  84.         }            
  85.     }
  86.     ES=1;
  87. }

  88. void clrStruct()
  89. {
  90.         Save_Data.isGetData = false;
  91.         Save_Data.isParseData = false;
  92.         Save_Data.isUsefull = false;
  93.         memset(Save_Data.GPS_Buffer, 0, GPS_Buffer_Length);      //清空
  94.         memset(Save_Data.UTCTime, 0, UTCTime_Length);
  95.         memset(Save_Data.latitude, 0, latitude_Length);
  96.         memset(Save_Data.N_S, 0, N_S_Length);
  97.         memset(Save_Data.longitude, 0, longitude_Length);
  98.         memset(Save_Data.E_W, 0, E_W_Length);
  99.         
  100. }

復制代碼

uart.h:
  1. /******************************************************************
  2.         作者:神秘藏寶室
  3.         最終解釋權歸原作者所有,鄙視其他店鋪不勞而獲的抄行為!
  4. ******************************************************************/
  5. #ifndef __UART_H__
  6. #define __UART_H__

  7. #include &lt;REGX52.H&gt;
  8. #include &lt;stdio.h&gt;
  9. #include &lt;stdlib.h&gt;
  10. #include &lt;string.h&gt;

  11. #define false 0
  12. #define true 1

  13. //定義數組長度
  14. #define GPS_Buffer_Length 80
  15. #define UTCTime_Length 11
  16. #define latitude_Length 11
  17. #define N_S_Length 2
  18. #define longitude_Length 12
  19. #define E_W_Length 2

  20. typedef struct SaveData
  21. {
  22.         char GPS_Buffer[GPS_Buffer_Length];
  23.         char isGetData;                //是否獲取到GPS數據
  24.         char isParseData;        //是否解析完成
  25.         char UTCTime[UTCTime_Length];                //UTC時間
  26.         char latitude[latitude_Length];                //緯度
  27.         char N_S[N_S_Length];                //N/S
  28.         char longitude[longitude_Length];                //經度
  29.         char E_W[E_W_Length];                //E/W
  30.         char isUsefull;                //定位信息是否有效
  31. } xdata _SaveData;



  32. //函數或者變量聲明
  33. extern void Uart_Init();
  34. extern void Uart1Sends(unsigned char *p);
  35. extern void Uart1Send(unsigned char c);
  36. extern void clrStruct();


  37. #define gpsRxBufferLength  76
  38. extern char idata gpsRxBuffer[gpsRxBufferLength];
  39. extern unsigned char RX_Count;
  40. extern _SaveData Save_Data;
  41. extern unsigned int  rec_data_len_uart;    //標記Buffer_Uart0接收數組
  42. extern unsigned char idata Buffer_Uart0_Rec[25];        

  43. #endif
復制代碼
回復

使用道具 舉報

ID:79094 發表于 2024-4-4 10:55 | 顯示全部樓層
生成的少錄文件 完整不  
回復

使用道具 舉報

ID:1113476 發表于 2024-4-4 20:49 來自手機 | 顯示全部樓層
估計是燒錄文件不完整吧
回復

使用道具 舉報

ID:402383 發表于 2024-4-6 14:16 | 顯示全部樓層
1-可能是缺少了I/O口配置初始化
2-可能延時函數時間太長,需要等待一段時間才正常
3-單片機芯片可能損壞,建議更換試一下
回復

使用道具 舉報

ID:281828 發表于 2024-4-6 19:48 | 顯示全部樓層
使用STC單片機時建議在STC-ISP軟件中下載、使用相關的STC***.h頭文件,可以避免很多奇怪的問題。
回復

使用道具 舉報

ID:1115609 發表于 2024-4-7 10:40 | 顯示全部樓層

1-可能是缺少了I/O口配置初始化
2-可能延時函數時間太長,需要等待一段時間才正常
3-單片機芯片可能損壞,建議更換試一下
另外使用STC單片機時建議在STC-ISP軟件中下載、使用相關的STC***.h頭文件,可以避免很多奇怪的問題
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩毛片在线视频 | 国产小视频在线观看 | 国产99久久精品 | 国产精品亚洲一区二区三区在线 | 日本特黄a级高清免费大片 成年人黄色小视频 | 国产精品久久久久久久久图文区 | 成人午夜电影在线观看 | 99久久视频| 久久99网| 欧美亚洲视频 | 成人在线免费观看 | 国产美女黄色片 | 国产亚洲精品美女久久久久久久久久 | 日韩二区 | 欧美成人一级视频 | 毛片99 | 亚洲欧美激情精品一区二区 | 亚洲欧美日韩中文字幕一区二区三区 | 黄免费看 | 在线免费观看毛片 | 精品国产一区二区三区久久久蜜月 | 中文字幕亚洲精品 | 亚洲精品成人 | 久久久久亚洲精品 | 日韩在线观看一区二区三区 | 国产1区| 国产精品夜色一区二区三区 | 亚洲国产在| 在线视频 亚洲 | 免费久 | 亚洲高清av | 一区二区三区四区视频 | 欧美精品一区二区三区在线播放 | 成人在线播放 | 日韩精品专区在线影院重磅 | 免费观看一级特黄欧美大片 | 国产一区二区三区在线 | 亚洲国产日韩欧美 | 丁香五月网久久综合 | 久久国产精品久久国产精品 | 日韩在线视频免费观看 |