《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > ARM7與FPGA在工業控制中的結合應用
ARM7與FPGA在工業控制中的結合應用
摘要: 工業控制中往往需要完成多通道故障檢測及多通道命令控制(這種多任務設置非常普遍),單獨的CPU芯片由于其外部控制接口數量有限而難以直接完成多路檢控任務,故利用ARM芯片與FPGA相結合
關鍵詞: FPGA ARM7 DSP 工業控制
Abstract:
Key words :

         工業控制中往往需要完成多通道故障檢測及多通道命令控制(這種多任務設置非常普遍),單獨的CPU芯片由于其外部控制接口數量有限而難以直接完成多路檢控任務,故利用ARM芯片與FPGA相結合來擴展檢控通道是一個非常好的選擇。這里介紹用Atmel公司ARM7處理器(AT91FR40162)和ALTERA公司的低成本FPGA芯片(cyclone2)結合使用完成多通道檢控任務的一種實現方法。

  各部分功能簡介
  圖1為此系統的結構連接框圖。如圖所示,ARM芯片與FPGA芯片之間通過數據總線、地址總線及讀寫控制線相連,而與終端PC則通過串口通信;FPGA與目標設備通過命令控制總線和故障檢測總線相連。


                                                                圖1 系統結構框圖

  1 故障檢測和命令控制部分
  故障檢測:檢測通道的故障(正常)信號以高(低)電平方式指示,其一旦有故障產生就會保持高電平不變直到故障排除。針對這種特征,在ARM控制器端采用定時中斷循環查詢方式來判斷故障通道的狀態。定時中斷程序通過對ARM 地址總線在FPGA中進行譯碼而順序鎖定被檢測通道的電平值,然后再經數據總線傳回ARM進行判斷,最后將判斷結果送至遠程終端。采用主機查詢方式而不采用故障中斷方式出于兩個原因:一方面是通常控制芯片外部中斷源有限(多數為4個外部中斷源),對于多目標中斷信號檢測顯然是困難的;另一方面,由于檢測通道或設備受到短時干擾而產生電平隨機反轉,造成故障中斷觸發,而中斷觸發后又無法在通道電平恢復正常時撤銷故障信號,故而形成虛假報警。
  命令控制:ARM芯片先判斷主控端發來的控制命令,然后通過地址總線和數據總線將命令狀態發送至經FPGA地址譯碼鎖定的控制通道上。
  2 ARM芯片與遠程檢測控制終端通信  

  由于只存在命令和故障狀態信號的收發,所以利用ARM的串口實現與遠程PC的通信,通信標準選為RS232標準。不過,在ARM芯片上要先將TTL電平通過MAX232芯片轉換為RS232電平標準,對于距離超過15m的全雙工通信,在發送接收兩端還要各加一對RS232轉RS422電平的轉換模塊,以增加通信距離。
  3 FPGA內部功能模塊說明
  FPGA內部檢測及控制電路結構關系如圖2所示。
                                          

                                     圖2  FPGA內部邏輯結構

  ARM芯片的ADDR2~0位地址線和片選使能信號一同進入譯碼器decode1進行地址譯碼后產生8路輸出(FPGA內部可設置一個最大輸出為256路的譯碼模塊,所以在實際應用中可擴展為更多通道),低4路用于命令發送通道,高4路用于故障檢測通道,讀寫使能信號控制數據總線。
  ARM芯片接收到發送信號編碼命令時,立即在串口接收中斷服務子程序中并送相應地址(通道編號)和數據(命令狀態)到FPGA中。譯碼器有效輸出作為相應通道D觸發器的鎖存時鐘,而數據狀態則被觸發器鎖定后作為所選通道的輸出完成相應控制。
  ARM芯片在定時中斷產生進入服務程序后對所有檢測通道輪流查詢,查詢到有通道故障時,故障信號結合選中通路信號經與非運算送往數據端口被讀取。
  FPGA程序設計注意問題
  1延時的配置
  通過地址總線和數據總線進行命令傳輸和故障檢測時,FPGA是作為ARM芯片的普通外設來使用的。而ARM芯片對外設訪問的速度要遠低于片內存儲器,所以要在ARM中設置訪問的正確等待周期。ARM中提供的延時周期為0~7個,通過調試即可找到外設合適的等待周期,此系統的等待周期根據實際測試設置為5個,具體的配置方法見ARM程序說明。
  2 讀寫使能信號的連接
  從圖2中可以看出,寫使能信號NWE及讀使能信號NRD應作為數據線(DATA0~5)的三態控制信號連接,即使在ARM芯片無其他外設時也不能缺省。因為ARM的上電加載程序時間要長于同一系統上FPGA的程序配置時間,而FPGA的檢測及控制通道與ARM芯片的數據總線相連,FPGA加載完成后數據總線會存有相應通道的邏輯電平值(不為三態),這就會導致ARM芯片在對片內Flash芯片燒寫程序或上電加載程序時與FPGA沖突(數據被邏輯鎖定),造成無法正確定位操作對象而使讀寫失敗。
ARM配置及應用程序說明

  1 處理器的資源分配

  ● 存儲器
  AT91FR40162內嵌一個256KB的SRAM,1024K個16位字組成的Flash存儲器。SRAM通過內部32位數據總線與ARM核相連,單周期訪問,Flash存儲器則通過外部總線訪問。
  ● 系統外圍
  EBI:外部總線控制接口,EBI可尋址64MB的空間,通過8個片選線(NCS0~NCS3獨立)和24位地址線訪問外設,地址線高4位與片選線(NCS4~7)復用,數據總線可配置成8/16位兩種模式與外設接口。

  PIO:并口控制器,PIO控制32根I/O線,多數為復用引腳,可通過編程選擇為通用或專用。

  AIC:先進中斷控制器,實現片內外圍中斷及4個外部中斷源中斷的管理,其外部中斷引腳與通用I/O復用。
  ● 用戶外圍
  USART0~1:串口收發控制器,支持8個數據位的發送,可以進行異步/同步傳輸選擇,其片外引腳與通用I/O復用。
  TC:定時/計數器,可以產生定時中斷和計數功能,其片外引腳與通用I/O復用。
  2 存儲器地址重映射后的空間分配

  在CPU上電后,都會從地址0開始第一條指令代碼的執行,而上電復位后0地址必須映射到NCS0片選所接的器件上,這里必須將NCS0連接到片內Flash上以加載初始化程序和應用程序。由于中斷和異常的入口地址是0~20H固定不變,它們的產生都是跳轉到0~20H之間相應的地址取程序執行,為了加快中斷響應,必須將0~20H地址映射到片內RAM區,所以在初始化的重映射命令執行(EB1_RCR的RCB位置1)后,內部RAM就映射到地址0,所有的中斷入口響應和堆棧操作都被映射到在RAM區進行。
                                         

  由于重映射主要是用于Flash和片內RAM的地址空間交換,所以片內外圍接口(EBI、USART、TC)對應的存儲器編程地址范圍在映射前后不發生改變,而訪問外設地址為重映射后所分配。重映射后地址分配如表1所示。
  3 應用接口的存儲器配置
  EBI存儲器:在8個EBI片選存儲器(EBI_CSR0~EBI_CSR7)中設置外設訪問參數。其中,32位存儲器中包括數據總線寬度8(16)設置,等待狀態數目1~7個周期設置,等待使能(不是使能)設置,片選使能(不使能)設置。這里將FPGA作為外設,使能NCS3(也可根據實際選擇其他空閑片選線),選擇總線寬度16,使能等待周期并設周期為5(根據調試選擇)。因默認NCS0為加載Flash片選線,而Flash為16位信號、7個等待周期,故需在EBI_CSR0中選擇16位總線寬度、7個等待周期并使能NCS0。
  AIC存儲器:AIC存儲器管理所有內外部中斷,對此存儲器的正確初始化賦值才會打開相應中斷。設定AIC工作參數:應用串口通信模式為異步模式,串口發送的數據位字符長度為8位,通信的波特率9600B/s,串口中斷優先級為6(中斷優先級由低到高0~7),接收發送通道使能。
  TC存儲器:定時中斷存儲器需要設定定時長度為1s(每1s產生中斷進行故障查詢),定時通道使能及軟件觸發模式,定時中斷優先級設為1。
  4 應用程序說明
?、?主程序
  #define AT91C_BASE_EBI       ((AT91PS_EBI)   0xFFE00000) //EBI基地址定義
  int main()
  {AT91F_EBI_OpenChipSelect (
        AT91C_BASE_EBI,  //地址指針                    
        0x3,            //片NCS3使能
        0x30000000+0x3f39); //片選存儲器初始化
         Usart_init();//初始化串口
      timer_init();//初始化定時器
         while(1){} //循環等待
  }
  ARM處理器在完成各寄存器初始化后進入應用主程序,在主程序中首先調用EBI接口使能函數來設置參數:在程序中設置存儲器基地址值(0xFFE00000),片選設置0x3(NCS3使能),NCS3的存儲器初始化;調用USART控制器函數初始化串口:打開串口,串口收發通道初始化,設定串口通信速率;調用定時中斷函數:打開定時中斷,設置定時中斷時間,設定觸發方式為軟件觸發;最后進入等待循環。
  ② 串口命令接收中斷服務程序
  #define USART0_INTERRUPT_LEVEL     6//設置中斷優先級為6
  #define AT91C_US_USMODE_NORMAL AT91C_US_CHMODE_NORMAL//*設置通信模式(NORMAL定義為異步模式)*//
  AT91PS_USART COM0=AT91C_BASE_US0;//設置COM0為收發口
  char message[4];
  //                 控制端串口中斷通信程序                //
  //*----------------------------------------------------------------------------*//
  void Usart0_c_irq_handler(AT91PS_USART USART_pt)//串口中斷處理函數
  {   volatile unsigned int *conp;unsigned int status;
 int time;
 volatile unsigned int i;
 status = USART_pt->US_CSR & USART_pt->US_IMR;//給狀態寄存器賦初值
 if ( status & AT91C_US_RXRDY)//接收通道寄存器判斷是否有數據
 {   
       AT91F_US_DisableIt(USART_pt,AT91C_US_RXRDY);//關閉接收通道準備好中斷
     AT91F_US_EnableIt(USART_pt,AT91C_US_ENDRX);//打開接收結束中斷
    AT91F_US_ReceiveFrame(USART_pt,(char*)(message),4);//調用接收數據數接收數據
      }
 if ( status & AT91C_US_ENDRX){
         AT91F_US_DisableIt(USART_pt,AT91C_US_ENDRX); // 關閉接收器傳送結束中斷
        { if((message[0]^0xff)==message[1])//判斷接收代碼
          {switch (message[0])
         {case  0x31 : {conp=(volatile unsigned int*)(0x1+0x30000000);//OPE1使能
         *conp=0x2;}; break;//0x31代碼送往OPE1端口
             case  0x30 : {conp=(volatile unsigned int*)(0x2+0x30000000);//OPE2使能
             *conp=0x1;}; break; // 0x30代碼送往OPE2端口
          case  0x11 : {conp=(volatile unsigned int*)(0x3+0x30000000);//OPE3使能
              *conp=0x2;};break;// 0x11代碼則往OPE3端口
             case  0x10 : {conp=(volatile unsigned int*)(0x4+0x30000000);//OPE4使能
             *conp=0x1;};break;  //0x10代碼送往OPE4端口          
        default:break;}
       }
       }
  以上程序為串口中斷服務程序,各函數語句說明參見注釋。中斷級別設置為6(高于定時中斷),這樣使命令發送優先于故障查詢(控制命令隨機出現而故障查詢總是循環進行);接收緩沖區message[4]數組類型必須設為動態分配,靜態數據分配會使處理器開辟數據緩沖區到Flash芯片中,從而引發在一個中斷處理程序中由于存取時間過長而導致串口收發超時的錯誤。因為篇幅有限,其他程序不再一一敘述。
  在ARM應用程序的編寫中,應該盡量少的在主函數內使用循環操作,主函數主要完成各接口控制器應用初始化,因為主函數不間斷循環操作不但會增加功耗,而且長時間頻繁切換于中斷服務和主循環之間會造成程序運行的不穩定,所以能用定時中斷完成的循環操作盡量用中斷完成。
 
  結語

  ARM芯片控制功能結合FPGA靈活的多硬件接口模擬特性在工程上體現出的其獨特的優勢,已發展為一種流行的硬件架構模式,隨著芯片功能的不斷強大,這種優勢將使其用途更廣,對任務處理變得更加靈活高效。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          亚洲免费观看高清在线观看| 久久久噜噜噜| 国产精品亚洲不卡a| 久久国产免费| 亚洲性av在线| 黄色在线成人| 香港久久久电影| 欧美成人一区在线| 欧美激情一区二区久久久| 欧美日韩一区二区三区| 亚洲高清精品中出| 久久在线免费视频| 亚洲最快最全在线视频| 销魂美女一区二区三区视频在线| 欧美日本精品一区二区三区| 一区二区三区日韩欧美精品| 国产日韩欧美精品综合| 国产欧美精品国产国产专区| 欧美影片第一页| 亚洲婷婷综合色高清在线| 99在线热播精品免费99热| 国产一区二区日韩| 国产精品久久久久秋霞鲁丝| 欧美三级韩国三级日本三斤| 国产精品高清免费在线观看| 欧美福利视频在线| 女女同性女同一区二区三区91| 精品动漫av| 亚洲欧美国产毛片在线| 欧美在线视频一区二区三区| 9l视频自拍蝌蚪9l视频成人| 蜜臀av性久久久久蜜臀aⅴ四虎| 9国产精品视频| 亚洲国产精品成人| 国产精品99久久久久久久女警| 久久综合成人精品亚洲另类欧美| 久久九九免费视频| 女仆av观看一区| 亚洲久久成人| 国产一区二区高清| 国产综合第一页| 国产精品乱子乱xxxx| 国产精品久久久久久久第一福利| 亚洲免费一在线| 韩国在线视频一区| 久久精品国产免费看久久精品| 国产精品视频自拍| 亚洲线精品一区二区三区八戒| 亚洲国产mv| 久久久爽爽爽美女图片| 欧美成年人在线观看| 国产一区二区三区久久久| 亚洲福利在线视频| 国产精品视频免费观看www| 老司机午夜精品视频| 欧美日韩另类综合| 欧美另类高清视频在线| 国产日韩高清一区二区三区在线| 欧美成人综合| 女人色偷偷aa久久天堂| 欧美日韩日日骚| 亚洲欧美偷拍卡通变态| 欧美激情精品久久久六区热门| 欧美日韩一区二区在线观看视频| 久久久另类综合| 在线一区观看| 国产自产女人91一区在线观看| 亚洲高清视频一区二区| 欧美日一区二区三区在线观看国产免| 亚洲在线观看免费| 亚洲免费电影在线观看| 日韩视频―中文字幕| 一区二区三区四区五区精品视频| 另类成人小视频在线| 久久综合九色| 国产精品日韩欧美| 欧美另类久久久品| 国产视频在线观看一区| 亚洲福利在线视频| 欧美在线观看日本一区| 午夜国产不卡在线观看视频| 欧美视频在线看| 亚洲主播在线播放| 欧美日韩午夜激情| 久久成人综合网| 免费亚洲一区二区| 欧美日韩免费一区| 欧美天堂亚洲电影院在线观看| 国产精品色网| 欧美影院在线| 国产精品免费一区豆花| 久久久爽爽爽美女图片| 欧美一区视频| 一区二区三区.www| 欧美日韩国产一中文字不卡| 欧美日韩色一区| 欧美成人精品三级在线观看| 亚洲欧美久久久久一区二区三区| 最新国产成人av网站网址麻豆| 国产欧美综合在线| 欧美日韩一区二区免费视频| 亚洲色图在线视频| 国产精品―色哟哟| 国产精品高清网站| 欧美成人蜜桃| 欧美成人黄色小视频| 欧美日韩国产综合久久| 欧美激情一区二区三级高清视频| 欧美资源在线| 欧美成人精品福利| 国产午夜亚洲精品理论片色戒| 欧美一区二区高清| 欧美三级乱人伦电影| 国产精品女人毛片| 欧美亚洲免费| 亚洲欧洲日本mm| 久久九九免费视频| 欧美一区免费视频| 国产日韩欧美一区二区三区四区| 亚洲国产精品美女| 国产一区二区三区四区| 国产亚洲午夜| 欧美女激情福利| 久久国产一区| 国产精品一区二区三区乱码| 亚洲免费高清视频| 在线观看91精品国产麻豆| 好男人免费精品视频| 久久亚洲综合| 久久精品1区| 欧美日本三级| 欧美中文字幕| 影音先锋中文字幕一区| 亚洲欧美综合一区| 麻豆精品精品国产自在97香蕉| 激情伊人五月天久久综合| 国产精品女同互慰在线看| 亚洲人成人99网站| 欧美日韩精品一区二区天天拍小说| 午夜精品视频在线观看一区二区| 欧美视频1区| 国产欧美成人| 亚洲人午夜精品免费| 亚洲精品一品区二品区三品区| 国产亚洲欧美日韩精品| 国产老肥熟一区二区三区| 欧美韩日精品| 日韩视频不卡| 欧美日韩免费观看一区三区| 在线免费精品视频| 99re6热在线精品视频播放速度| 欧美性大战久久久久久久| 永久域名在线精品| 欧美电影专区| 亚洲一区二区高清视频| 午夜日韩在线| 国产综合色一区二区三区| 欧美一区激情| 在线精品一区二区| 欧美午夜视频在线观看| 国产日韩一区二区三区在线播放| 亚洲欧美国产77777| 国产精品久久久久久久电影| 又紧又大又爽精品一区二区| 夜夜夜久久久| 韩国成人福利片在线播放| 狠狠色丁香久久婷婷综合_中| 国产日韩欧美综合在线| 亚洲毛片一区| 欧美成人网在线| 伊人狠狠色j香婷婷综合| 国产精品久久久久免费a∨| 久久精品视频播放| 欧美激情精品久久久久久| 亚洲激情视频在线观看| 欧美亚洲成人精品| 亚洲激精日韩激精欧美精品| 嫩草伊人久久精品少妇av杨幂| 国产专区精品视频| 国产精品av久久久久久麻豆网| 国产婷婷一区二区| 久久久久久久综合色一本| 噜噜噜在线观看免费视频日韩| 在线成人www免费观看视频| 欧美亚洲一区三区| 亚洲视频在线一区观看| 欧美日本一道本| 伊人激情综合| 欧美午夜精品| 亚洲欧美日本日韩| 红桃视频成人| 欧美一区二区三区久久精品| 噜噜噜91成人网| 欧美激情一级片一区二区| 一卡二卡3卡四卡高清精品视频| 欧美在线高清视频| 国产亚洲精品久| 麻豆精品在线观看| 极品少妇一区二区三区| 正在播放欧美一区| 国产精品初高中精品久久| 欧美日韩国产欧美日美国产精品| 女人香蕉久久**毛片精品| 精品成人国产在线观看男人呻吟| 亚洲素人一区二区| 亚洲一区免费在线观看| 欧美一区二区三区精品电影| 性刺激综合网| 蜜桃av一区| 日韩五码在线| 黄网站色欧美视频| 亚洲国产视频一区| 欧美a级片网| 亚洲第一网站免费视频| 黄色资源网久久资源365| 亚洲在线播放电影| 性欧美激情精品| 1024成人| 一本色道久久综合亚洲精品小说| 欧美精品18+| 国产精品任我爽爆在线播放| 精品成人在线观看| 久久国产夜色精品鲁鲁99| 亚洲精品国产精品乱码不99| 国产精品久久久久久久久久免费看| 欧美黄色aa电影| 亚洲欧美日韩在线一区| 欧美日本乱大交xxxxx| 国产精品亚洲一区二区三区在线| 亚洲日本一区二区三区| 亚洲视频第一页| 欧美一区二区在线| 久久狠狠亚洲综合| 一区在线播放视频| 136国产福利精品导航网址应用| 麻豆精品精品国产自在97香蕉| 狠色狠色综合久久| 国产精品国产三级国产普通话三级| 99在线观看免费视频精品观看| 亚洲一区二区三区乱码aⅴ| 亚洲茄子视频| 久久欧美肥婆一二区| 欧美日本亚洲韩国国产| 久久亚洲一区二区三区四区| 亚洲国产精品久久久久秋霞蜜臀| 91久久精品国产91久久性色| 亚洲少妇最新在线视频| 欧美日韩视频一区二区三区| 国产精品无人区| 久久久久**毛片大全| 国产精品扒开腿做爽爽爽软件| 99视频一区| 黑人操亚洲美女惩罚| 国产小视频国产精品| 韩日欧美一区| 日韩视频永久免费观看| 欧美极品在线播放| 国产自产女人91一区在线观看| 亚洲国产欧美另类丝袜| 亚洲一区二区三区在线看| 欧美护士18xxxxhd| 欧美一区在线看| 在线看无码的免费网站| 久久综合九色欧美综合狠狠| 久久av最新网址| 欧美电影在线观看| 欧美日韩成人一区二区三区| 欧美日韩亚洲三区| 国产乱人伦精品一区二区| 经典三级久久| 亚洲第一级黄色片| 亚洲精品一区二区三区蜜桃久| 狠狠干综合网| 欧美成人激情视频| 欧美日韩黄色一区二区| 亚洲精品美女久久7777777| 亚洲午夜精品视频| 国产精品影视天天线| 日韩一级二级三级| 麻豆九一精品爱看视频在线观看免费| 亚洲免费av电影| 久久三级福利| 久久久噜噜噜久久中文字免| 欧美精品久久久久久久| 免费成年人欧美视频| 午夜在线视频一区二区区别| 精品99视频| 久久一区二区三区国产精品| 午夜精品久久久久久久男人的天堂| 欧美人成在线| 国产精品伦理| 久久国产夜色精品鲁鲁99| 久久久久国产精品一区三寸| 日韩天堂在线观看| 亚洲高清精品中出| 国精品一区二区三区| 亚洲综合久久久久| 久久精品一区二区三区不卡牛牛| 欧美gay视频| 免费一级欧美片在线播放| 国产欧美一区二区精品忘忧草| 国产精品福利久久久| 香蕉成人久久| 激情久久中文字幕| 美日韩精品免费观看视频| 久久久噜噜噜久久中文字免| 欧美激情第五页| 宅男精品导航| 蜜乳av另类精品一区二区| 美女视频一区免费观看| 欧美一区二区三区精品| 国产日韩精品在线观看| 久久综合伊人| 国内精品久久久| 午夜精品成人在线视频| 欧美激情综合亚洲一二区| 免费成人美女女| 亚洲一区二区黄色| 嫩草国产精品入口| 中日韩男男gay无套| 亚洲黄色片网站| 久久亚洲欧美| 亚洲人成人一区二区三区| 欧美一区二区三区免费观看视频| 在线精品视频一区二区| 在线视频精品| 一本色道久久综合亚洲精品不| 亚洲大片av|