scapy.contrib.ethercat¶
EtherCat automation protocol¶
- author
Thomas Tannhaeuser, hecke@naberius.de
- license
GPLv2
This module is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This module is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
- description
This module provides Scapy layers for the EtherCat protocol.
- normative references:
IEC 61158-3-12 - data link service and topology description
IEC 61158-4-12 - protocol specification
Currently only read/write services as defined in IEC 61158-4-12, sec. 5.4 are supported.
- TODO
Mailbox service (sec. 5.5)
Network variable service (sec. 5.6)
- NOTES
EtherCat frame type defaults to TYPE-12-PDU (0x01) using xxx bytes of padding
padding for minimum frame size is added automatically
-
class
scapy.contrib.ethercat.EtherCat(*args, **kargs)¶ Bases:
scapy.packet.PacketCommon EtherCat header layer
-
ETHERCAT_HEADER_LEN= 2¶
-
ETHERCAT_TYPE12_DLPDU_TYPES= {1: <class 'scapy.contrib.ethercat.EtherCatAPRD'>, 2: <class 'scapy.contrib.ethercat.EtherCatAPWR'>, 3: <class 'scapy.contrib.ethercat.EtherCatAPRW'>, 4: <class 'scapy.contrib.ethercat.EtherCatFPRD'>, 5: <class 'scapy.contrib.ethercat.EtherCatFPWR'>, 6: <class 'scapy.contrib.ethercat.EtherCatFPRW'>, 7: <class 'scapy.contrib.ethercat.EtherCatBRD'>, 8: <class 'scapy.contrib.ethercat.EtherCatBWR'>, 9: <class 'scapy.contrib.ethercat.EtherCatBRW'>, 10: <class 'scapy.contrib.ethercat.EtherCatLRD'>, 11: <class 'scapy.contrib.ethercat.EtherCatLWR'>, 12: <class 'scapy.contrib.ethercat.EtherCatLRW'>, 13: <class 'scapy.contrib.ethercat.EtherCatARMW'>, 14: <class 'scapy.contrib.ethercat.EtherCatFRMW'>}¶
-
ETHER_FRAME_MIN_LEN= 64¶
-
ETHER_FSC_LEN= 4¶
-
ETHER_HEADER_LEN= 14¶
-
FRAME_TYPES= {1: 'TYPE-12-PDU', 4: 'NETWORK-VARIABLES', 5: 'MAILBOX'}¶
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | LENGTH | | TYPE | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatEtherCat fields¶ length
LEBitField(11 bits)0_reserved
LEBitField(1 bit)0type
LEBitField(4 bits)0
-
guess_payload_class(payload)¶
-
payload_guess¶ Possible sublayers:
EtherCatAPRD,EtherCatAPRW,EtherCatAPWR,EtherCatARMW,EtherCatBRD,EtherCatBRW,EtherCatBWR,EtherCatFPRD,EtherCatFPRW,EtherCatFPWR,EtherCatFRMW,EtherCatLRD,EtherCatLRW,EtherCatLWR
-
post_build(pkt, pay)¶ need to set the length of the whole PDU manually to avoid any bit fiddling use a dummy class to build the layer content
also add padding if frame is < 64 bytes
- Note: padding only handles Ether/n*Dot1Q/EtherCat
(no special mumbo jumbo)
- Parameters
pkt – raw string containing the current layer
pay – raw string containing the payload
- Returns
<new current layer> + payload
-
-
class
scapy.contrib.ethercat.EtherCatAPRD(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUAPRD - Auto Increment Physical Read (IEC 61158-5-12, sec. 5.4.1.2 tab. 14 / p. 32)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatAPRDEtherCatAPRD fields¶ _cmd
1idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatAPRW(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUAPRW - Auto Increment Physical Read Write (IEC 61158-5-12, sec. 5.4.3.1 tab. 22 / p. 41)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatAPRWEtherCatAPRW fields¶ _cmd
3idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatAPWR(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUAPWR - Auto Increment Physical Write (IEC 61158-5-12, sec. 5.4.2.2 tab. 18 / p. 37)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatAPWREtherCatAPWR fields¶ _cmd
2idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatARMW(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUARMW - Auto increment physical read multiple write (IEC 61158-5-12, sec. 5.4.3.5 tab. 26 / p. 46)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatARMWEtherCatARMW fields¶ _cmd
13idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatBRD(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUBRD - Broadcast read (IEC 61158-5-12, sec. 5.4.1.4 tab. 16 / p. 34)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatBRDEtherCatBRD fields¶ _cmd
7idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatBRW(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUBRW - Broadcast read write (IEC 61158-5-12, sec. 5.4.3.3 tab. 24 / p. 39)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatBRWEtherCatBRW fields¶ _cmd
9idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatBWR(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUBWR - Broadcast read (IEC 61158-5-12, sec. 5.4.2.4 tab. 20 / p. 39)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatBWREtherCatBWR fields¶ _cmd
8idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatFPRD(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUFPRD - Configured address physical read (IEC 61158-5-12, sec. 5.4.1.3 tab. 15 / p. 33)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatFPRDEtherCatFPRD fields¶ _cmd
4idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatFPRW(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUFPRW - Configured address physical read write (IEC 61158-5-12, sec. 5.4.3.2 tab. 23 / p. 43)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatFPRWEtherCatFPRW fields¶ _cmd
6idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatFPWR(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUFPWR - Configured address physical write (IEC 61158-5-12, sec. 5.4.2.3 tab. 19 / p. 38)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatFPWREtherCatFPWR fields¶ _cmd
5idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatFRMW(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDUFRMW - Configured address physical read multiple write (IEC 61158-5-12, sec. 5.4.3.6 tab. 27 / p. 47)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADP | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ADO | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatFRMWEtherCatFRMW fields¶ _cmd
14idx
0adp
0ado
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatLRD(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDULRD - Logical read (IEC 61158-5-12, sec. 5.4.1.5 tab. 17 / p. 36)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADR | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatLRDEtherCatLRD fields¶ _cmd
10idx
0adr
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatLRW(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDULRW - Logical read write (IEC 61158-5-12, sec. 5.4.3.4 tab. 25 / p. 45)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADR | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatLRWEtherCatLRW fields¶ _cmd
12idx
0adr
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatLWR(*args, **kargs)¶ Bases:
scapy.contrib.ethercat.EtherCatType12DLPDULWR - Logical write (IEC 61158-5-12, sec. 5.4.2.5 tab. 21 / p. 40)
-
aliastypes¶
-
fields_desc¶ Display RFC-like schema
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | CMD | IDX | ADR | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | LEN | RESE| C | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | NEXT |IRQ| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | DATA |WKC| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+ Fig. EtherCatLWREtherCatLWR fields¶ _cmd
11idx
0adr
0len
LEBitFieldLenField(11 bits)None_reserved
LEBitField(3 bits)0c
LEBitEnumField(1 bit)0next
LEBitEnumField(1 bit)Noneirq
0data
[]wkc
0
-
-
class
scapy.contrib.ethercat.EtherCatType12DLPDU(*args, **kargs)¶ Bases:
scapy.packet.PacketType12 message base class
-
BROADCAST_ADDRESSING_DESC= [<Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).idx>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).adp>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).ado>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).len>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW)._reserved>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).c>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).next>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).irq>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).data>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).wkc>]¶
-
LOGICAL_ADDRESSING_DESC= [<Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).idx>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).adr>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).len>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW)._reserved>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).c>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).next>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).irq>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).data>, <Field (EtherCatLRD,EtherCatLWR,EtherCatLRW).wkc>]¶
-
PHYSICAL_ADDRESSING_DESC= [<Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).idx>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).adp>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).ado>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).len>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW)._reserved>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).c>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).next>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).irq>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).data>, <Field (EtherCatAPRD,EtherCatFPRD,EtherCatBRD,EtherCatAPWR,EtherCatFPWR,EtherCatBWR,EtherCatAPRW,EtherCatFPRW,EtherCatBRW,EtherCatARMW,EtherCatFRMW).wkc>]¶
-
aliastypes¶
-
guess_payload_class(payload)¶
-
post_build(pkt, pay)¶ set next attr automatically if not set explicitly by user
- Parameters
pkt – raw string containing the current layer
pay – raw string containing the payload
- Returns
<new current layer> + payload
-
-
class
scapy.contrib.ethercat.LEBitEnumField(name, default, size, enum)¶ Bases:
scapy.contrib.ethercat.LEBitField,scapy.fields._EnumField-
i2s¶
-
i2s_cb¶
-
s2i¶
-
s2i_cb¶
-
-
class
scapy.contrib.ethercat.LEBitField(name, default, size, tot_size=0, end_tot_size=0)¶ Bases:
scapy.fields.BitFielda little endian version of the BitField
-
addfield(pkt, s, val)¶ - Parameters
pkt – packet instance the raw string s and field belongs to
s – raw string representing the frame
val – value
- Returns
final raw string, tuple (s, bitsdone, data) if in between bit field # noqa: E501
as we don’t know the final size of the full bitfield we need to accumulate the data. # noqa: E501 if we reach a field that ends at a octet boundary, we build the whole string # noqa: E501
-
getfield(pkt, s)¶ extract data from raw str
collect all instances belonging to the bit field set. if we reach a field that ends at a octet boundary, dissect the whole bit field at once # noqa: E501
- Parameters
pkt – packet instance the field belongs to
s – raw string representing the frame -or- tuple containing raw str, number of bits and array of fields # noqa: E501
- Returns
tuple containing raw str, number of bits and array of fields -or- remaining raw str and value of this # noqa: E501
-
-
class
scapy.contrib.ethercat.LEBitFieldLenField(name, default, size, length_of=None, count_of=None, adjust=<function LEBitFieldLenField.<lambda>>)¶ Bases:
scapy.contrib.ethercat.LEBitField-
adjust¶
-
count_of¶
-
i2m(pkt, x)¶
-
length_of¶
-
-
exception
scapy.contrib.ethercat.LEBitFieldSequenceException¶ Bases:
scapy.error.Scapy_Exceptionthrown by EtherCat structure tests