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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3136|回復: 6
打印 上一主題 下一主題
收起左側

51單片機的基礎學習STM32比較吃力,原子的USMART看不懂啊

[復制鏈接]
跳轉到指定樓層
樓主
ID:140644 發表于 2020-1-10 16:03 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
最近學習SD卡讀寫知識,又牽涉到USART函數,對于結構體定義和函數調用知識匱乏。
研究了三天還沒有眉目。原子的例程是由深入淺,看起來比較吃力,原來學習51系列單片機
都是由淺入深,先點亮一個LED,再學習輸入的定義和操作。看來還得慢慢摸索啊。

  1. #include "usmart.h"
  2. #include "usart.h"
  3. #include "sys.h"
  4. //////////////////////////////////////////////////////////////////////////////////         
  5. //本程序只供學習使用,未經作者許可,不得用于其它任何用途
  6. //ALIENTEK STM32開發板           
  7. //正點原子@ALIENTEK
  8. //All rights reserved
  9. //********************************************************************************
  10. //升級說明
  11. //V1.4
  12. //增加了對參數為string類型的函數的支持.適用范圍大大提高.
  13. //優化了內存占用,靜態內存占用為79個字節@10個參數.動態適應數字及字符串長度
  14. //V2.0
  15. //1,修改了list指令,打印函數的完整表達式.
  16. //2,增加了id指令,打印每個函數的入口地址.
  17. //3,修改了參數匹配,支持函數參數的調用(輸入入口地址).
  18. //4,增加了函數名長度宏定義.        
  19. //V2.1 20110707                 
  20. //1,增加dec,hex兩個指令,用于設置參數顯示進制,及執行進制轉換.
  21. //注:當dec,hex不帶參數的時候,即設定顯示參數進制.當后跟參數的時候,即執行進制轉換.
  22. //如:"dec 0XFF" 則會將0XFF轉為255,由串口返回.
  23. //如:"hex 100"         則會將100轉為0X64,由串口返回
  24. //2,新增usmart_get_cmdname函數,用于獲取指令名字.
  25. //V2.2 20110726        
  26. //1,修正了void類型參數的參數統計錯誤.
  27. //2,修改數據顯示格式默認為16進制.
  28. //V2.3 20110815
  29. //1,去掉了函數名后必須跟"("的限制.
  30. //2,修正了字符串參數中不能有"("的bug.
  31. //3,修改了函數默認顯示參數格式的修改方式.
  32. //V2.4 20110905
  33. //1,修改了usmart_get_cmdname函數,增加最大參數長度限制.避免了輸入錯誤參數時的死機現象.
  34. //2,增加USMART_ENTIM_SCAN宏定義,用于配置是否使用TIM定時執行scan函數.
  35. //V2.5 20110930
  36. //1,修改usmart_init函數為void usmart_init(u8 sysclk),可以根據系統頻率自動設定掃描時間.(固定100ms)
  37. //2,去掉了usmart_init函數中的uart_init函數,串口初始化必須在外部初始化,方便用戶自行管理.
  38. //V2.6 20111009
  39. //1,增加了read_addr和write_addr兩個函數.可以利用這兩個函數讀寫內部任意地址(必須是有效地址).更加方便調試.
  40. //2,read_addr和write_addr兩個函數可以通過設置USMART_USE_WRFUNS為來使能和關閉.
  41. //3,修改了usmart_strcmp,使其規范化.                          
  42. //V2.7 20111024
  43. //1,修正了返回值16進制顯示時不換行的bug.
  44. //2,增加了函數是否有返回值的判斷,如果沒有返回值,則不會顯示.有返回值時才顯示其返回值.
  45. //V2.8 20111116
  46. //1,修正了list等不帶參數的指令發送后可能導致死機的bug.
  47. //V2.9 20120917
  48. //1,修改了形如:void*xxx(void)類型函數不能識別的bug。
  49. //V3.0 20130425
  50. //1,新增了字符串參數對轉義符的支持。
  51. //V3.1 20131120
  52. //1,增加runtime系統指令,可以用于統計函數執行時間.
  53. //用法:
  54. //發送:runtime 1 ,則開啟函數執行時間統計功能
  55. //發送:runtime 0 ,則關閉函數執行時間統計功能
  56. ///runtime統計功能,必須設置:USMART_ENTIMX_SCAN 為1,才可以使用!!
  57. /////////////////////////////////////////////////////////////////////////////////////
  58. //USMART資源占用情況@MDK [url=mailto:3.80A@2.0]3.80A@2.0[/url]版本:
  59. //FLASH:4K~K字節(通過USMART_USE_HELP和USMART_USE_WRFUNS設置)
  60. //SRAM:72字節(最少的情況下)
  61. //SRAM計算公式:   SRAM=PARM_LEN+72-4  其中PARM_LEN必須大于等于4.
  62. //應該保證堆棧不小于100個字節.
  63. ////////////////////////////////////////////用戶配置參數////////////////////////////////////////////////////         
  64. //系統命令
  65.        u8 *sys_cmd_tab[]=
  66.       {
  67.         "?",
  68.         "help",
  69.         "list",
  70.         "id",
  71.         "hex",
  72.         "dec",
  73.         "runtime",           
  74.        };            
  75. //處理系統指令
  76. //0,成功處理;其他,錯誤代碼;
  77. u8 usmart_sys_cmd_exe(u8 *str)
  78. {
  79.         u8 i;
  80.         u8 sfname[MAX_FNAME_LEN];                                                         //存放本地函數名
  81.         u8 pnum;
  82.         u8 rval;
  83.         u32 res;  
  84.         res=usmart_get_cmdname(str,sfname,&i,MAX_FNAME_LEN);                              //得到指令及指令長度
  85.         if(res)return USMART_FUNCERR;                                                     //錯誤的指令
  86.         str+=i;                                             
  87.         for(i=0;i<sizeof(sys_cmd_tab)/4;i++)                                              //支持的系統指令
  88.         {
  89.         if(usmart_strcmp(sfname,sys_cmd_tab[i])==0)break;
  90.         }
  91.         switch(i)
  92.         {                                          
  93.         case 0:
  94.         case 1:                                                                         //幫助指令
  95.         printf("\r\n");
  96.        #if USMART_USE_HELP
  97.        printf("------------------------USMART V3.1------------------------ \r\n");
  98.        printf("    USMART是由ALIENTEK開發的一個靈巧的串口調試互交組件,通過 \r\n");
  99.        printf("它,你可以通過串口助手調用程序里面的任何函數,并執行.因此,你可\r\n");
  100.        printf("以隨意更改函數的輸入參數(支持數字(10/16進制)、字符串、函數入\r\n");         
  101.        printf("口地址等作為參數),單個函數最多支持10個輸入參數,并支持函數返 \r\n");
  102.        printf("回值顯示.新增參數顯示進制設置功能,新增進制轉換功能.\r\n");
  103.        printf("技術支持:[url=http://www.openedv.com]www.openedv.com[/url]\r\n");
  104.        printf("USMART有7個系統命令:\r\n");
  105.        printf("?:      獲取幫助信息\r\n");
  106.        printf("help:   獲取幫助信息\r\n");
  107.        printf("list:   可用的函數列表\r\n\n");
  108.        printf("id:     可用函數的ID列表\r\n\n");
  109.        printf("hex:    參數16進制顯示,后跟空格+數字即執行進制轉換\r\n\n");
  110.        printf("dec:    參數10進制顯示,后跟空格+數字即執行進制轉換\r\n\n");
  111.        printf("runtime:1,開啟函數運行計時;0,關閉函數運行計時;\r\n\n");
  112.        printf("請按照程序編寫格式輸入函數名及參數并以回車鍵結束.\r\n");   
  113.        printf("--------------------------ALIENTEK------------------------- \r\n");
  114.        #else
  115.        printf("指令失效\r\n");
  116.        #endif
  117.        break;
  118.        case 2:                                                                         //查詢指令
  119.        printf("\r\n");
  120.        printf("-------------------------函數清單--------------------------- \r\n");
  121.       for(i=0;i<usmart_dev.fnum;i++)printf("%s\r\n",usmart_dev.funs[i].name);
  122.       printf("\r\n");
  123.       break;         
  124.      case 3:                                                                         //查詢ID
  125.      printf("\r\n");
  126.      printf("-------------------------函數 ID --------------------------- \r\n");
  127.      for(i=0;i<usmart_dev.fnum;i++)
  128.     {
  129.     usmart_get_fname((u8*)usmart_dev.funs[i].name,sfname,&pnum,&rval);        //得到本地函數名
  130.     printf("%s id       is:\r\n0X%08X\r\n",sfname,usmart_dev.funs[i].func);  //顯示ID
  131.     }
  132.     printf("\r\n");
  133.     break;
  134.     case 4:                                                                         //hex指令
  135.    printf("\r\n");
  136.    usmart_get_aparm(str,sfname,&i);
  137.    if(i==0)                                                                      //參數正常
  138.    {
  139.     i=usmart_str2num(sfname,&res);                                                           //記錄該參數        
  140.     if(i==0)                                                                                                              //進制轉換功能
  141.     {
  142.     printf("HEX:0X%X\r\n",res);                                                             //轉為16進制
  143.     }
  144.    else if(i!=4)
  145.    return USMART_PARMERR;                                        //參數錯誤.
  146.    else                                                                                                                          //參數顯示設定功能
  147.    {
  148.    printf("16進制參數顯示!\r\n");
  149.    usmart_dev.sptype=SP_TYPE_HEX;  
  150.    }
  151.   }
  152.    else return USMART_PARMERR;                                                                    //參數錯誤.
  153.    printf("\r\n");
  154.    break;
  155.   case 5:                                                                         //dec指令
  156.                         printf("\r\n");
  157.                         usmart_get_aparm(str,sfname,&i);
  158.                         if(i==0)                                                                      //參數正常
  159.                         {
  160.                                 i=usmart_str2num(sfname,&res);                                                           //記錄該參數        
  161.                                 if(i==0)                                                                                                               //進制轉換功能
  162.                                 {
  163.                                         printf("DEC:%lu\r\n",res);                                                             //轉為10進制
  164.                                 }else if(i!=4)return USMART_PARMERR;                                        //參數錯誤.
  165.                                 else                                                                                                                          //參數顯示設定功能
  166.                                 {
  167.                                         printf("10進制參數顯示!\r\n");
  168.                                         usmart_dev.sptype=SP_TYPE_DEC;  
  169.                                 }

  170.                         }else return USMART_PARMERR;                                                                    //參數錯誤.
  171.                         printf("\r\n");
  172.                         break;         
  173.                      case 6:                                                                         //runtime指令,設置是否顯示函數執行時間
  174.                         printf("\r\n");
  175.                         usmart_get_aparm(str,sfname,&i);
  176.                         if(i==0)                                                                      //參數正常
  177.                         {
  178.                       i=usmart_str2num(sfname,&res);                                                                 //記錄該參數        
  179.                      if(i==0)                                                                                                                     //讀取指定地址數據功能
  180.                       {
  181.                 if(USMART_ENTIMX_SCAN==0)printf("\r\nError! \r\nTo EN RunTime function,Please set USMART_ENTIMX_SCAN = 1 first!\r\n");//報錯
  182.                                         else
  183.                                         {
  184.                                                 usmart_dev.runtimeflag=res;
  185.                                                 if(usmart_dev.runtimeflag)printf("Run Time Calculation ON\r\n");
  186.                                                 else printf("Run Time Calculation OFF\r\n");
  187.                                         }
  188.                                 }else return USMART_PARMERR;                                                                   //未帶參數,或者參數錯誤         
  189.                          }else return USMART_PARMERR;                                                                          //參數錯誤.
  190.                         printf("\r\n");
  191.                         break;            
  192.                 default:                                                                        //非法指令
  193.                         return USMART_FUNCERR;
  194.         }
  195.         return 0;
  196. }
  197. ////////////////////////////////////////////////////////////////////////////////////////
  198. //移植注意:本例是以stm32為例,如果要移植到其他mcu,請做相應修改.
  199. //usmart_reset_runtime,清除函數運行時間,連同定時器的計數寄存器以及標志位一起清零.并設置重裝載值為最大,以最大限度的延長計時時間.
  200. //usmart_get_runtime,獲取函數運行時間,通過讀取CNT值獲取,由于usmart是通過中斷調用的函數,所以定時器中斷不再有效,此時最大限度
  201. //只能統計2次CNT的值,也就是清零后+溢出一次,當溢出超過2次,沒法處理,所以最大延時,控制在:2*計數器CNT*0.1ms.對STM32來說,是:13.1s左右
  202. //其他的:TIM4_IRQHandler和Timer4_Init,需要根據MCU特點自行修改.確保計數器計數頻率為:10Khz即可.另外,定時器不要開啟自動重裝載功能!!

  203. #if USMART_ENTIMX_SCAN==1
  204. /***********************************************************/
  205. /***********************復位runtime*************************/
  206.               void usmart_reset_runtime(void)                                       //需要根據所移植到的MCU的定時器參數進行修改
  207.               {
  208.                     TIM4->SR&=~(1<<0);                                                          //清除中斷標志位
  209.                     TIM4->ARR=0XFFFF;                                                            //將重裝載值設置到最大
  210.                     TIM4->CNT=0;                                                                      //清空定時器的CNT
  211.                     usmart_dev.runtime=0;        
  212.               }
  213. /******** 獲得runtime時間 **********************************/
  214. /* 返回值:執行時間,單位:0.1ms,最大延時時間為定時器CNT值的2倍*0.1ms */
  215. /* 需要根據所移植到的MCU的定時器參數進行修改 ***********************/
  216.       u32 usmart_get_runtime(void)
  217.      {
  218.         if(TIM4->SR&0X0001)                                                               //在運行期間,產生了定時器溢出
  219.         {
  220.        usmart_dev.runtime+=0XFFFF;
  221.         }
  222.         usmart_dev.runtime+=TIM4->CNT;
  223.         return usmart_dev.runtime;                                                                    //返回計數值
  224.      }
  225. /**** 下面這兩個函數,非USMART函數,放到這里,僅僅方便移植. ******/
  226. /**** 定時器4中斷服務程序 ***********************************/
  227.       void TIM4_IRQHandler(void)
  228.      {                                                                  
  229.         if(TIM4->SR&0X0001)                                                               //溢出中斷
  230.         {
  231.                 usmart_dev.scan();                                                                    //執行usmart掃描        
  232.                 TIM4->CNT=0;                                                                                //清空定時器的CNT
  233.                 TIM4->ARR=1000;                                                                              //恢復原來的設置
  234.         }                                   
  235.         TIM4->SR&=~(1<<0);                                                                //清除中斷標志位            
  236.    }
  237. /***************** 使能定時器4,使能中斷. ********************/
  238.      void Timer4_Init(u16 arr,u16 psc)
  239.     {
  240.         RCC->APB1ENR|=1<<2;                                                                      //TIM4時鐘使能   
  241.          TIM4->ARR=arr;                                                                          //設定計數器自動重裝值  
  242.         TIM4->PSC=psc;                                                                          //預分頻器7200,得到10Khz的計數時鐘        
  243.         TIM4->DIER|=1<<0;                                                                 //允許更新中斷                                                                                      
  244.         TIM4->CR1|=0x01;                                                                  //使能定時器2
  245.         MY_NVIC_Init(3,3,TIM4_IRQn,2);                                                    //搶占3,子優先級3,組2(組2中優先級最低
  246.       }
  247. #endif
  248. /************** 初始化串口控制器 ****************************/
  249. /************** sysclk:系統時鐘(Mhz)***********************/
  250. void usmart_init(u8 sysclk)
  251. {
  252. #if USMART_ENTIMX_SCAN==1
  253.         Timer4_Init(1000,(u32)sysclk*100-1);                                              //分頻,時鐘為10K ,100ms中斷一次,注意,計數頻率必須為10Khz,以和runtime單位(0.1ms)同步.
  254. #endif
  255.         usmart_dev.sptype=1;                                                                    //十六進制顯示參數
  256. }               
  257. /********* 從str中獲取函數名,id,及參數信息 *******************/
  258. /********* *str:字符串指針. *********************************/
  259. /********* 返回值:0,識別成功;其他,錯誤代碼. ******************/
  260. u8 usmart_cmd_rec(u8*str)
  261. {
  262.         u8 sta,i,rval;                                                                    //狀態         
  263.         u8 rpnum,spnum;
  264.         u8 rfname[MAX_FNAME_LEN];                                                         //暫存空間,用于存放接收到的函數名  
  265.         u8 sfname[MAX_FNAME_LEN];                                                         //存放本地函數名
  266.         sta=usmart_get_fname(str,rfname,&rpnum,&rval);                                    //得到接收到的數據的函數名及參數個數         
  267.         if(sta)return sta;                                                                //錯誤
  268.         for(i=0;i<usmart_dev.fnum;i++)
  269.         {
  270.          sta=usmart_get_fname((u8*)usmart_dev.funs[i].name,sfname,&spnum,&rval);         //得到本地函數名及參數個數
  271.          if(sta)return sta;                                                              //本地解析有誤         
  272.          if(usmart_strcmp(sfname,rfname)==0)                                             //相等
  273.          {
  274.            if(spnum>rpnum)return USMART_PARMERR;                                         //參數錯誤(輸入參數比源函數參數少)
  275.            usmart_dev.id=i;                                                              //記錄函數ID.
  276.            break;                                                                        //跳出.
  277.          }        
  278.         }
  279.         if(i==usmart_dev.fnum)return USMART_NOFUNCFIND;                                          //未找到匹配的函數
  280.          sta=usmart_get_fparam(str,&i);                                                                                  //得到函數參數個數        
  281.         if(sta)return sta;                                                                                                                //返回錯誤
  282.         usmart_dev.pnum=i;                                                                                                                //參數個數記錄
  283.        return USMART_OK;
  284.      }
  285. //usamrt執行函數
  286. //該函數用于最終執行從串口收到的有效函數.
  287. //最多支持10個參數的函數,更多的參數支持也很容易實現.不過用的很少.一般5個左右的參數的函數已經很少見了.
  288. //該函數會在串口打印執行情況.以:"函數名(參數1,參數2...參數N)=返回值".的形式打印.
  289. //當所執行的函數沒有返回值的時候,所打印的返回值是一個無意義的數據.
  290. /***********************************************************/
  291. /***********************************************************/
  292. /***********************************************************/
  293. /***********************************************************/
  294. /***********************************************************/
  295.      void usmart_exe(void)
  296.      {
  297.         u8 id,i;
  298.         u32 res=0;                  
  299.         u32 temp[MAX_PARM];                                                               //參數轉換,使之支持了字符串
  300.         u8 sfname[MAX_FNAME_LEN];                                                         //存放本地函數名
  301.         u8 pnum,rval;
  302.         id=usmart_dev.id;
  303.         if(id>=usmart_dev.fnum)return;                                                    //不執行.
  304.         usmart_get_fname((u8*)usmart_dev.funs[id].name,sfname,&pnum,&rval);               //得到本地函數名,及參數個數
  305.         printf("\r\n%s(",sfname);                                                         //輸出正要執行的函數名
  306.         for(i=0;i<pnum;i++)                                                               //輸出參數
  307.         {
  308.           if(usmart_dev.parmtype&(1<<i))                                                  //參數是字符串
  309.           {
  310.           printf("%c",'"');                        
  311.           printf("%s",usmart_dev.parm+usmart_get_parmpos(i));
  312.           printf("%c",'"');
  313.           temp[i]=(u32)&(usmart_dev.parm[usmart_get_parmpos(i)]);
  314.           }
  315.            else                                                                                                                //參數是數字
  316.           {
  317.           temp[i]=*(u32*)(usmart_dev.parm+usmart_get_parmpos(i));
  318.           if(usmart_dev.sptype==SP_TYPE_DEC)printf("%lu",temp[i]);                      //10進制參數顯示
  319.           else printf("0X%X",temp[i]);                                                  //16進制參數顯示            
  320.          }
  321.          if(i!=pnum-1)printf(",");
  322.         }
  323.         printf(")");
  324.         usmart_reset_runtime();                                                                  //計時器清零,開始計時
  325.         switch(usmart_dev.pnum)
  326.         {
  327.                 case 0:                                                                         //無參數(void類型)                                                                                          
  328.                         res=(*(u32(*)())usmart_dev.funs[id].func)();
  329.                         break;
  330.             case 1:                                                                       //有1個參數
  331.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0]);
  332.                         break;
  333.             case 2:                                                                       //有2個參數
  334.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1]);
  335.                         break;
  336.             case 3:                                                                       //有3個參數
  337.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2]);
  338.                         break;
  339.             case 4:                                                                       //有4個參數
  340.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2],temp[3]);
  341.                         break;
  342.             case 5:                                                                       //有5個參數
  343.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2],temp[3],temp[4]);
  344.                         break;
  345.             case 6:                                                                       //有6個參數
  346.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2],temp[3],temp[4],\
  347.                         temp[5]);
  348.                         break;
  349.             case 7:                                                                       //有7個參數
  350.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2],temp[3],temp[4],\
  351.                         temp[5],temp[6]);
  352.                         break;
  353.             case 8:                                                                       //有8個參數
  354.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2],temp[3],temp[4],\
  355.                         temp[5],temp[6],temp[7]);
  356.                         break;
  357.             case 9:                                                                       //有9個參數
  358.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2],temp[3],temp[4],\
  359.                         temp[5],temp[6],temp[7],temp[8]);
  360.                         break;
  361.             case 10:                                                                      //有10個參數
  362.                         res=(*(u32(*)())usmart_dev.funs[id].func)(temp[0],temp[1],temp[2],temp[3],temp[4],\
  363.                         temp[5],temp[6],temp[7],temp[8],temp[9]);
  364.                         break;
  365.         }
  366.         usmart_get_runtime();                                                             //獲取函數執行時間
  367.         if(rval==1)                                                                       //需要返回值.
  368.         {
  369.                 if(usmart_dev.sptype==SP_TYPE_DEC)printf("=%lu;\r\n",res);                      //輸出執行結果(10進制參數顯示)
  370.                 else printf("=0X%X;\r\n",res);                                                  //輸出執行結果(16進制參數顯示)           
  371.         }else printf(";\r\n");                                                                        //不需要返回值,直接輸出結束
  372.         if(usmart_dev.runtimeflag)                                                              //需要顯示函數執行時間
  373.         {
  374.                 printf("Function Run Time:%d.%1dms\r\n",usmart_dev.runtime/10,usmart_dev.runtime%10);//打印函數執行時間
  375.         }        
  376. }
  377. /******************* usmart掃描函數 *********************************/
  378. /* 通過調用該函數,實現usmart的各個控制.該函數需要每隔一定時間被調用一次 */
  379. /* 以及時執行從串口發過來的各個函數. **********************************/
  380. /* 本函數可以在中斷里面調用,從而實現自動管理. **************************/
  381. /* 如果非ALIENTEK用戶,則USART_RX_STA和USART_RX_BUF[]需要用戶自己實現 **/
  382. void usmart_scan(void)
  383. {
  384.         u8 sta,len;  
  385.         if(USART_RX_STA&0x8000)                                                           //串口接收完成?
  386.         {                                          
  387.                 len=USART_RX_STA&0x3fff;                                                              //得到此次接收到的數據長度
  388.                 USART_RX_BUF[len]='\0';                                                                //在末尾加入結束符.
  389.                 sta=usmart_dev.cmd_rec(USART_RX_BUF);                                           //得到函數各個信息
  390.                 if(sta==0)usmart_dev.exe();                                                            //執行函數
  391.                 else
  392.                 {  
  393.                         len=usmart_sys_cmd_exe(USART_RX_BUF);
  394.                         if(len!=USMART_FUNCERR)sta=len;
  395.                         if(sta)
  396.                         {
  397.                                 switch(sta)
  398.                                 {
  399.                                         case USMART_FUNCERR:
  400.                                                 printf("函數錯誤!\r\n");                           
  401.                                                 break;        
  402.                                         case USMART_PARMERR:
  403.                                                 printf("參數錯誤!\r\n");                           
  404.                                                 break;                                
  405.                                         case USMART_PARMOVER:
  406.                                                 printf("參數太多!\r\n");                           
  407.                                                 break;               
  408.                                         case USMART_NOFUNCFIND:
  409.                                                 printf("未找到匹配的函數!\r\n");                           
  410.                                                 break;               
  411.                                 }
  412.                         }
  413.                 }
  414.                 USART_RX_STA=0;                                                                 //狀態寄存器清空            
  415.         }
  416. }

  417. #if USMART_USE_WRFUNS==1                                                                   //如果使能了讀寫操作
  418. /********************* 讀取指定地址的值 *********************/
  419. u32 read_addr(u32 addr)
  420. {
  421.         return *(u32*)addr;//        
  422. }
  423. /******************** 在指定地址寫入指定的值 *****************/
  424. void write_addr(u32 addr,u32 val)
  425. {
  426.         *(u32*)addr=val;         
  427. }
  428. #endif
復制代碼


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:404160 發表于 2020-1-13 20:31 | 只看該作者
結構;簡單的講,就是把N個長度的字節變量,按需要分段定義其可理解的變量。這樣使用起來簡單方便。還容易理解
回復

使用道具 舉報

板凳
ID:282850 發表于 2020-1-14 15:47 | 只看該作者
點亮一個LED是最好的學習方法,由深入淺的學習方法還是第一次聽到,如果小學講微積分、大學講+-×除,怕是教育要出問題的。吃包子時語言上可以說先吃第4個,最后吃第一個,但邏輯不對。更不能一口把所有包子全放嘴里再慢慢一個個下咽。
回復

使用道具 舉報

地板
ID:481073 發表于 2020-1-14 16:57 | 只看該作者
f556 發表于 2020-1-14 15:47
點亮一個LED是最好的學習方法,由深入淺的學習方法還是第一次聽到,如果小學講微積分、大學講+-×除,怕是 ...

emmmm,其實就是一堆配置文件,原子講的挺好的,你想想,要用串口,第一步肯定是配置串口,然后就是串口的工作方式,什么波特率,字節,校驗啥的,然后就是配置串口要用到的gpio口了,該是啥模式就選擇啥模式,這些東西都在結構體里面,在庫里面吧結構體找到了一個個寫就行了,這個串口多個重定向c的printf函數,這個參考下就行了。
回復

使用道具 舉報

5#
ID:680894 發表于 2020-1-14 19:59 | 只看該作者
51單片機功能少一些,當然學起來覺著好理解一些,不過STM32及其他芯片也不是很難,只是功能更多一些,相關配值多一些,多練練就習慣了!
回復

使用道具 舉報

6#
ID:351097 發表于 2020-1-15 11:18 | 只看該作者
建議提高一下c語言基礎
回復

使用道具 舉報

7#
ID:652775 發表于 2020-1-16 11:33 | 只看該作者
硬著頭皮去多看,時間長了,你就會感受到日積月累的力量了
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲精品免费在线观看 | 极品在线 | 精品视频久久久 | 婷婷综合色 | 综合色久| 色男人的天堂 | 日韩精品一区二区三区 | 亚洲国产精品一区二区久久 | 欧美理伦片在线播放 | 一区二区免费视频 | 99热国产精品 | 欧美精品在欧美一区二区少妇 | 欧美性影院 | 蜜桃视频在线观看免费视频网站www | 日日骚视频 | 日韩在线中文字幕 | 亚洲精品乱码久久久久久黑人 | 日韩和的一区二在线 | 亚洲精品一区二区冲田杏梨 | 亚洲成人毛片 | 美女久久久 | 欧美日韩国产免费 | 中文精品一区二区 | 日韩成人免费av | 亚洲理论在线观看电影 | 国产综合区 | 成人免费一区二区三区视频网站 | 国产一区二区三区 | 欧美成人免费电影 | 91麻豆精品国产91久久久久久久久 | 国产精品福利在线 | 国产高清视频一区二区 | 亚洲国产欧美日韩 | 欧美久久视频 | 人人色视频 | 四虎永久在线精品免费一区二 | 欧美一区2区三区4区公司二百 | av天天爽| 99精品免费在线观看 | 无码日韩精品一区二区免费 | 中文字幕在线中文 |