blob: 796041ad2bb6d6ba2c42888fcb971dd6b6af4927 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
#!/usr/bin/env python3
#
# Simple pyprofibus example
#
# This example initializes an S7-315-2DP configured as slave,
# reads its input data and writes the data back to the module.
#
import sys
import pyprofibus
from pyprofibus import DpTelegram_SetPrm_Req, monotonic_time
master = None
try:
# Parse the config file.
config = pyprofibus.PbConf.fromFile("example_s7-315-2dp.conf")
# Create a PHY (layer 1) interface object
phy = config.makePhy()
# Create a DP class 1 master with DP address 1
master = pyprofibus.DPM1(phy = phy,
masterAddr = config.dpMasterAddr,
debug = True)
# Create a slave descriptions.
for slaveConf in config.slaveConfs:
gsd = slaveConf.gsd
# Create a slave description for an S7-315-2DP
slaveDesc = pyprofibus.DpSlaveDesc(identNumber = gsd.getIdentNumber(),
slaveAddr = slaveConf.addr)
# Create Chk_Cfg telegram
slaveDesc.setCfgDataElements(gsd.getCfgDataElements())
# Set User_Prm_Data
slaveDesc.setUserPrmData(gsd.getUserPrmData())
# Set various standard parameters
slaveDesc.setSyncMode(slaveConf.syncMode)
slaveDesc.setFreezeMode(slaveConf.freezeMode)
slaveDesc.setGroupMask(slaveConf.groupMask)
slaveDesc.setWatchdog(slaveConf.watchdogMs)
# Register the S7-315-2DP slave at the DPM
master.addSlave(slaveDesc)
# Initialize the DPM
master.initialize()
slaveDescs = master.getSlaveList()
# Cyclically run Data_Exchange.
inData = [0]
rtSum, runtimes, nextPrint = 0, [ 0, ] * 512, monotonic_time() + 1.0
while True:
start = monotonic_time()
# Run slave state machines.
for slaveDesc in slaveDescs:
outData = inData
inDataTmp = master.runSlave(slaveDesc, outData)
if inDataTmp is not None:
inData = inDataTmp
# Print statistics.
end = monotonic_time()
runtimes.append(end - start)
rtSum = rtSum - runtimes.pop(0) + runtimes[-1]
if end > nextPrint:
nextPrint = end + 3.0
sys.stderr.write("pyprofibus cycle time = %.3f ms\n" %\
(rtSum / len(runtimes) * 1000.0))
except pyprofibus.ProfibusError as e:
print("Terminating: %s" % str(e))
finally:
if master:
master.destroy()
|