隨著微處理器的快速發(fā)展和廣泛的應用,數(shù)字通信網絡延伸到工業(yè)過程現(xiàn)場成為可能,產生了以微處理器為核心,使用集成電路代替常規(guī)電子線路,實施信息采集、顯示、處理、傳輸以及優(yōu)化控制等功能的智能設備。
引言
設備之間彼此通信、控制,在精度、可操作性以及可靠性、可維護性等都有更高的要求。由此,導致了現(xiàn)場總線的產生。1984年,現(xiàn)場總線的概念得到正式提出。IEC(International Electrotechnical Commission,國際電工委員會)對現(xiàn)場總線(Fieldbus)的定義為:現(xiàn)場總線是一種應用于生產現(xiàn)場,在現(xiàn)場設備之間、現(xiàn)場設備和控制裝置之間實行雙向、串形、多結點的數(shù)字通信技術。
現(xiàn)有的放開式數(shù)控系統(tǒng)實現(xiàn)方案主要采用pc機和數(shù)控系統(tǒng)結合的方法,pc機作為上位機實現(xiàn)較為復雜的網絡通信,人機交互等功能,數(shù)控系統(tǒng)作為下位機將上位機輸入的運行參數(shù)經過處理交給執(zhí)行部件執(zhí)行,同時將檢測系統(tǒng)的反饋信息上傳給上位機實現(xiàn)實時監(jiān)控,各個模塊之間協(xié)調工作互不干擾,給系統(tǒng)升級帶來了方便。
放開式系統(tǒng)動態(tài)控制器的核心是dsp,它具有運算速度快,支持復雜運動算法的特點,可以滿足高精度運動控制的要求,因此,以dsp為核心的多軸動態(tài)控制卡越來越廣泛地應用在運動控制系統(tǒng)中,將多軸動態(tài)控制卡插在pc機擴展槽上,就可以組成高精度運動控制系統(tǒng),位置反饋信號的采集、閉環(huán)控制計算及控制量的輸出均由動態(tài)控制卡完成,極大的提高了運算速度和控制響應速度,將工控機的資源從煩瑣的數(shù)據(jù)采集和計算中解決出來,從而可以更好的實施整個控制系統(tǒng)的管理。
作者經過綜合調研,采用ti公司的2407系列dsp作為微處理單元,采用pci總線作為并行總線與pc機進行通訊,同時采用現(xiàn)在比較流行的現(xiàn)場總線技術同現(xiàn)場設備進行通訊,所以這是一個基于現(xiàn)場總線和pci總線的智能動態(tài)控制器。
2 動態(tài)控制器的系統(tǒng)構成
2.1 現(xiàn)場總線
基于pci總線的動態(tài)控制器采用現(xiàn)場總線技術,解決了傳統(tǒng)串行總線傳輸速率低,響應速度慢,出錯率高等缺點,同時由于現(xiàn)場總線采用數(shù)字信號而不是傳統(tǒng)的模擬信號作為通信手段,解決了傳統(tǒng)數(shù)控系統(tǒng)中的難以解決的零漂問題,簡化了系統(tǒng)的實現(xiàn)方案,同時這種總線有利于放開式系統(tǒng)的發(fā)展。
can最早由德國BOSCH公司推出,它廣泛用于離散控制領域,其總線規(guī)范已被ISO國際標準組織制定為國際標準,得到了Intel、Motorola、NEC等公司的支持。CAN協(xié)議分為二層:物理層和數(shù)據(jù)鏈路層。CAN的信號傳輸采用短幀結構,傳輸時間短,具有自動關閉功能,具有較強的抗干擾能力。CAN支持多主工作方式,并采用了非破壞性總線仲裁技術,通過設置優(yōu)先級來避免沖突,通訊距離最遠可達10KM/5Kbps/s,通訊速率最高可達40M /1Mbp/s,網絡節(jié)點數(shù)實際可達110個。目前已有多家公司開發(fā)了符合CAN協(xié)議的通信芯片。
can是一種多主總線,通信介質可以是雙絞線、同軸電纜或光纖,通信速率可達1mb/s,該協(xié)議由數(shù)據(jù)鏈路層和物理層組成,數(shù)據(jù)鏈路層分為邏輯鏈路控制子層(lic)和媒體訪問控制子層(mac)。現(xiàn)在已形成該協(xié)議的國際標準(iso1898),can總線通信接口中集成了can協(xié)議的物理層和數(shù)據(jù)鏈路層功能,可完成對通信數(shù)據(jù)的幀處理(包括位填充、數(shù)據(jù)塊編碼、循環(huán)冗余校驗等)、can總線有can2.0a和can2.0b兩種協(xié)議,can協(xié)議的一個最大的特點是對通信數(shù)據(jù)塊進行編碼(取消了傳統(tǒng)的對站地址編碼),can協(xié)議采用crc校驗并提供相應的錯誤信息處理功能,保證了數(shù)據(jù)通信的可靠性。
can總線以其可靠性高、通信速率快、穩(wěn)定性好,抗干擾能力強,開發(fā)成本低等特點, 而被工控領域普遍采用,被公認為最有前途的現(xiàn)場總線之一。
2.2 pci 總線
作為目前微型計算機主流總線標準的pci總線,原來是專門為了提高系統(tǒng)數(shù)據(jù)傳輸性能,現(xiàn)在作為高性能外設接口,與傳統(tǒng)的isa總線相比,pci總線有以下特點:
突出的數(shù)據(jù)傳輸性能 總線寬度32位(可擴展到64位,)支持突發(fā)傳輸方式,pci總線規(guī)范2.0版支持3mhz總線操作,32位33mhz總線在讀寫操作中峰值傳輸速率達到132mb/s(isa最大傳輸速率8mb/s);
良好的兼容性能 pci總線部件和插卡的設計獨立于處理器, 定義了3.3-5v兩種信號環(huán)境,5-3.3v的組件技術可以是使電平平穩(wěn)過渡;
即插即用 每個pci設備上都有配置空間能實現(xiàn)自動配置,使系統(tǒng)bios和操作系統(tǒng)的系統(tǒng)層軟件能自動配置系統(tǒng)部件和插卡;
線主控和同步操作,pci總線接口芯片可以主控總線,其同步操作可以保證cpu和總線主控同時操作;
總線仲裁機制,pci總線仲裁能在另一個總線主設備在pci總線上執(zhí)行傳輸時發(fā)出,從而提供系統(tǒng)數(shù)據(jù)傳輸性能。
在pci總線的設計上采用了plx公司的產品pci9052,這是一種高性能的pci總線控制器,專門為開發(fā)pci板卡而設計的一種pci總線控制器,圖1是放開式數(shù)控系統(tǒng)總體結構框圖。
2.3 微處理芯片
動態(tài)控制器板卡上有一個高速dsp芯片作為運動控制模塊的控制器,該設計選擇it公司生產的tms320lf2407作為動態(tài)控制卡的控制芯片,由于tms320xx系列dsp芯片是專門為控制電機設計的一款高性能低價位的產品,同時作為控制電機的伺服控制系統(tǒng)也是采用的這款dsp芯片作為伺服控制器,所以具有良好的通訊和系統(tǒng)兼容性能,tms3201lf2407內部還有一個can控制器模塊,這樣就不需要另外選擇一個can控制器,簡化了電路設計,同時提高了系統(tǒng)性能。
由于dsp芯片和pc機都是控制器,他們對存儲器編址是不同的,為了統(tǒng)一編碼,在pci控制器和dsp之間要加一個雙口ram來連接2個控制器。idt7024是idt公司生產的一款雙口ram,他和普遍的ram不同之處是它有2個地址4單元,1個存儲單元,對于pc機來說他就對對應于一段內存單元,對于dsp來說他可以對應于一段片外存儲單元,這樣就解決了dsp和pc機之間的通信問題,本設計采用的是通用pc機加實時控制單元的遞階式結構。采用放開式數(shù)控系統(tǒng)上pc機的windows環(huán)境形成良好的人機界面,利用pc機的資源優(yōu)勢,放開式結構平臺(動態(tài)控制器)可以集成不同開發(fā)商提供的軟件并適合連網需要,且具有與硬件無關的特性,設備層高速度、高可靠性,標準化的數(shù)字通訊,可滿足用戶個性化要求且保證高性能、低成本。
3 系統(tǒng)硬件設計原理
基于can總線動態(tài)控制卡的硬件結構如圖2所示,從個人pc機中傳入的參數(shù)如:加工參數(shù),插補軌跡以及一些狀態(tài)信息,通過pci總線傳到pci控制器pci9052的高速緩存fifo中,pci9052作為總線主設備將pc機傳來的信息經過緩存最終存儲到雙口ramidt7024內,由于雙口ram映射為pc機的一部分內存地址,所以pc機就像操作內存一樣將信息存儲到雙口ram,等待dsp的讀取,dsp定時從雙口ram中讀取pc機傳來的各種控制信息,dsp的主要功能是根據(jù)pc機送來得插補信息,通過插補算法形成伺服控制模塊能夠接受的動態(tài)信息,通過can總線將運動信息傳遞到伺服控制器,通過伺服控制器來驅動伺服電機運動,從而控制數(shù)控機床的運動。#p#分頁標題#e#
在設計中由于pci9052,idt7024都是5v元件,tms2320lf2407屬于3.3v器件,同時pci插槽提供5v電源模塊,所以電路只使用了電壓轉換電路將5v信號轉變?yōu)?.3v信號,如圖2,由于dsp內嵌can控制器,所以外部只需要一個pcac82520t-can收發(fā)器就可以直接掛在can總線上進行通訊。
4 數(shù)控系統(tǒng)的軟件設計
放開式cac系統(tǒng)解決軟件公用的最主要措施是采用通用的操作系統(tǒng),本系統(tǒng)設計pci動態(tài)控制卡可以在windows90/2000/xp中文操作系統(tǒng)下正常工作,軟件框圖如圖3所示。
為了使系統(tǒng)達到控制要求,需要解決如下幾個關鍵問題:
(1)保證系統(tǒng)相應的實時性
系統(tǒng)對外界信息以足夠快的速度進行處理,并在一定的時間內作出響應,本控制系統(tǒng)是利用windows中斷保證實時響應;
(2)協(xié)調的進行多任務調度
cnc系統(tǒng)具有多種不同優(yōu)先級任務,要求系統(tǒng)軟件能合理,有序地調度這些任務的運行,多任務意味著多個任務能并行運行,調度的關鍵在于按照一定的優(yōu)先權,事件發(fā)生的順序合理的切換各任務的狀態(tài);
(3)提供任務通信機制
由于cnc系統(tǒng)中各任務并否是孤立的,任務之間要完成信息交換和資源共享,cnc系統(tǒng)的通信形式有兩種,互斥和同步,互斥是針對不可共享資源的訪問問題,如大多數(shù)外部設備和共享的可讀寫數(shù)據(jù)區(qū),同步是指任務之間的協(xié)同工作,任務之間的相對速度有不可預見性,必須由任務通信機制達到同步;
(4)提供定時和延時
定時和延時功能一般由時鐘提供,cnc系統(tǒng)大部分任務都是依據(jù)定時或延遲條件來激活。
5 驅動程序
5.1 獲取系統(tǒng)分配的配置資源
對于即插即用型設備,系統(tǒng)都是動態(tài)分配系統(tǒng)資源的,如何獲取系統(tǒng)分配給這些內存單元的地址是vxd驅動程序需要解決的首要問題。在pci的配制周期機制中,主橋路提供了兩個寄存器用于對配置空間的操作,第一個是配置空間基地址寄存器canfig-address,雙字地址是cf8h,第二個是配置空間數(shù)據(jù)緩沖寄存器config-data,地址是cfch,對配置空間的操作是通過輸入一個值到設備的config-data寄存器,在此之后如果對config-data寄存器進行讀寫操作,pci控制器就會將config-address寄存器中的值轉換成pci總線上所需要的配置周期。
5.2 vxd與應用程序的通訊
vxd運行在系統(tǒng)ring0級,處理系統(tǒng)底層設備,應用程序利用其提供的接口服務來處理硬件,windows允許vxd和應用程序之間進行雙向通信。
在windows中,win23應用程序對vxd的通訊方法只有一種,利用設備輸入輸出控制函數(shù)deviceiocontrol()來實現(xiàn),利用createfile()函數(shù)加載vxd獲得vxd設備句柄,如果調用成功,win32應用程序就可以調用deviceiocontrol()程序與vxd進行通訊。
vxd的命令代碼需要根據(jù)其固定格式進行定義,程序中共定義了2個命令代碼,分別用于對雙口靜態(tài)ram的讀寫操作和vxd對win32應用程序異步過程調用時回調函數(shù)地址傳輸。
另外,由于采用中斷方式對dsp處理的數(shù)據(jù)進行讀取,所以中斷事件發(fā)生時, 需要vxd異步通知win32應用程序,設計時在應用程序中創(chuàng)建了兩個線程,一個用于等待中斷事件,當中斷事件發(fā)生時,讀取dsp送到雙口ram中數(shù)據(jù),另一個用于顯示數(shù)據(jù)。
5.3 訪問i/o以及內存
在s599的串行存儲器中,將pci配置基礎地址寄存器badr1配置為4k,16位寄存器空間,badr2設置為8個自己的i/o空間,基地址寄存器badro對應s5933內部16個雙字節(jié)pci總線操作寄存器,當利用查找方式獲得配置空間數(shù)據(jù)時,即可得到存儲器空間基地址和i/o端口基地址。
5.4 處理中斷
當dsp處理數(shù)據(jù)寫滿2k的存儲器空間時pci將產生中斷,中斷信號從配置空間寄存器中讀出,pci設備分配的硬件中斷信號是共享中斷,必須使用類vsharedhardwareint的中斷通知事件處理函數(shù)onsharedhardwareint()。
6 應用程序的編寫
6.1 人機接口模塊
使用vc編寫基于pci總線動態(tài)控制器板卡的應用程序,主要利用設備輸入輸出控制函數(shù)deviceiocontrol(),將界面上對數(shù)控機床的各個參數(shù)轉換數(shù)據(jù)送到底層的vxd進行通信。
6.2 解決程序模塊
對從應用程序中人機界面模塊中傳入的參數(shù)進行解釋,完成將上位機輸入信息解釋成下位機dsp能夠執(zhí)行的語言,程序解釋模塊固化到pci板卡的dsp片內rom中。
6.3 plc接口模塊
實現(xiàn)pci控制卡與現(xiàn)場總線上的plc模塊之間的通訊,由于can總線的特點是可以將對plc模塊的控制作為一個應用模塊做在pci控制卡上,從而實現(xiàn)了模塊化控制。
6.4 插補模塊
在加工信息解釋的基礎上,調用運動學算法模塊,將運動平臺在操作空間的運動轉變?yōu)榭臻g的伺服運動,實時生成刀具的運動軌跡,并將各伺服軸的移動指令送給伺服模塊。
6.5 運動算法模塊
主要為伺服驅動提供逆解、速度映射算法,為加工狀態(tài)的實時仿真及精度補償提供正解算法。
7 結語
采用pc+動態(tài)控制卡模式,實現(xiàn)數(shù)控系統(tǒng)的放開式設計方法開發(fā)周期短,系統(tǒng)可靠性高,便于機床功能擴展,由于軟件采用了模塊化,同時基于組件技術,界面友好,操作方便,進行軟件升級以及用戶進行二次開發(fā)都比較方便。
轉載請注明出處。