mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-12 08:02:04 +01:00
388 lines
15 KiB
Markdown
388 lines
15 KiB
Markdown
|
# PLCLogo Binding
|
||
|
|
||
|
This binding provides native support of Siemens LOGO! PLC devices.
|
||
|
Communication with LOGO! is done via Moka7 library.
|
||
|
Currently only two devices are supported: `0BA7` (LOGO! 7) and `0BA8` (LOGO! 8).
|
||
|
Additionally multiple devices are supported.
|
||
|
Different families of LOGO! devices should work also, but was not tested now due to lack of hardware.
|
||
|
Binding works nicely at least 100ms polling rate, if network connection is stable.
|
||
|
|
||
|
## Pitfalls
|
||
|
|
||
|
- Changing of block parameter while running the binding may kill your LOGO!, so that program flashing via LOGO! SoftComort
|
||
|
will be required. Furthermore programs within LOGO! SoftComfort and LOGO! itself will differ, so that online simulation
|
||
|
will not work anymore without program synchronisation.
|
||
|
|
||
|
- Flashing the LOGO! while running the binding may crash the network interface of your LOGO!. Before flashing the LOGO!
|
||
|
with LOGO! SoftComfort stop openHAB service. If network interface is crashed, no reader could be created for this
|
||
|
device. See troubleshooting section below how to recover.
|
||
|
|
||
|
## Discovery
|
||
|
|
||
|
Siemens LOGO! devices can be manually discovered by sending a request to every IP on the network.
|
||
|
This functionality should be used with caution, because it produces heavy load to the operating hardware.
|
||
|
For this reason, the binding does not do an automatic background discovery, but discovery can be triggered manually.
|
||
|
|
||
|
## Bridge configuration
|
||
|
|
||
|
Every Siemens LOGO! PLC is configured as bridge:
|
||
|
|
||
|
```
|
||
|
Bridge plclogo:device:<DeviceId> [ address="<ip>", family="<0BA7/0BA8>", localTSAP="0x<number>", remoteTSAP="0x<number>", refresh=<number> ]
|
||
|
```
|
||
|
|
||
|
| Parameter | Type | Required | Default | Description |
|
||
|
| ---------- | :-----: | :--------: | :-------: | ---------------------------------------------------------------- |
|
||
|
| address | String | Yes | | IP address of the LOGO! PLC. |
|
||
|
| family | String | Yes | | LOGO! family to communicate with. Can be `0BA7` or `0BA8` now. |
|
||
|
| localTSAP | String | Yes | | TSAP (as hex) is used by the local instance. Check configuration |
|
||
|
| | | | | in LOGO!Soft Comfort. Common used value is `0x3000`. |
|
||
|
| remoteTSAP | String | Yes | | TSAP (as hex) of the remote LOGO! PLC, as configured by |
|
||
|
| | | | | LOGO!Soft Comfort. Common used value is `0x2000`. |
|
||
|
| refresh | Integer | No | 100ms | Polling interval, in milliseconds. Is used for query the LOGO!. |
|
||
|
|
||
|
Be sure not to use the same values for localTSAP and remoteTSAP, if configure more than one LOGO!
|
||
|
|
||
|
## Thing configuration
|
||
|
|
||
|
Binding supports four types of things: digital, analog, memory and datetime.
|
||
|
|
||
|
### Digital Things
|
||
|
|
||
|
The configuration pattern for digital things is:
|
||
|
|
||
|
```
|
||
|
Thing digital <ThingId> "Label" @ "Location" [ kind="<kind>", force=<true/false> ]
|
||
|
```
|
||
|
|
||
|
| Parameter | Type | Required | Default | Description |
|
||
|
| --------- | :-----: | :--------: | :-------: | ------------------------------------------------------------ |
|
||
|
| kind | String | Yes | | Blocks kind |
|
||
|
| force | Boolean | No | false | Send current value to openHAB, independent if changed or not |
|
||
|
|
||
|
Follow block kinds are allowed for digital things:
|
||
|
|
||
|
| Type | `0BA7` | `0BA8` |
|
||
|
| -------------- | :----: | ------ |
|
||
|
| Input | `I` | `I` |
|
||
|
| Output | `Q` | `Q` |
|
||
|
| Marker | `M` | `M` |
|
||
|
| Network input | | `NI` |
|
||
|
| Network output | | `NQ` |
|
||
|
|
||
|
### Analog Things
|
||
|
|
||
|
The configuration pattern for analog things is:
|
||
|
|
||
|
```
|
||
|
Thing analog <ThingId> "Label" @ "Location" [ kind="<kind>", threshold=<number>, force=<true/false> ]
|
||
|
```
|
||
|
|
||
|
| Parameter | Type | Required | Default | Description |
|
||
|
| --------- | :-----: | :--------: | :-------: | ------------------------------------------------------------- |
|
||
|
| kind | String | Yes | | Blocks kind |
|
||
|
| threshold | Integer | No | 0 | Send current value to openHAB, if changed more than threshold |
|
||
|
| force | Boolean | No | false | Send current value to openHAB, independent if changed or not |
|
||
|
|
||
|
Follow block kinds are allowed for analog things:
|
||
|
|
||
|
| Type | `0BA7` | `0BA8` |
|
||
|
| -------------- | :----: | ------ |
|
||
|
| Input | `AI` | `AI` |
|
||
|
| Output | `AQ` | `AQ` |
|
||
|
| Marker | `AM` | `AM` |
|
||
|
| Network input | | `NAI` |
|
||
|
| Network output | | `NAQ` |
|
||
|
|
||
|
### Memory Things
|
||
|
|
||
|
The configuration pattern for analog things is:
|
||
|
|
||
|
```
|
||
|
Thing memory <ThingId> "Label" @ "Location" [ block="<name>", threshold=<number>, force=<true/false> ]
|
||
|
```
|
||
|
|
||
|
Follow block names are allowed for memory things:
|
||
|
|
||
|
| Type | `0BA7` | `0BA8` |
|
||
|
| ----- | :---------------: | ----------------- |
|
||
|
| Bit | `VB[0-850].[0-7]` | `VB[0-850].[0-7]` |
|
||
|
| Byte | `VB[0-850]` | `VB[0-850]` |
|
||
|
| Word | `VW[0-849]` | `VW[0-849]` |
|
||
|
| DWord | `VD[0-847]` | `VD[0-847]` |
|
||
|
|
||
|
Parameter `threshold` will be taken into account for Byte, Word and DWord, i.e Number items, only.
|
||
|
|
||
|
### DateTime Things
|
||
|
|
||
|
The configuration pattern for datetime things is:
|
||
|
|
||
|
```
|
||
|
Thing datetime <ThingId> "Label" @ "Location" [ block="<name>", type=<type>, force=<true/false> ]
|
||
|
```
|
||
|
|
||
|
Follow block names are allowed for datetime things:
|
||
|
|
||
|
| Type | `0BA7` | `0BA8` |
|
||
|
| ----- | :---------: | ----------- |
|
||
|
| Word | `VW[0-849]` | `VW[0-849]` |
|
||
|
|
||
|
If parameter `type` is `"date"`, then the binding will try to interpret incoming data as calendar date.
|
||
|
The time this case will be taken from openHAB host.
|
||
|
If `type` is set to `"time"`, then incoming data will be tried to interpret as time of day.
|
||
|
The date this case will be taken from openHAB host.
|
||
|
|
||
|
### Pulse Things
|
||
|
|
||
|
The configuration pattern for pulse things is:
|
||
|
|
||
|
```
|
||
|
Thing pulse <ThingId> "Label" @ "Location" [ block="<name>", observe="<name>", pulse=<number> ]
|
||
|
```
|
||
|
|
||
|
Follow block names are allowed for pulse things:
|
||
|
|
||
|
| Type | `0BA7` | `0BA8` |
|
||
|
| ----- | :---------------: | ----------------- |
|
||
|
| Bit | `VB[0-850].[0-7]` | `VB[0-850].[0-7]` |
|
||
|
|
||
|
Follow observed block names are allowed for pulse things:
|
||
|
|
||
|
| Type | `0BA7` | `0BA8` |
|
||
|
| ----- | :---------------: | ----------------- |
|
||
|
| Bit | `VB[0-850].[0-7]` | `VB[0-850].[0-7]` |
|
||
|
| Bit | `I[1-24]` | `I[1-24]` |
|
||
|
| Bit | `Q[1-16]` | `Q[1-20]` |
|
||
|
| Bit | `M[1-27]` | `M[1-64]` |
|
||
|
| Bit | | `NI[1-64]` |
|
||
|
| Bit | | `NQ[1-64]` |
|
||
|
|
||
|
If `observe` is not set or set equal `block`, simply pulse with length `pulse` milliseconds is send to `block`.
|
||
|
If `observe` is set and differ from `block`, binding will wait for value change on `observe` and send then a pulse with length `pulse` milliseconds to block.
|
||
|
Please note, update rate for change detection depends on bridge refresh value.
|
||
|
For both use cases: if `block` was `0` then `1` is send and vice versa.
|
||
|
|
||
|
## Channels
|
||
|
|
||
|
### Bridge
|
||
|
|
||
|
Each device have currently three channels `diagnostic`, `rtc` and `weekday`:
|
||
|
|
||
|
```
|
||
|
channel="plclogo:device:<DeviceId>:diagnostic"
|
||
|
channel="plclogo:device:<DeviceId>:rtc"
|
||
|
channel="plclogo:device:<DeviceId>:weekday"
|
||
|
```
|
||
|
|
||
|
Channels `diagnostic` and `weekday` supports `String` items. Channel `diagnostic` contains the last diagnostic message reported by LOGO!.
|
||
|
Channel `weekday` contains current day of the week.
|
||
|
The value is provided by LOGO!.
|
||
|
Channel `rtc` supports `DateTime` items only. Since Siemens `0BA7` (LOGO! 7) devices will not transfer any useful data for this channel, local time of openHAB host will be used.
|
||
|
Rather for Siemens `0BA8` (LOGO! 8) devices, the data will be read from PLC.
|
||
|
Since the smallest resolution provided by LOGO! is one second, `rtc` channel will be tried to update with the same rate.
|
||
|
|
||
|
### Digital
|
||
|
|
||
|
Format pattern for digital channels is
|
||
|
|
||
|
```
|
||
|
channel="plclogo:digital:<DeviceId>:<ThingId>:<Channel>"
|
||
|
```
|
||
|
|
||
|
Dependent on configured LOGO! PLC and thing kind, follow channels are available:
|
||
|
|
||
|
| Kind | `0BA7` | `0BA8` | Item |
|
||
|
| ---- | :-------: | :--------: | --------- |
|
||
|
| `I` | `I[1-24]` | `I[1-24]` | `Contact` |
|
||
|
| `Q` | `Q[1-16]` | `Q[1-20]` | `Switch` |
|
||
|
| `M` | `M[1-27]` | `M[1-64]` | `Switch` |
|
||
|
| `NI` | | `NI[1-64]` | `Contact` |
|
||
|
| `NQ` | | `NQ[1-64]` | `Switch` |
|
||
|
|
||
|
### Analog
|
||
|
|
||
|
Format pattern for analog channels is
|
||
|
|
||
|
```
|
||
|
channel="plclogo:analog:<DeviceId>:<ThingId>:<Channel>"
|
||
|
```
|
||
|
|
||
|
Dependent on configured LOGO! PLC and thing kind, follow channels are available:
|
||
|
|
||
|
| Kind | `0BA7` | `0BA8` | Item |
|
||
|
| ----- | :--------: | :---------: | -------- |
|
||
|
| `AI` | `AI[1-8]` | `AI[1-8]` | `Number` |
|
||
|
| `AQ` | `AQ[1-2]` | `AQ[1-8]` | `Number` |
|
||
|
| `AM` | `AM[1-16]` | `AM[1-64]` | `Number` |
|
||
|
| `NAI` | | `NAI[1-32]` | `Number` |
|
||
|
| `NAQ` | | `NAQ[1-16]` | `Number` |
|
||
|
|
||
|
### Memory
|
||
|
|
||
|
Format pattern for memory channels for bit values is
|
||
|
|
||
|
```
|
||
|
channel="plclogo:memory:<DeviceId>:<ThingId>:<state/value>"
|
||
|
```
|
||
|
|
||
|
Dependent on configured LOGO! PLC and thing kind, follow channels are available:
|
||
|
|
||
|
| Kind | `0BA7` | `0BA8` | Item |
|
||
|
| ----------------- | :-----: | :-----: | -------- |
|
||
|
| `VB[0-850].[0-7]` | `state` | `state` | `Switch` |
|
||
|
| `VB[0-850]` | `value` | `value` | `Number` |
|
||
|
| `VW[0-849]` | `value` | `value` | `Number` |
|
||
|
| `VD[0-847]` | `value` | `value` | `Number` |
|
||
|
|
||
|
### DateTime
|
||
|
|
||
|
Format pattern depends for date/time channels is
|
||
|
|
||
|
```
|
||
|
channel="plclogo:datetime:<DeviceId>:<ThingId>:<date/time>"
|
||
|
```
|
||
|
|
||
|
Dependent on configured LOGO! PLC and thing kind, follow channels are available:
|
||
|
|
||
|
| Kind | `0BA7` | `0BA8` | Item |
|
||
|
| ----------- | :-----: | :-----: | ---------- |
|
||
|
| `VW[0-849]` | `date` | `date` | `DateTime` |
|
||
|
| `VW[0-849]` | `time` | `time` | `DateTime` |
|
||
|
| `VW[0-849]` | `value` | `value` | `Number` |
|
||
|
|
||
|
Channel `date` is available, if thing is configured as `"date"`.
|
||
|
Is thing configured as `"time"`, then channel `time` is provided.
|
||
|
Raw block data is provided via `value` channel, independed from thing configuration:
|
||
|
|
||
|
```
|
||
|
channel="plclogo:datetime:<DeviceId>:<ThingId>:value"
|
||
|
```
|
||
|
|
||
|
### Pulse
|
||
|
|
||
|
Format pattern depends for pulse channels is
|
||
|
|
||
|
```
|
||
|
channel="plclogo:pulse:<DeviceId>:<ThingId>:state"
|
||
|
```
|
||
|
|
||
|
Additionally the state of observed block data is provided via `observed` channel
|
||
|
|
||
|
```
|
||
|
channel="plclogo:pulse:<DeviceId>:<ThingId>:observed"
|
||
|
```
|
||
|
|
||
|
Dependent on configured LOGO! PLC and thing kind, follow channels are available:
|
||
|
|
||
|
| Kind | `0BA7` | `0BA8` | Item |
|
||
|
| ----------------- | :--------: | :--------: | --------- |
|
||
|
| `VB[0-850].[0-7]` | `state` | `state` | `Switch` |
|
||
|
| `VB[0-850].[0-7]` | `observed` | `observed` | `Switch` |
|
||
|
| `I[1-24]` | `observed` | `observed` | `Contact` |
|
||
|
| `Q[1-16/20]` | `observed` | `observed` | `Switch` |
|
||
|
| `M[1-27/64]` | `observed` | `observed` | `Switch` |
|
||
|
| `NI[1-64]` | | `observed` | `Contact` |
|
||
|
| `NQ[1-64]` | | `observed` | `Switch` |
|
||
|
|
||
|
## Examples
|
||
|
|
||
|
Configuration of one Siemens LOGO!
|
||
|
|
||
|
logo.things:
|
||
|
|
||
|
```
|
||
|
Bridge plclogo:device:Logo [ address="192.168.0.1", family="0BA8", localTSAP="0x3000", remoteTSAP="0x2000", refresh=100 ]
|
||
|
{
|
||
|
Thing digital Inputs [ kind="I" ]
|
||
|
Thing digital Outputs [ kind="Q" ]
|
||
|
Thing memory VW100 [ block="VW100", threshold=1, force=true ]
|
||
|
Thing datetime VW102 [ block="VW102", type="time" ]
|
||
|
Thing datetime VW150 [ block="VW150", type="date" ]
|
||
|
Thing pulse VB0_1 [ block="VB0.1", observe="Q1", pulse=500 ]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
logo.items:
|
||
|
|
||
|
```
|
||
|
Contact LogoI1 { channel="plclogo:digital:Logo:Inputs:I1" }
|
||
|
Contact LogoI2 { channel="plclogo:digital:Logo:Inputs:I2" }
|
||
|
Switch LogoQ1 { channel="plclogo:digital:Logo:Outputs:Q1" }
|
||
|
Switch LogoQ2 { channel="plclogo:digital:Logo:Outputs:Q2" }
|
||
|
Number Position { channel="plclogo:memory:Logo:VW100:value" }
|
||
|
|
||
|
DateTime LogoTime { channel="plclogo:datetime:Logo:VW102:time" }
|
||
|
DateTime LogoDate { channel="plclogo:datetime:Logo:VW150:date" }
|
||
|
|
||
|
Switch LogoVB1_S { channel="plclogo:pulse:Logo:VB0_1:state"}
|
||
|
Switch LogoVB1_O { channel="plclogo:pulse:Logo:VB0_1:observed"}
|
||
|
|
||
|
String Diagnostic { channel="plclogo:device:Logo:diagnostic"}
|
||
|
DateTime RTC { channel="plclogo:device:Logo:rtc"}
|
||
|
String DayOfWeek { channel="plclogo:device:Logo:weekday"}
|
||
|
```
|
||
|
|
||
|
Configuration of two Siemens LOGO!
|
||
|
|
||
|
logo.things:
|
||
|
|
||
|
```
|
||
|
Bridge plclogo:device:Logo1 [ address="192.168.0.1", family="0BA8", localTSAP="0x3000", remoteTSAP="0x2000", refresh=100 ]
|
||
|
{
|
||
|
Thing digital Inputs [ kind="I" ]
|
||
|
Thing digital Outputs [ kind="Q" ]
|
||
|
Thing memory VW100 [ block="VW100", threshold=1 ]
|
||
|
Thing pulse VB0_0 [ block="VB0.0", observe="NI1", pulse=250 ]
|
||
|
}
|
||
|
Bridge plclogo:device:Logo2 [ address="192.168.0.2", family="0BA8", localTSAP="0x3100", remoteTSAP="0x2000", refresh=100 ]
|
||
|
{
|
||
|
Thing digital Inputs [ kind="I" ]
|
||
|
Thing digital Outputs [ kind="Q" ]
|
||
|
Thing memory VD102 [ block="VD102", threshold=1 ]
|
||
|
Thing pulse VB0_1 [ block="VB0.1", observe="VB0.1", pulse=500 ]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
logo.items:
|
||
|
|
||
|
```
|
||
|
Contact Logo1_I1 { channel="plclogo:digital:Logo1:Inputs:I1" }
|
||
|
Contact Logo1_I2 { channel="plclogo:digital:Logo1:Inputs:I2" }
|
||
|
Switch Logo1_Q1 { channel="plclogo:digital:Logo1:Outputs:Q1" }
|
||
|
Switch Logo1_Q2 { channel="plclogo:digital:Logo1:Outputs:Q2" }
|
||
|
Number Logo1_VW100 { channel="plclogo:memory:Logo1:VW100:value" }
|
||
|
Switch Logo1_VB0_S { channel="plclogo:pulse:Logo1:VB0_0:state"}
|
||
|
Contact Logo1_VB0_O { channel="plclogo:pulse:Logo1:VB0_0:observed"}
|
||
|
DateTime Logo1_RTC { channel="plclogo:device:Logo1:rtc"}
|
||
|
|
||
|
Contact Logo2_I1 { channel="plclogo:digital:Logo2:Inputs:I1" }
|
||
|
Contact Logo2_I2 { channel="plclogo:digital:Logo2:Inputs:I2" }
|
||
|
Switch Logo2_Q1 { channel="plclogo:digital:Logo2:Outputs:Q1" }
|
||
|
Switch Logo2_Q2 { channel="plclogo:digital:Logo2:Outputs:Q2" }
|
||
|
Number Logo2_VD102 { channel="plclogo:memory:Logo2:VD102:value" }
|
||
|
Switch Logo2_VB1_S { channel="plclogo:pulse:Logo2:VB0_1:state"}
|
||
|
Switch Logo2_VB1_O { channel="plclogo:pulse:Logo2:VB0_1:observed"}
|
||
|
DateTime Logo2_RTC { channel="plclogo:device:Logo2:rtc"}
|
||
|
```
|
||
|
|
||
|
## Troubleshooting
|
||
|
|
||
|
**LOGO! bridge will not go online**
|
||
|
|
||
|
Be sure to have only one bridge for each LOGO! device.
|
||
|
|
||
|
**Log shows reader was created but no communication with LOGO! possible**
|
||
|
|
||
|
Check TSAP values: localTSAP and remoteTSAP should not be the same.
|
||
|
You have to choose different addresses.
|
||
|
|
||
|
**openHAB is starting without errors but no reader was created for the LOGO!**
|
||
|
|
||
|
If all configuration parameters were checked and fine, it maybe possible that the network interface of the LOGO! is crashed.
|
||
|
To recover stop openHAB, cold boot your LOGO! (power off/on) and reflash the program with LOGO! SoftComfort.
|
||
|
Then restart openHAB and check logging for a created reader.
|
||
|
|
||
|
**RTC value differs from the value shown in LOGO! (0BA7)**
|
||
|
|
||
|
This is no bug! Since there is no way to read the RTC from a 0BA7, the binding simply returns the local time of openHAB host.
|