forked from mbuesch/pyprofibus
-
Notifications
You must be signed in to change notification settings - Fork 0
/
example_et200s.py
executable file
·91 lines (77 loc) · 2.82 KB
/
example_et200s.py
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
81
82
83
84
85
86
87
88
89
90
91
#!/usr/bin/env python3
#
# Simple pyprofibus example
#
# This example initializes an ET-200S slave, reads input
# data and writes the data back to the module.
#
# The hardware configuration is as follows:
#
# v--------------v----------v----------v----------v----------v
# | IM 151-1 | PM-E | 2 DO | 2 DO | 4 DI |
# | STANDARD | DC24V | DC24V/2A | DC24V/2A | DC24V |
# | | | | | |
# | | | | | |
# | ET 200S | | | | |
# | | | | | |
# | | | | | |
# | 6ES7 | 6ES7 | 6ES7 | 6ES7 | 6ES7 |
# | 151- | 138- | 132- | 132- | 131- |
# | 1AA04- | 4CA01- | 4BB30- | 4BB30- | 4BD01- |
# | 0AB0 | 0AA0 | 0AA0 | 0AA0 | 0AA0 |
# ^--------------^----------^----------^----------^----------^
#
import pyprofibus
def main(watchdog=None):
master = None
try:
# Parse the config file.
config = pyprofibus.PbConf.fromFile("example_et200s.conf")
# Create a DP master.
master = config.makeDPM()
# Create the slave descriptions.
outData = {}
for slaveConf in config.slaveConfs:
slaveDesc = slaveConf.makeDpSlaveDesc()
# Set User_Prm_Data
dp1PrmMask = bytearray((pyprofibus.dp.DpTelegram_SetPrm_Req.DPV1PRM0_FAILSAFE,
pyprofibus.dp.DpTelegram_SetPrm_Req.DPV1PRM1_REDCFG,
0x00))
dp1PrmSet = bytearray((pyprofibus.dp.DpTelegram_SetPrm_Req.DPV1PRM0_FAILSAFE,
pyprofibus.dp.DpTelegram_SetPrm_Req.DPV1PRM1_REDCFG,
0x00))
slaveDesc.setUserPrmData(slaveConf.gsd.getUserPrmData(dp1PrmMask=dp1PrmMask,
dp1PrmSet=dp1PrmSet))
# Register the ET-200S slave at the DPM
master.addSlave(slaveDesc)
# Set initial output data.
outData[slaveDesc.name] = bytearray((0x00, 0x00))
# Initialize the DPM
master.initialize()
# Cyclically run Data_Exchange.
while True:
# Write the output data.
for slaveDesc in master.getSlaveList():
slaveDesc.setOutData(outData[slaveDesc.name])
# Run slave state machines.
handledSlaveDesc = master.run()
# Get the in-data (receive)
if handledSlaveDesc:
inData = handledSlaveDesc.getInData()
if inData is not None:
# In our example the output data shall be a mirror of the input.
outData[handledSlaveDesc.name][0] = inData[0] & 3
outData[handledSlaveDesc.name][1] = (inData[0] >> 2) & 3
# Feed the system watchdog, if it is available.
if watchdog is not None:
watchdog()
except pyprofibus.ProfibusError as e:
print("Terminating: %s" % str(e))
return 1
finally:
if master:
master.destroy()
return 0
if __name__ == "__main__":
import sys
sys.exit(main())