傳感器

在VB中訪問NETLINK并讀寫S7300 PLC數(shù)據(jù)

ainet.cn   2007年10月24日

無(wú)錫市北辰自動(dòng)化技術(shù)有限公司 張鵬 2007-10-16

 

一、概述

Hilscher NETLINK用于將西門子MPI協(xié)議轉(zhuǎn)換為以太網(wǎng)TCP/IP協(xié)議,并提供公開的無(wú)需授權(quán)的驅(qū)動(dòng)函數(shù)庫(kù)。

NETLINK有三種應(yīng)用:

1、對(duì)于僅僅需要STEP7編程監(jiān)控和WINCC監(jiān)控,安裝IBHNET127驅(qū)動(dòng)即可,該驅(qū)動(dòng)安裝后將在控制面板的Set PG/PC Interface中添加IBHNet MPI/PPI/Profibus三個(gè)驅(qū)動(dòng)連接;將STEP7(S7 ONLINE)和WINCC(MPI)的訪問點(diǎn)指向以上驅(qū)動(dòng)連接即可。

2、對(duì)于第三方組態(tài)軟件(如KingView、iFix等)通過NETLINK訪問PLC,選擇我公司開發(fā)的OPCServer。

3、對(duì)于VB或者VC++(6.0以上版本)的自行開發(fā)界面,有兩種方法實(shí)現(xiàn)通訊:

l          調(diào)用Hilscher提供的IP Driver驅(qū)動(dòng)函數(shù)庫(kù)進(jìn)行通訊;

l          使用winsock控件進(jìn)行通訊;

 

本文對(duì)在VB6.0中通過Hilscher IP Driver驅(qū)動(dòng)庫(kù)讀寫S7300/400 PLC數(shù)據(jù)的基本開發(fā)步驟作簡(jiǎn)要描述,具體資料可以參考NETLINK光盤netDEVICE System Software中的和文件,該光盤可到 頁(yè)面中下載。

 

二、平臺(tái)和配置

1、平臺(tái):WINDOW2000+SP4,Microsoft VB6.0;

2、軟件和驅(qū)動(dòng)安裝:Hilscher SYCON軟件和IP Driver;

3、硬件要求:NETLINK電纜一根,西門子S7300 CPU一臺(tái)(如CPU314),以太網(wǎng)交換機(jī)一臺(tái)(如TP-LINK),以太網(wǎng)電纜;

4、系統(tǒng)配置:如下圖所示

 

三、NETLINK參數(shù)配置

如上圖所示,將計(jì)算機(jī)網(wǎng)卡的IP地址配置為,將NETLINK的RJ45端口鏈接到交換機(jī)端口上,另一端插入CPU314的MPI通訊口,NETLINK是由CPU314的MPI口供電的。如果CPU上已經(jīng)連接了其他監(jiān)控設(shè)備如觸摸屏,則可以選用西門子帶編程口的網(wǎng)絡(luò)插頭。

NETLINK鏈接到MPI端口后的三分鐘內(nèi)(上電三分鐘內(nèi))運(yùn)行[開始]-[程序]-[Hilscher IP Driver]-[NetIdent Demo Program],點(diǎn)擊[Start Poll]按鈕自動(dòng)查找網(wǎng)絡(luò)上的NETLINK,找到后將會(huì)顯示NETLINK信息,NETLINK出廠默認(rèn)IP地址為,選擇顯示的NETLINK并點(diǎn)擊[Set IP]按鈕,設(shè)置IP地址為;如果軟件找不到NETLINK,請(qǐng)用PING命令檢查網(wǎng)絡(luò)是否鏈接正確。

注意1:通過NetIdent設(shè)定的IP地址是臨時(shí)的,在NETLINK再次上電后將自動(dòng)恢復(fù)到原來的IP地址;

注意2:NETLINK上電的三分鐘內(nèi)允許通過NetIdent設(shè)定其IP地址,三分鐘后設(shè)定將被拒絕;

設(shè)定好NETLINK的IP地址后運(yùn)行[開始]-[程序]-[SyCon System Configurator],新建項(xiàng)目并添加NETLINK設(shè)備,雙擊NETLINK并設(shè)定網(wǎng)絡(luò)參數(shù),IP地址設(shè)為,選擇自動(dòng)檢測(cè)接口和自動(dòng)速率識(shí)別,NETLINK的MPI地址設(shè)定為1(注意不要和MPI網(wǎng)絡(luò)上其他站點(diǎn)地址沖突);設(shè)定好參數(shù)后將其下載到NETLINK。(具體可以參考《NetLINK和IBHNet驅(qū)動(dòng)在SIEMENS STEP7 WINCC中的使用說明.doc》中的描述)

注意3:通過SYCON軟件設(shè)定的IP地址是永久固定的,在NETLINK再次上電后不會(huì)改變;

四、IP Driver參數(shù)配置

運(yùn)行[開始]-[程序]-[Hilscher IP Driver]-[IP Driver Setup],在Connection 0中輸入NETLINK的IP地址:、1099、TCP、Client、5000;

運(yùn)行[開始]-[程序]-[Hilscher IP Driver]-[IP Driver Test],在菜單[Connection select]中選擇Connection 0,連接后進(jìn)行其他菜單的測(cè)試,如[Driver Info]等,如果測(cè)試正常說明IP Driver已連接到NETLINK。

 

五、VB應(yīng)用

應(yīng)用舉例:

1、   按下[循環(huán)啟動(dòng)]按鈕后周期性讀取MW0的數(shù)值(間隔100ms),直到按下[停止]按鈕。

2、   按下[寫入新值]按鈕命令將新值寫入MW0。

3、   [復(fù)位NETLINK]按鈕初始化NETLINK。

 

演示界面如下圖所示:

 

開發(fā)步驟:

1、    新建VB EXE工程,將NETLINK光盤中Api\Demo\VBASIC32\模板文件復(fù)制到VB工程中并取消只讀屬性;然后添加到工程中,打開模板,加入以下常數(shù)申明:

'新增常數(shù)

Public Const TASK_TDT_UINT8 = 5

Public Const TASK_TFC_READ = 1

Public Const TASK_TFC_WRITE = 2

2、    新建模塊Module1,添加以下公共變量和API函數(shù):

Public Const usSize = 288                   '消息長(zhǎng)度常數(shù)=288

Public SndMsgRead As MSG_STRUC              '讀取MW0數(shù)據(jù)的消息

Public SndMsgWrite As MSG_STRUC             '寫MWO數(shù)據(jù)的消息

Public SndMsgReset As MSG_STRUC             '復(fù)位NETLINK的消息

Public RcvMsg As MSG_STRUC                  '接收消息

'內(nèi)存拷貝API

Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)

3、    Form1代碼窗口中添加讀寫控制變量、三個(gè)消息初始化函數(shù)、NETLINK鏈接和讀寫函數(shù)(請(qǐng)參考文件):

Dim bNetLink_Connected As Boolean   'NETLINK鏈接標(biāo)記

Dim bStartRead As Boolean           '開始循環(huán)讀取標(biāo)記

Dim bWrite As Boolean               '寫數(shù)據(jù)標(biāo)記

 

'初始化讀MW0數(shù)據(jù)的消息

Private Function Initial_SndMsgRead()

= 3          '接收號(hào)=3

= 255        '發(fā)送號(hào)=255

= 8          '讀數(shù)據(jù)長(zhǎng)度=8

= 0          '消息號(hào)

SndMsgRead.a = 0           '應(yīng)答號(hào)=0

SndMsgRead.f = 0           '錯(cuò)誤號(hào)=0

SndMsgRead.b = 0           '命令碼=16#33(M區(qū)數(shù)據(jù))

SndMsgRead.e = 0           '擴(kuò)展號(hào)=0

(0) = 2     'S7300 CPU的MPI地址=2

(1) = 0     '數(shù)據(jù)區(qū)=0

(2) = 0     'M區(qū)起始地址=0(起始地址 MOD 256)

(3) = 0     'M區(qū)起始地址=0(起始地址 / 256)

(4) = 0     '數(shù)據(jù)索引=0(僅用于DB區(qū))

(5) = 2     '讀取的字節(jié)數(shù)=2 (MW0)

(6) = TASK_TDT_UINT8    '數(shù)據(jù)類型=TASK_TDT_UINT8(字節(jié))

(7) = TASK_TFC_READ     '功能號(hào)=TASK_TFC_READ(讀數(shù)據(jù))

End Function

 

'初始化寫MW0數(shù)據(jù)的消息

Private Function Initial_SndMsgWrite()

= 3          '接收號(hào)

= 255        '發(fā)送號(hào)

= 10         '寫數(shù)據(jù)長(zhǎng)度=10

= 0          '消息號(hào)

SndMsgWrite.a = 0           '應(yīng)答號(hào)=0

SndMsgWrite.f = 0           '錯(cuò)誤號(hào)=0

SndMsgWrite.b = 0           '命令碼=16#33(M區(qū)數(shù)據(jù))

SndMsgWrite.e = 0           '擴(kuò)展號(hào)=0

(0) = 2     'S7300 CPU的MPI地址=2

(1) = 0     '數(shù)據(jù)區(qū)=0

(2) = 0     'M區(qū)起始地址=0(起始地址 MOD 256)

(3) = 0     'M區(qū)起始地址=0(起始地址 / 256)

(4) = 0     '數(shù)據(jù)索引=0(僅用于DB區(qū))

(5) = 0     '要寫的字節(jié)數(shù)=2 (MW0)

(6) = TASK_TDT_UINT8    'TASK_TDT_UINT8

(7) = TASK_TFC_WRITE    'TASK_TFC_WRITE

(8) = 0     '待寫數(shù)據(jù)低字節(jié)=0

(9) = 0      '待寫數(shù)據(jù)高字節(jié)=0

End Function

 

'初始化復(fù)位NETLINK消息

Private Function Initial_SndMsgReset()

= 0         '接收號(hào)=0(NETLINK 系統(tǒng))

= 255       '發(fā)送號(hào)

= 1         '數(shù)據(jù)長(zhǎng)度

= 1         '消息號(hào)

SndMsgReset.a = 0          '應(yīng)答號(hào)=0

SndMsgReset.f = 0          '錯(cuò)誤號(hào)=0

SndMsgReset.b = 1          '命令碼=1

SndMsgReset.e = 0          '擴(kuò)展號(hào)=0

(0) = 1     '=1

End Function

 

'NETLINK鏈接

Private Function NetLINK_Connect()

Dim sRet As Integer

sRet = DevOpenDriver(0)                     '打開驅(qū)動(dòng)

If sRet = DRV_NO_ERROR Then

    sRet = DevInitBoard(0, 0)               '初始化板卡

    If sRet = DRV_NO_ERROR Then

        bNetLink_Connected = True           '設(shè)置NETLINK鏈接標(biāo)記

    Else

        MsgBox "找不到NETLINK!", vbCritical + vbOKOnly, "錯(cuò)誤"

        DevExitBoard 0                      '退出板卡

        DevCloseDriver 0                    '關(guān)閉驅(qū)動(dòng)

    End If

Else

    MsgBox "找不到NETLINK驅(qū)動(dòng)!", vbCritical + vbOKOnly, "錯(cuò)誤"

    DevExitBoard 0

    DevCloseDriver 0

End If

End Function

 

'讀MW0數(shù)據(jù)

Private Function ReadValue()

Dim sRet As Integer, RcvData(0 To 1) As Byte, Val_INT16 As Integer

sRet = DevPutMessage(0, SndMsgRead, 500)    '發(fā)送讀取數(shù)據(jù)的消息

If sRet = DRV_NO_ERROR Then                 '如果發(fā)送消息無(wú)錯(cuò)誤

    sRet = DevGetMessage(0, usSize, RcvMsg, 500)    '接收返回消息

    '如果接收無(wú)錯(cuò)誤且消息無(wú)錯(cuò)誤且功能號(hào)為讀取消息則接收消息中的MW0數(shù)據(jù)

    If sRet = DRV_NO_ERROR And RcvMsg.f = 0 And (7) = TASK_TFC_READ Then

        RcvData(0) = (9)         '注意高低字節(jié)的顛到

        RcvData(1) = (8)

        CopyMemory Val_INT16, RcvData(0), 2

        = Val_INT16

    End If

End If

End Function

 

'寫MW0數(shù)據(jù)

Private Function WriteValue()

Dim sRet As Integer, SndData(0 To 1) As Byte, Val_INT16 As Integer

Val_INT16 = Int()

CopyMemory SndData(0), Val_INT16, 2

(8) = SndData(1)            '注意高低字節(jié)的顛到

(9) = SndData(0)

sRet = DevPutMessage(0, SndMsgWrite, 500)   '發(fā)送寫數(shù)據(jù)的消息

If sRet = DRV_NO_ERROR Then                 '如果發(fā)送消息無(wú)錯(cuò)誤

    sRet = DevGetMessage(0, usSize, RcvMsg, 500)    '接收返回消息

End If

bWrite = False                              '復(fù)位寫值標(biāo)志

End Function

4、    Form1添加定時(shí)器Timer1,設(shè)定周期為100ms;在Timer1的執(zhí)行事件中添加以下代碼:

'定時(shí)器1的執(zhí)行代碼

Private Sub Timer1_Timer()

If bNetLink_Connected = False Then  '如果NetLink沒有鏈接則退出定時(shí)器執(zhí)行

    Exit Sub

End If

If bWrite = True Then               '如果有寫值請(qǐng)求

    WriteValue                      '寫MW0值

ElseIf bStartRead = True Then       '否則檢查是否啟動(dòng)了讀循環(huán)

    ReadValue                       '讀MW0值

End If

End Sub

5、    添加[循環(huán)讀取]、[停止]、[寫入新值]、[復(fù)位NETLINK]按鈕的動(dòng)作

'循環(huán)讀取按鈕

Private Sub Command_read_Click()

If bNetLink_Connected = False Then  '如果NETLINK未鏈接

    NetLINK_Connect                 '鏈接NETLINK

End If

If bNetLink_Connected = True Then   '如果已鏈接

    bStartRead = True               '啟動(dòng)循環(huán)讀

End If

End Sub

 

'停止按鈕

Private Sub Command_stop_Click()

bStartRead = False

End Sub

 

'寫入新值按鈕

Private Sub Command_set_Click()

If IsNumeric() Then

    bWrite = True

Else

    MsgBox "設(shè)定值錯(cuò)誤,范圍:-32768至32767", vbExclamation + vbOKOnly, "格式錯(cuò)誤"

End If

End Sub

 

'復(fù)位NETLINK按鈕

Private Sub Command_reset_Click()

Dim sRet As Integer

If bStartRead = True Then

    MsgBox "復(fù)位NETLINK前請(qǐng)先停止循環(huán)讀取。", vbInformation + vbOKOnly, "提示"

Else

    sRet = DevPutMessage(0, SndMsgReset, 500)       '發(fā)送復(fù)位NETLINK的消息

End If

End Sub

6、    Form1的Load事件中添加初始化代碼:

'Form1裝載

Private Sub Form_Load()

bStartRead = False

bWrite = False

bNetLink_Connected = False

= 0

= 0

Initial_SndMsgRead          '初始化讀取數(shù)據(jù)消息

Initial_SndMsgWrite         '初始化寫值消息

Initial_SndMsgReset         '初始化復(fù)位消息

NetLINK_Connect             '鏈接NETLINK

End Sub

 

六、注意事項(xiàng)

1、   注意發(fā)送消息中的數(shù)據(jù)起始地址的高低字節(jié)顛到和接收消息中數(shù)據(jù)區(qū)的高低字節(jié)顛到;

2、   定時(shí)器事件在操作系統(tǒng)繁忙時(shí)容易被中斷執(zhí)行,可以適當(dāng)提高進(jìn)程和線程的優(yōu)先級(jí)來保證數(shù)據(jù)的更新速率,在Form_Load()中添加以下代碼:

Dim hThread As Long, hProcess As Long

hThread = GetCurrentThread

hProcess = GetCurrentProcess

SetThreadPriority hThread, THREAD_PRIORITY_HIGHEST

SetPriorityClass hProcess, HIGH_PRIORITY_CLASS

Module1中添加以下聲明:

Public Const THREAD_BASE_PRIORITY_IDLE = -15

Public Const THREAD_BASE_PRIORITY_LOWRT = 15

Public Const THREAD_BASE_PRIORITY_MIN = -2

Public Const THREAD_BASE_PRIORITY_MAX = 2

Public Const THREAD_PRIORITY_LOWEST = THREAD_BASE_PRIORITY_MIN

Public Const THREAD_PRIORITY_HIGHEST = THREAD_BASE_PRIORITY_MAX

Public Const THREAD_PRIORITY_BELOW_NORMAL = (THREAD_PRIORITY_LOWEST + 1)

Public Const THREAD_PRIORITY_ABOVE_NORMAL = (THREAD_PRIORITY_HIGHEST - 1)

Public Const THREAD_PRIORITY_IDLE = THREAD_BASE_PRIORITY_IDLE

Public Const THREAD_PRIORITY_NORMAL = 0

Public Const THREAD_PRIORITY_TIME_CRITICAL = THREAD_BASE_PRIORITY_LOWRT

Public Const HIGH_PRIORITY_CLASS = &H80

Public Const IDLE_PRIORITY_CLASS = &H40

Public Const NORMAL_PRIORITY_CLASS = &H20

Public Const REALTIME_PRIORITY_CLASS = &H100

 

Public Declare Function SetThreadPriority Lib "kernel32" (ByVal hThread As Long, ByVal nPriority As Long) As Long

Public Declare Function SetPriorityClass Lib "kernel32" (ByVal hProcess As Long, ByVal dwPriorityClass As Long) As Long

3、   無(wú)論是讀取數(shù)據(jù)還是寫數(shù)據(jù),發(fā)送和接收消息函數(shù)必須成對(duì)出現(xiàn);

4、   在實(shí)際的通訊中如果網(wǎng)絡(luò)中斷(譬如交換機(jī)斷電,插拔網(wǎng)絡(luò)插頭)將會(huì)導(dǎo)致發(fā)送和接收消息函數(shù)出錯(cuò),其返回值sRet大于等于10000(網(wǎng)絡(luò)錯(cuò)誤),此時(shí)需要主動(dòng)發(fā)出NETLINK復(fù)位消息;發(fā)出復(fù)位消息后一般需要等待5秒鐘后再次進(jìn)行鏈接;

5、   在每次嘗試NETLINK鏈接前為了避免找不到NETLINK導(dǎo)致的驅(qū)動(dòng)函數(shù)超時(shí)返回,可以先采用NetIdent協(xié)議(參考文件,使用Winsock控件)廣播網(wǎng)絡(luò)上的NETLINK,找到NETLINK后再嘗試鏈接,這樣可以提高通訊效率;

6、   一次讀取地址連續(xù)的數(shù)據(jù)包(不要超過240個(gè)字節(jié))比多次讀取單個(gè)數(shù)據(jù)的效率要高的多;

7、   發(fā)送和返回的響應(yīng)消息的消息號(hào)Nr是對(duì)應(yīng)的,可以用Nr來判斷多個(gè)讀寫任務(wù)的響應(yīng)消息;

8、   如果一臺(tái)計(jì)算機(jī)需要同時(shí)訪問多個(gè)NETLINK通訊,建議采用VC++6.0開發(fā),采用多線程技術(shù);

 

七、聯(lián)系我們

無(wú)錫市北辰自動(dòng)化技術(shù)有限公司

江蘇省滴翠路100號(hào)無(wú)錫市國(guó)家工業(yè)設(shè)計(jì)園創(chuàng)意園A幢903

電話:0510-85166823,85162669,聯(lián)系人:王海波,張鵬

傳真:0510-85166813

Email:,網(wǎng)址:

(轉(zhuǎn)載)

標(biāo)簽:VB NETLINK S7300 PLC數(shù)據(jù) 我要反饋 
泰科電子ECK、ECP系列高壓直流接觸器白皮書下載
世強(qiáng)
優(yōu)傲機(jī)器人下載中心
億萬(wàn)克
專題報(bào)道