[.Net Micro Framework PortingKit-03]デバッグ初歩:LEDランプ点灯


前回の記事「STM 3210 Eプラットフォーム構築」では、STM 3210の基本プラットフォームを構築し、コンパイル済みなので、次はMDKによるダウンロードデバッグを検討します.
私たちはシート外SRAMを使ったので、MDKスクリプトを書いて、3つの機能を実現しなければなりません.1つはSRAMの初期化、2つはミラーファイルのダウンロード、3つはPCポインタの設定です.
EM-TM 3210 Eランダムディスクにはいくつかの開発ボードのテストエンジニアリングがあるので、マニュアルを見る必要はありません.まず、コードの中で収穫があるかどうかを見てみましょう.テストエンジニアリングの起動コードstm 32 f 10 x_vector.sでは、シート外SRAM初期化コードを見つけることができます.具体的な内容は以下の通りです.

  
  
  
  
  1. ; FSMC Bank1 NOR/SRAM3 is used for the STM3210E-EVAL, if another Bank is   
  2.  
  3. ; required, then adjust the Register Addresses  
  4.  
  5.    
  6.  
  7. ; Enable FSMC clock  
  8.  
  9.                                             LDR R0,= 0x00000114   
  10.  
  11.                                             LDR R1,= 0x40021014  
  12.  
  13.                                             STR R0,[R1]                       
  14.  
  15.                
  16.  
  17. ; Enable GPIOD, GPIOE, GPIOF and GPIOG clocks  
  18.  
  19.                                             LDR R0,= 0x000001E0  
  20.  
  21.                                             LDR R1,= 0x40021018  
  22.  
  23.                                             STR R0,[R1]         
  24.  
  25.    
  26.  
  27. ; SRAM Data lines, NOE and NWE configuration   
  28.  
  29. ; SRAM Address lines configuration   
  30.  
  31. ; NOE and NWE configuration     
  32.  
  33. ; NE3 configuration   
  34.  
  35. ; NBL0, NBL1 configuration   
  36.  
  37.    
  38.  
  39.                                             LDR R0,= 0x44BB44BB   
  40.  
  41.                                             LDR R1,= 0x40011400  
  42.  
  43.                                             STR R0,[R1]               
  44.  
  45.                                       
  46.  
  47.                                             LDR R0,= 0xBBBBBBBB   
  48.  
  49.                                             LDR R1,= 0x40011404  
  50.  
  51.                                             STR R0,[R1]               
  52.  
  53.                                       
  54.  
  55.                                             LDR R0,= 0xB44444BB   
  56.  
  57.                                             LDR R1,= 0x40011800  
  58.  
  59.                                             STR R0,[R1]               
  60.  
  61.                                       
  62.  
  63.                                             LDR R0,= 0xBBBBBBBB   
  64.  
  65.                                             LDR R1,= 0x40011804  
  66.  
  67.                                             STR R0,[R1]               
  68.  
  69.                                       
  70.  
  71.                                             LDR R0,= 0x44BBBBBB   
  72.  
  73.                                             LDR R1,= 0x40011C00  
  74.  
  75.                                             STR R0,[R1]          
  76.  
  77.    
  78.  
  79.                                             LDR R0,= 0xBBBB4444   
  80.  
  81.                                             LDR R1,= 0x40011C04  
  82.  
  83.                                             STR R0,[R1]          
  84.  
  85.    
  86.  
  87.                                             LDR R0,= 0x44BBBBBB  
  88.  
  89.                                             LDR R1,= 0x40012000  
  90.  
  91.                                             STR R0,[R1]               
  92.  
  93.    
  94.  
  95.                                             LDR R0,= 0x44444B44  
  96.  
  97.                                             LDR R1,= 0x40012004  
  98.  
  99.                                             STR R0,[R1]        
  100.  
  101.                                               
  102.  
  103. ; FSMC Configuration     
  104.  
  105. ; Enable FSMC Bank1_SRAM Bank   
  106.  
  107.    
  108.  
  109.                                             ;LDR R0,= 0x00001011  
  110.  
  111.                                            ;LDR R1,= 0xA0000010  
  112.  
  113.                                            ;STR R0,[R1]       
  114.  
  115.    
  116.  
  117.                                            ;LDR R0,= 0x00000200   
  118.  
  119.                                            ;LDR R1,= 0xA0000014  
  120.  
  121.                                            ;STR R0,[R1]  
  122.  
  123.                                                         
  124.  
  125.                                             LDR R0,= 0x00001000  
  126.  
  127.                                            LDR R1,= 0xA0000010  
  128.  
  129.                                            STR R0,[R1]        
  130.  
  131.    
  132.  
  133.                                            LDR R0,= 0x00000200   
  134.  
  135.                                            LDR R1,= 0xA0000014  
  136.  
  137.                                            STR R0,[R1]        
  138.  
  139.                                                         
  140.  
  141.                                             LDR R0,= 0x0FFFFFFF  
  142.  
  143.                                            LDR R1,= 0xA0000114  
  144.  
  145.                                            STR R0,[R1]        
  146.  
  147.                                                         
  148.  
  149.                                             LDR R0,= 0x00001001  
  150.  
  151.                                            LDR R1,= 0xA0000010  
  152.  
  153.                                            STR R0,[R1]          
  154.  
  155.    
  156.  

では、これをサンプルとして、スクリプトファイルConfigを作成します.ini、最終的な内容は以下の通りです.

  
  
  
  
  1. // SRAM3 0x68000000 - 0x68020000      
  2.  
  3. FUNC void InitSRAM3(void)  
  4.  
  5. {  
  6.  
  7.    // FSMC  
  8.  
  9.    _WDWORD(0x40021014,0x00000114);  
  10.  
  11.    // FSMC GPIO  
  12.  
  13.    _WDWORD(0x40021018,0x000001E0);  
  14.  
  15.    
  16.  
  17.    // SRAM ,NOE NWE  
  18.  
  19.    //SRAM  
  20.  
  21.    //NOE NWE  
  22.  
  23.    //NE3  
  24.  
  25.    //NBL0,NBL1  
  26.  
  27.    _WDWORD(0x40011400,0x44BB44BB);  
  28.  
  29.    _WDWORD(0x40011404,0xBBBBBBBB);  
  30.  
  31.    _WDWORD(0x40011800,0xB44444BB);  
  32.  
  33.    _WDWORD(0x40011804,0xBBBBBBBB);     
  34.  
  35.    _WDWORD(0x40011C00,0x44BBBBBB);  
  36.  
  37.    _WDWORD(0x40011C04,0xBBBB4444);  
  38.  
  39.    _WDWORD(0x40012000,0x44BBBBBB);  
  40.  
  41.    _WDWORD(0x40012004,0x44444B44);  
  42.  
  43.    
  44.  
  45.    //FSMC  
  46.  
  47.    //  FSMC Bank1_SRAM Bank  
  48.  
  49.    _WDWORD(0xA0000010,0x00001000);  
  50.  
  51.    _WDWORD(0xA0000014,0x00000200);  
  52.  
  53.    _WDWORD(0xA0000114,0x0FFFFFFF);  
  54.  
  55.    _WDWORD(0xA0000010,0x00001001);  
  56.  
  57. }  
  58.  
  59.    
  60.  
  61. InitSRAM3();  
  62.  
  63. exec("LOAD C:\\MicroFramework_CortexM3\\BuildOutput\\THUMB2\\MDK3.1\\le\\RAM\\debug\\STM3210E\\bin\\NativeSample.axf INCREMENTAL");  
  64.  
  65. PC = 0x20001000;  
  66.  

 
ダウンロードに追わないで、LEDランプが点滅するコードを作成します.
私たちはいます.\Solutions\STM3210E\NativeSample\NativeSample.cppファイルには、次のコードが追加されます.

  
  
  
  
  1. typedef volatile unsigned long  vu32;  
  2.  
  3. typedef unsigned long  u32;  
  4.  
  5. typedef unsigned short  u16;  
  6.  
  7. typedef struct 
  8.  
  9. {  
  10.  
  11.   vu32 CRL;  
  12.  
  13.   vu32 CRH;  
  14.  
  15.   vu32 IDR;  
  16.  
  17.   vu32 ODR;  
  18.  
  19.   vu32 BSRR;  
  20.  
  21.   vu32 BRR;  
  22.  
  23.   vu32 LCKR;  
  24.  
  25. } GPIO_TypeDef;  
  26.  
  27.    
  28.  
  29. #define PERIPH_BASE           ((u32)0x40000000)  
  30.  
  31. #define APB2PERIPH_BASE       (PERIPH_BASE + 0x10000)  
  32.  
  33. #define GPIOF_BASE            (APB2PERIPH_BASE + 0x1C00)  
  34.  
  35. #define GPIOF                 ((GPIO_TypeDef *) GPIOF_BASE)  
  36.  
  37. #define GPIO_Pin_6                 ((u16)0x0040)   
  38.  
  39. #define GPIO_Pin_7                 ((u16)0x0080)   
  40.  
  41.    
  42.  
  43. void ApplicationEntryPoint()  
  44.  
  45. {   
  46.  
  47.      //..................  
  48.  
  49.      
  50.  
  51.     //  
  52.  
  53.     u32 GPIO_Pin = GPIO_Pin_6|GPIO_Pin_7;  
  54.  
  55.     u32 pinpos = 0x00,pos = 0x00,pinmask = 0x00;  
  56.  
  57.     u32 tmpreg = GPIOF->CRL;  
  58.  
  59.     for (int pinpos = 0x00; pinpos < 0x08; pinpos++)  
  60.  
  61.     {  
  62.  
  63.       pos = ((u32)0x01) << pinpos;  
  64.  
  65.       if ((GPIO_Pin & pos) == pos)  
  66.  
  67.       {  
  68.  
  69.         pos = pinpos << 2;  
  70.  
  71.         //Clear the corresponding low control register bits  
  72.  
  73.         pinmask = ((u32)0x0F) << pos;  
  74.  
  75.         tmpreg &= ~pinmask;       
  76.  
  77.                 //Write the mode configuration in the corresponding bits   
  78.  
  79.                 tmpreg |= ((u32)0x3) << pos;  
  80.  
  81.       }  
  82.  
  83.     }  
  84.  
  85.     GPIOF->CRL = tmpreg;  
  86.  
  87.    
  88.  
  89.     //  
  90.  
  91.     while(TRUE)  
  92.  
  93.     {  
  94.  
  95.        GPIOF->BSRR = GPIO_Pin_6;  
  96.  
  97.           GPIOF->BSRR = GPIO_Pin_7;  
  98.  
  99.        for(long i=0;i<1000000;i++);  
  100.  
  101.        GPIOF->BRR = GPIO_Pin_6;  
  102.  
  103.           GPIOF->BRR = GPIO_Pin_7;  
  104.  
  105.           for(long i=0;i<1000000;i++);  
  106.  
  107.     }  
  108.  
  109. }  
  110.  

では、MDKにCortex-M 3ベースのプロジェクトを新規作成し、iniファイルを作成してからデバッグを開始します(MDKの詳細なデバッグ方法は、関連ドキュメントを参照してください.MDKのローカライズが優れているので、簡単にできます).デバッグ中のMDKインタフェースを次に示します.
 
 
そしてEM-STM 3210 E開発ボードを見て、ハッ!D 1とD 2のLEDが点滅していることがわかります.
しかし、あまり早く喜ばないでください.私たちが今完成した仕事は、万里の長征の第一歩で、もっと煩わしい複雑な仕事が後ろにあります.Cortex-M 3アーキテクチャのチップを選んだので、現在.Net Micro Frameworkではサポートされていません.重要な問題はCortex-M 3の割り込みアーキテクチャがARM 7とARM 9と大きく異なり、割り込みベクトルテーブルの位置も必ずしも0アドレスの先頭に置くとは限らず、NVICによって構成され、この開発ボードのメモリが小さいため、関連コードはNor Flashに置いて起動することである.Net Micro Frameworkの慣習は異なるので、私たちは自分で多くのコードを再構築し、修正して、私たちの開発ボードを正常に動作させる必要があります(ただし、Net Micro Frameworkの初心者もあまり心配しないでください.ARM 7またはARM 9アーキテクチャに基づくチップを選択すれば、あなたの仕事は簡単になります).
次に、割り込みベクトルテーブルの作成、起動コードの修正、元の割り込みに関するコードの調整、クロック初期化、NVIC初期化、FMSC初期化、SRAM初期化、シリアル初期化、IO駆動開発、Nand Flash駆動開発、I 2 C駆動開発、SPI駆動開発、LED駆動開発、LCD駆動開発の順に行います.
道は長くて、私は上下して求めます--実は埋め込み式の開発は挑戦と楽しみに満ちていることです!
 
 
本文は“葉帆工房”のブログから出て、転載して作者と連絡してください!