beremiz

Parents 015dab6a915f
Children 91c10856adaa
Cherry-pick and re-commit to legitimate ancestor of commit 'Ethercat Management Function Refactoring Source by RTES Lab.' from youcu
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/etherlab/CommonEtherCATFunction.py Wed Apr 02 15:03:32 2014 +0200
@@ -0,0 +1,1600 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+#This file is part of Beremiz, an Integrated Development Environment for
+#programming IEC 61131-3 automates supporting EtherCAT.
+#
+#Copyright (C) 2013: Real-Time & Embedded Systems (RTES) Lab. University of Seoul, Korea
+#
+#See COPYING file for copyrights details.
+#
+#This library 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.1 of the License, or (at your option) any later version.
+#
+#This library 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.
+#
+#You should have received a copy of the GNU General Public
+#License along with this library; if not, write to the Free Software
+#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+
+import os
+import wx
+
+def ExtractHexDecValue(value):
+ """
+ convert numerical value in string format into decimal or hex format.
+ @param value : hex or decimal data
+ @return integer data
+ """
+ try:
+ return int(value)
+ except:
+ pass
+ try:
+ return int(value.replace("#", "0"), 16)
+
+ except:
+ raise ValueError, "Invalid value for HexDecValue \"%s\"" % value
+
+def ExtractName(names, default=None):
+ """
+ Extract "name" field from XML entries.
+ @param names : XML entry
+ @default : if it fails to extract from the designated XML entry, return the default value ("None").
+ @return default or the name extracted
+ """
+ if len(names) == 1:
+ return names[0].getcontent()
+ else:
+ for name in names:
+ if name.getLcId() == 1033:
+ return name.getcontent()
+ return default
+
+#--------------------------------------------------
+# Remote Exec Etherlab Commands
+#--------------------------------------------------
+
+# --------------------- for master ---------------------------
+MASTER_STATE = """
+import commands
+result = commands.getoutput("ethercat master")
+returnVal =result
+"""
+
+# --------------------- for slave ----------------------------
+# ethercat state -p (slave position) (state (INIT, PREOP, SAFEOP, OP))
+SLAVE_STATE = """
+import commands
+result = commands.getoutput("ethercat state -p %d %s")
+returnVal = result
+"""
+
+# ethercat slave
+GET_SLAVE = """
+import commands
+result = commands.getoutput("ethercat slaves")
+returnVal =result
+"""
+
+# ethercat xml -p (slave position)
+SLAVE_XML = """
+import commands
+result = commands.getoutput("ethercat xml -p %d")
+returnVal = result
+"""
+
+# ethercat sdos -p (slave position)
+SLAVE_SDO = """
+import commands
+result = commands.getoutput("ethercat sdos -p %d")
+returnVal =result
+"""
+
+# ethercat upload -p (slave position) (main index) (sub index)
+GET_SLOW_SDO = """
+import commands
+result = commands.getoutput("ethercat upload -p %d %s %s")
+returnVal =result
+"""
+
+# ethercat download -p (slave position) (main index) (sub index) (value)
+SDO_DOWNLOAD = """
+import commands
+result = commands.getoutput("ethercat download --type %s -p %d %s %s %s")
+returnVal =result
+"""
+
+# ethercat sii_read -p (slave position)
+SII_READ = """
+import commands
+result = commands.getoutput("ethercat sii_read -p %d")
+returnVal =result
+"""
+
+# ethercat reg_read -p (slave position) (address) (size)
+REG_READ = """
+import commands
+result = commands.getoutput("ethercat reg_read -p %d %s %s")
+returnVal =result
+"""
+
+# ethercat sii_write -p (slave position) - (contents)
+SII_WRITE = """
+import subprocess
+process = subprocess.Popen(
+ ["ethercat", "-f", "sii_write", "-p", "%d", "-"],
+ stdin=subprocess.PIPE)
+process.communicate(sii_data)
+returnVal = process.returncode
+"""
+
+# ethercat reg_write -p (slave position) -t (uinit16) (address) (data)
+REG_WRITE = """
+import commands
+result = commands.getoutput("ethercat reg_write -p %d -t uint16 %s %s")
+returnVal =result
+"""
+
+# ethercat rescan -p (slave position)
+RESCAN = """
+import commands
+result = commands.getoutput("ethercat rescan -p %d")
+returnVal =result
+"""
+
+#--------------------------------------------------
+# Common Method For EtherCAT Management
+#--------------------------------------------------
+class _CommonSlave:
+
+ # ----- Data Structure for ethercat management ----
+ SlaveState = ""
+
+ # category of SDO data
+ DatatypeDescription, CommunicationObject, ManufacturerSpecific, \
+ ProfileSpecific, Reserved, AllSDOData = range(6)
+
+ # store the execution result of "ethercat sdos" command into SaveSDOData.
+ SaveSDOData = []
+
+ # Flags for checking "write" permission of OD entries
+ CheckPREOP = False
+ CheckSAFEOP = False
+ CheckOP = False
+
+ # Save PDO Data
+ TxPDOInfo = []
+ TxPDOCategory = []
+ RxPDOInfo = []
+ RxPDOCategory = []
+
+ # Save EEPROM Data
+ SiiData = ""
+
+ # Save Register Data
+ RegData = ""
+ CrtRegSpec = {"ESCType": "",
+ "FMMUNumber": "",
+ "SMNumber": "",
+ "PDIType": ""}
+
+ def __init__(self, controler):
+ """
+ Constructor
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ self.Controler = controler
+
+ self.ClearSDODataSet()
+
+ #-------------------------------------------------------------------------------
+ # Used Master State
+ #-------------------------------------------------------------------------------
+ def GetMasterState(self):
+ """
+ Execute "ethercat master" command and parse the execution result
+ @return MasterState
+ """
+
+ # exectute "ethercat master" command
+ error, return_val = self.Controler.RemoteExec(MASTER_STATE, return_val = None)
+ master_state = {}
+ # parse the reslut
+ for each_line in return_val.splitlines():
+ if len(each_line) > 0 :
+ chunks = each_line.strip().split(':', 1)
+ key = chunks[0]
+ value = []
+ if len(chunks) > 1 :
+ value = chunks[1].split()
+ if '(attached)' in value:
+ value.remove('(attached)')
+ master_state[key] = value
+
+ return master_state
+
+ #-------------------------------------------------------------------------------
+ # Used Slave State
+ #-------------------------------------------------------------------------------
+ def RequestSlaveState(self, command):
+ """
+ Set slave state to the specified one using "ethercat states -p %d %s" command.
+ Command example : "ethercat states -p 0 PREOP" (target slave position and target state are given.)
+ @param command : target slave state
+ """
+ error, return_val = self.Controler.RemoteExec(SLAVE_STATE%(self.Controler.GetSlavePos(), command), return_val = None)
+
+ def GetSlaveStateFromSlave(self):
+ """
+ Get slave information using "ethercat slaves" command and store the information into internal data structure
+ (self.SlaveState) for "Slave State"
+ return_val example : 0 0:0 PREOP + EL9800 (V4.30) (PIC24, SPI, ET1100)
+ """
+ error, return_val = self.Controler.RemoteExec(GET_SLAVE, return_val = None)
+ self.SlaveState = return_val
+ return return_val
+
+ #-------------------------------------------------------------------------------
+ # Used SDO Management
+ #-------------------------------------------------------------------------------
+ def GetSlaveSDOFromSlave(self):
+ """
+ Get SDO objects information of current slave using "ethercat sdos -p %d" command.
+ Command example : "ethercat sdos -p 0"
+ @return return_val : execution results of "ethercat sdos" command (need to be parsed later)
+ """
+ error, return_val = self.Controler.RemoteExec(SLAVE_SDO%(self.Controler.GetSlavePos()), return_val = None)
+ return return_val
+
+ def SDODownload(self, data_type, idx, sub_idx, value):
+ """
+ Set an SDO object value to user-specified value using "ethercat download" command.
+ Command example : "ethercat download --type int32 -p 0 0x8020 0x12 0x00000000"
+ @param data_type : data type of SDO entry
+ @param idx : index of the SDO entry
+ @param sub_idx : subindex of the SDO entry
+ @param value : value of SDO entry
+ """
+ error, return_val = self.Controler.RemoteExec(SDO_DOWNLOAD%(data_type, self.Controler.GetSlavePos(), idx, sub_idx, value), return_val = None)
+
+ def BackupSDODataSet(self):
+ """
+ Back-up current SDO entry information to restore the SDO data
+ in case that the user cancels SDO update operation.
+ """
+ self.BackupDatatypeDescription = self.SaveDatatypeDescription
+ self.BackupCommunicationObject = self.SaveCommunicationObject
+ self.BackupManufacturerSpecific = self.SaveManufacturerSpecific
+ self.BackupProfileSpecific = self.SaveProfileSpecific
+ self.BackupReserved = self.SaveReserved
+ self.BackupAllSDOData = self.SaveAllSDOData
+
+ def ClearSDODataSet(self):
+ """
+ Clear the specified SDO entry information.
+ """
+ for count in range(6):
+ self.SaveSDOData.append([])
+
+ #-------------------------------------------------------------------------------
+ # Used PDO Monitoring
+ #-------------------------------------------------------------------------------
+ def RequestPDOInfo(self):
+ """
+ Load slave information from RootClass (XML data) and parse the information (calling SlavePDOData() method).
+ """
+ # Load slave information from ESI XML file (def EthercatMaster.py)
+ slave = self.Controler.CTNParent.GetSlave(self.Controler.GetSlavePos())
+
+ type_infos = slave.getType()
+ device, alignment = self.Controler.CTNParent.GetModuleInfos(type_infos)
+ # Initialize PDO data set
+ self.ClearDataSet()
+
+ # if 'device' object is valid, call SavePDOData() to parse PDO data
+ if device is not None :
+ self.SavePDOData(device)
+
+ def SavePDOData(self, device):
+ """
+ Parse PDO data and store the results in TXPDOCategory and RXPDOCategory
+ Tx(Rx)PDOCategory : index, name, entry number
+ Tx(Rx)Info : entry index, sub index, name, length, type
+ @param device : Slave information extracted from ESI XML file
+ """
+ # Parsing TXPDO entries
+ for pdo, pdo_info in ([(pdo, "Inputs") for pdo in device.getTxPdo()]):
+ # Save pdo_index, entry, and name of each entry
+ pdo_index = ExtractHexDecValue(pdo.getIndex().getcontent())
+ entries = pdo.getEntry()
+ pdo_name = ExtractName(pdo.getName())
+
+ # Initialize entry number count
+ count = 0
+
+ # Parse entries
+ for entry in entries:
+ # Save index and subindex
+ index = ExtractHexDecValue(entry.getIndex().getcontent())
+ subindex = ExtractHexDecValue(entry.getSubIndex())
+ # if entry name exists, save entry data
+ if ExtractName(entry.getName()) is not None :
+ entry_infos = {
+ "entry_index" : index,
+ "subindex" : subindex,
+ "name" : ExtractName(entry.getName()),
+ "bitlen" : entry.getBitLen(),
+ "type" : entry.getDataType().getcontent()
+ }
+ self.TxPDOInfo.append(entry_infos)
+ count += 1
+
+ categorys = {"pdo_index" : pdo_index, "name" : pdo_name, "number_of_entry" : count}
+ self.TxPDOCategory.append(categorys)
+
+ # Parsing RxPDO entries
+ for pdo, pdo_info in ([(pdo, "Outputs") for pdo in device.getRxPdo()]):
+ # Save pdo_index, entry, and name of each entry
+ pdo_index = ExtractHexDecValue(pdo.getIndex().getcontent())
+ entries = pdo.getEntry()
+ pdo_name = ExtractName(pdo.getName())
+
+ # Initialize entry number count
+ count = 0
+
+ # Parse entries
+ for entry in entries:
+ # Save index and subindex
+ index = ExtractHexDecValue(entry.getIndex().getcontent())
+ subindex = ExtractHexDecValue(entry.getSubIndex())
+ # if entry name exists, save entry data
+ if ExtractName(entry.getName()) is not None :
+ entry_infos = {
+ "entry_index" : index,
+ "subindex" : subindex,
+ "name" : ExtractName(entry.getName()),
+ "bitlen" : str(entry.getBitLen()),
+ "type" : entry.getDataType().getcontent()
+ }
+ self.RxPDOInfo.append(entry_infos)
+ count += 1
+
+ categorys = {"pdo_index" : pdo_index, "name" : pdo_name, "number_of_entry" : count}
+ self.RxPDOCategory.append(categorys)
+
+ def GetTxPDOCategory(self):
+ """
+ Get TxPDOCategory data structure (Meta informaton of TxPDO).
+ TxPDOCategorys : index, name, number of entries
+ @return TxPDOCategorys
+ """
+ return self.TxPDOCategory
+
+ def GetRxPDOCategory(self):
+ """
+ Get RxPDOCategory data structure (Meta information of RxPDO).
+ RxPDOCategorys : index, name, number of entries
+ @return RxPDOCategorys
+ """
+ return self.RxPDOCategory
+
+ def GetTxPDOInfo(self):
+ """
+ Get TxPDOInfo data structure (Detailed information on TxPDO entries).
+ TxPDOInfos : entry index, sub index, name, length, type
+ @return TxPDOInfos
+ """
+ return self.TxPDOInfo
+
+ def GetRxPDOInfo(self):
+ """
+ Get RxPDOInfo data structure (Detailed information on RxPDO entries).
+ RxPDOInfos : entry index, sub index, name, length, type
+ @return RxPDOInfos
+ """
+ return self.RxPDOInfo
+
+ def ClearDataSet(self):
+ """
+ Initialize PDO management data structure.
+ """
+ self.TxPDOInfos = []
+ self.TxPDOCategorys = []
+ self.RxPDOInfos = []
+ self.RxPDOCategorys = []
+
+ #-------------------------------------------------------------------------------
+ # Used EEPROM Management
+ #-------------------------------------------------------------------------------
+ # Base data types in ETG2000; format = {"Name": "BitSize"}
+ BaseDataTypeDict = {"BOOL": "01",
+ "SINT": "02",
+ "INT": "03",
+ "DINT": "04",
+ "USINT": "05",
+ "UINT": "06",
+ "UDINT": "07",
+ "REAL": "08",
+ "INT24": "10",
+ "LREAL": "11",
+ "INT40": "12",
+ "INT48": "13",
+ "INT56": "14",
+ "LINT": "15",
+ "UINT24": "16",
+ "UINT40": "18",
+ "UINT48": "19",
+ "UINT56": "1a",
+ "ULINT": "1b",
+ "USINT": "1e",
+ "BITARR8": "2d",
+ "BITARR16": "2e",
+ "BITARR32": "2f",
+ "BIT1": "30",
+ "BIT2": "31",
+ "BIT3": "32",
+ "BIT4": "33",
+ "BIT5": "34",
+ "BIT6": "35",
+ "BIT7": "36",
+ "BIT8": "37"}
+
+ def GetSmartViewInfos(self):
+ """
+ Parse XML data for "Smart View" of EEPROM contents.
+ @return smartview_infos : EEPROM contents dictionary
+ """
+
+ smartview_infos = {"eeprom_size": 128,
+ "pdi_type": 0,
+ "device_emulation": "False",
+ "vendor_id": '0x00000000',
+ "product_code": '0x00000000',
+ "revision_no": '0x00000000',
+ "serial_no": '0x00000000',
+ "supported_mailbox": "",
+ "mailbox_bootstrapconf_outstart": '0',
+ "mailbox_bootstrapconf_outlength": '0',
+ "mailbox_bootstrapconf_instart": '0',
+ "mailbox_bootstrapconf_inlength": '0',
+ "mailbox_standardconf_outstart": '0',
+ "mailbox_standardconf_outlength": '0',
+ "mailbox_standardconf_instart": '0',
+ "mailbox_standardconf_inlength": '0'}
+
+ slave = self.Controler.CTNParent.GetSlave(self.Controler.GetSlavePos())
+ type_infos = slave.getType()
+ device, alignment = self.Controler.CTNParent.GetModuleInfos(type_infos)
+
+ # 'device' represents current slave device selected by user
+ if device is not None:
+ for eeprom_element in device.getEeprom().getcontent()["value"]:
+ # get EEPROM size; <Device>-<Eeprom>-<ByteSize>
+ if eeprom_element["name"] == "ByteSize":
+ smartview_infos["eeprom_size"] = eeprom_element["value"]
+
+ elif eeprom_element["name"] == "ConfigData":
+ configData_data = self.DecimalToHex(eeprom_element["value"])
+ # get PDI type; <Device>-<Eeprom>-<ConfigData> address 0x00
+ smartview_infos["pdi_type"] = int(configData_data[0:2], 16)
+ # get state of device emulation; <Device>-<Eeprom>-<ConfigData> address 0x01
+ if "{:0>8b}".format(int(configData_data[2:4], 16))[7] == '1':
+ smartview_infos["device_emulation"] = "True"
+
+ elif eeprom_element["name"] == "BootStrap":
+ bootstrap_data = "{:0>16x}".format(eeprom_element["value"])
+ # get bootstrap configuration; <Device>-<Eeprom>-<BootStrap>
+ for cfg, iter in [("mailbox_bootstrapconf_outstart", 0),
+ ("mailbox_bootstrapconf_outlength", 1),
+ ("mailbox_bootstrapconf_instart", 2),
+ ("mailbox_bootstrapconf_inlength", 3)]:
+ smartview_infos[cfg] = str(int(bootstrap_data[4*iter+2:4*(iter+1)]+bootstrap_data[4*iter:4*iter+2], 16))
+
+ # get protocol (profile) types supported by mailbox; <Device>-<Mailbox>
+ for mailbox_protocol in ["VoE", "SoE", "FoE", "CoE", "EoE", "AoE"]:
+ if eval("device.getMailbox().get%s()"%mailbox_protocol) is not None:
+ smartview_infos["supported_mailbox"] += "%s, "%mailbox_protocol
+ smartview_infos["supported_mailbox"] = smartview_infos["supported_mailbox"].strip(", ")
+
+ # get standard configuration of mailbox; <Device>-<Sm>
+ for sm_element in device.getSm():
+ if sm_element.getcontent() == "MBoxOut":
+ smartview_infos["mailbox_standardconf_outstart"] = str(ExtractHexDecValue(sm_element.getStartAddress()))
+ smartview_infos["mailbox_standardconf_outlength"] = str(ExtractHexDecValue(sm_element.getDefaultSize()))
+ elif sm_element.getcontent() == "MBoxIn":
+ smartview_infos["mailbox_standardconf_instart"] = str(ExtractHexDecValue(sm_element.getStartAddress()))
+ smartview_infos["mailbox_standardconf_inlength"] = str(ExtractHexDecValue(sm_element.getDefaultSize()))
+ else:
+ pass
+
+ # get device identity from <Device>-<Type>
+ # vendor ID; by default, pre-defined value in self.ModulesLibrary
+ # if device type in 'vendor' item equals to actual slave device type, set 'vendor_id' to vendor ID.
+ for vendor_id, vendor in self.Controler.CTNParent.CTNParent.ModulesLibrary.Library.iteritems():
+ for available_device in vendor["groups"][vendor["groups"].keys()[0]]["devices"]:
+ if available_device[0] == type_infos["device_type"]:
+ smartview_infos["vendor_id"] = "0x" + "{:0>8x}".format(vendor_id)
+
+ # product code;
+ if device.getType().getProductCode() is not None:
+ product_code = device.getType().getProductCode()
+ smartview_infos["product_code"] = "0x"+"{:0>8x}".format(ExtractHexDecValue(product_code))
+
+ # revision number;
+ if device.getType().getRevisionNo() is not None:
+ revision_no = device.getType().getRevisionNo()
+ smartview_infos["revision_no"] = "0x"+"{:0>8x}".format(ExtractHexDecValue(revision_no))
+
+ # serial number;
+ if device.getType().getSerialNo() is not None:
+ serial_no = device.getType().getSerialNo()
+ smartview_infos["serial_no"] = "0x"+"{:0>8x}".format(ExtractHexDecValue(serial_no))
+
+ return smartview_infos
+
+ else:
+ return None
+
+ def DecimalToHex(self, decnum):
+ """
+ Convert decimal value into hexadecimal representation.
+ @param decnum : decimal value
+ @return hex_data : hexadecimal representation of input value in decimal
+ """
+ value = "%x" % decnum
+ value_len = len(value)
+ if (value_len % 2) == 0:
+ hex_len = value_len
+ else:
+ hex_len = (value_len / 2) * 2 + 2
+
+ hex_data = ("{:0>"+str(hex_len)+"x}").format(decnum)
+
+ return hex_data
+
+ def SiiRead(self):
+ """
+ Get slave EEPROM contents maintained by master device using "ethercat sii_read -p %d" command.
+ Command example : "ethercat sii_read -p 0"
+ @return return_val : result of "ethercat sii_read" (binary data)
+ """
+ error, return_val = self.Controler.RemoteExec(SII_READ%(self.Controler.GetSlavePos()), return_val = None)
+ self.SiiData = return_val
+ return return_val
+
+ def SiiWrite(self, binary):
+ """
+ Overwrite slave EEPROM contents using "ethercat sii_write -p %d" command.
+ Command example : "ethercat sii_write -p 0 - (binary contents)"
+ @param binary : EEPROM contents in binary data format
+ @return return_val : result of "ethercat sii_write" (If it succeeds, the return value is NULL.)
+ """
+ error, return_val = self.Controler.RemoteExec(SII_WRITE%(self.Controler.GetSlavePos()), return_val = None, sii_data = binary)
+ return return_val
+
+ def LoadData(self):
+ """
+ Loading data from EEPROM use Sii_Read Method
+ @return self.BinaryCode : slave EEPROM data in binary format (zero-padded)
+ """
+ return_val = self.Controler.CommonMethod.SiiRead()
+ self.BinaryCode = return_val
+ self.Controler.SiiData = self.BinaryCode
+
+ # append zero-filled padding data up to EEPROM size
+ for index in range(self.SmartViewInfosFromXML["eeprom_size"] - len(self.BinaryCode)):
+ self.BinaryCode = self.BinaryCode +'ff'.decode('hex')
+
+ return self.BinaryCode
+
+ def HexRead(self, binary):
+ """
+ Convert binary digit representation into hexadecimal representation for "Hex View" menu.
+ @param binary : binary digits
+ @return hexCode : hexadecimal digits
+ @return hexview_table_row, hexview_table_col : Grid size for "Hex View" UI
+ """
+ row_code = []
+ row_text = ""
+ row = 0
+ hex_code = []
+
+ hexview_table_col = 17
+
+ for index in range(0, len(binary)) :
+ if len(binary[index]) != 1:
+ break
+ else:
+ digithexstr = hex(ord(binary[index]))
+
+ tempvar2 = digithexstr[2:4]
+ if len(tempvar2) == 1:
+ tempvar2 = "0" + tempvar2
+ row_code.append(tempvar2)
+
+ if int(digithexstr, 16)>=32 and int(digithexstr, 16)<=126:
+ row_text = row_text + chr(int(digithexstr, 16))
+ else:
+ row_text = row_text + "."
+
+ if index != 0 :
+ if len(row_code) == (hexview_table_col - 1):
+ row_code.append(row_text)
+ hex_code.append(row_code)
+ row_text = ""
+ row_code = []
+ row = row + 1
+
+ hexview_table_row = row
+
+ return hex_code, hexview_table_row, hexview_table_col
+
+ def GenerateEEPROMList(self, data, direction, length):
+ """
+ Generate EEPROM data list by reconstructing 'data' string.
+ example : data="12345678", direction=0, length=8 -> eeprom_list=['12', '34', '56', '78']
+ data="12345678", direction=1, length=8 -> eeprom_list=['78', '56', '34', '12']
+ @param data : string to be reconstructed
+ @param direction : endianness
+ @param length : data length
+ @return eeprom_list : reconstructed list data structure
+ """
+ eeprom_list = []
+
+ if direction is 0 or 1:
+ for i in range(length/2):
+ if data == "":
+ eeprom_list.append("00")
+ else:
+ eeprom_list.append(data[direction*(length-2):direction*(length-2)+2])
+ data = data[(1-direction)*2:length-direction*2]
+ length -= 2
+ return eeprom_list
+
+ def XmlToEeprom(self):
+ """
+ Extract slave EEPROM contents using slave ESI XML file.
+ - Mandatory parts
+ - String category : ExtractEEPROMStringCategory()
+ - General category : ExtractEEPROMGeneralCategory()
+ - FMMU category : ExtractEEPROMFMMUCategory
+ - SyncM category : ExtractEEPROMSyncMCategory()
+ - Tx/RxPDO category : ExtractEEPROMPDOCategory()
+ - DC category : ExtractEEPROMDCCategory()
+ @return eeprom_binary
+ """
+ eeprom = []
+ data = ""
+ eeprom_size = 0
+ eeprom_binary = ""
+
+ # 'device' is the slave device of the current EtherCAT slave plugin
+ slave = self.Controler.CTNParent.GetSlave(self.Controler.GetSlavePos())
+ type_infos = slave.getType()
+ device, alignment = self.Controler.CTNParent.GetModuleInfos(type_infos)
+
+ if device is not None:
+ # get ConfigData for EEPROM offset 0x0000-0x000d; <Device>-<Eeprom>-<ConfigData>
+ for eeprom_element in device.getEeprom().getcontent()["value"]:
+ if eeprom_element["name"] == "ConfigData":
+ data = self.DecimalToHex(eeprom_element["value"])
+ eeprom += self.GenerateEEPROMList(data, 0, 28)
+
+ # calculate CRC for EEPROM offset 0x000e-0x000f
+ crc = 0x48
+ for segment in eeprom:
+ for i in range(8):
+ bit = crc & 0x80
+ crc = (crc << 1) | ((int(segment, 16) >> (7 - i)) & 0x01)
+ if bit:
+ crc ^= 0x07
+ for k in range(8):
+ bit = crc & 0x80
+ crc <<= 1
+ if bit:
+ crc ^= 0x07
+ eeprom.append(hex(crc)[len(hex(crc))-3:len(hex(crc))-1])
+ eeprom.append("00")
+
+ # get VendorID for EEPROM offset 0x0010-0x0013;
+ data = ""
+ for vendor_id, vendor in self.Controler.CTNParent.CTNParent.ModulesLibrary.Library.iteritems():
+ for available_device in vendor["groups"][vendor["groups"].keys()[0]]["devices"]:
+ if available_device[0] == type_infos["device_type"]:
+ data = "{:0>8x}".format(vendor_id)
+ eeprom += self.GenerateEEPROMList(data, 1, 8)
+
+ # get Product Code for EEPROM offset 0x0014-0x0017;
+ data = ""
+ if device.getType().getProductCode() is not None:
+ data = "{:0>8x}".format(ExtractHexDecValue(device.getType().getProductCode()))
+ eeprom += self.GenerateEEPROMList(data, 1, 8)
+
+ # get Revision Number for EEPROM offset 0x0018-0x001b;
+ data = ""
+ if device.getType().getRevisionNo() is not None:
+ data = "{:0>8x}".format(ExtractHexDecValue(device.getType().getRevisionNo()))
+ eeprom += self.GenerateEEPROMList(data, 1, 8)
+
+ # get Serial Number for EEPROM 0x001c-0x001f;
+ data = ""
+ if device.getType().getSerialNo() is not None:
+ data = "{:0>8x}".format(ExtractHexDecValue(device.getType().getSerialNo()))
+ eeprom += self.GenerateEEPROMList(data, 1, 8)
+
+ # get Execution Delay for EEPROM 0x0020-0x0021; not analyzed yet
+ eeprom.append("00")
+ eeprom.append("00")
+
+ # get Port0/1 Delay for EEPROM offset 0x0022-0x0025; not analyzed yet
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+
+ # reserved for EEPROM offset 0x0026-0x0027;
+ eeprom.append("00")
+ eeprom.append("00")
+
+ # get BootStrap for EEPROM offset 0x0028-0x002e; <Device>-<Eeprom>-<BootStrap>
+ data = ""
+ for eeprom_element in device.getEeprom().getcontent()["value"]:
+ if eeprom_element["name"] == "BootStrap":
+ data = "{:0>16x}".format(eeprom_element["value"])
+ eeprom += self.GenerateEEPROMList(data, 0, 16)
+
+ # get Standard Mailbox for EEPROM offset 0x0030-0x0037; <Device>-<sm>
+ data = ""
+ for sm_element in device.getSm():
+ if sm_element.getcontent() == "MBoxOut":
+ standard_receive_mailbox_offset = "{:0>4x}".format(ExtractHexDecValue(sm_element.getStartAddress()))
+ standard_receive_mailbox_size = "{:0>4x}".format(ExtractHexDecValue(sm_element.getDefaultSize()))
+ elif sm_element.getcontent() == "MBoxIn":
+ standard_send_mailbox_offset = "{:0>4x}".format(ExtractHexDecValue(sm_element.getStartAddress()))
+ standard_send_mailbox_size = "{:0>4x}".format(ExtractHexDecValue(sm_element.getDefaultSize()))
+
+ if standard_receive_mailbox_offset is None:
+ eeprom.append("00")
+ eeprom.append("00")
+ else:
+ eeprom.append(standard_receive_mailbox_offset[2:4])
+ eeprom.append(standard_receive_mailbox_offset[0:2])
+ if standard_receive_mailbox_size is None:
+ eeprom.append("00")
+ eeprom.append("00")
+ else:
+ eeprom.append(standard_receive_mailbox_size[2:4])
+ eeprom.append(standard_receive_mailbox_size[0:2])
+ if standard_send_mailbox_offset is None:
+ eeprom.append("00")
+ eeprom.append("00")
+ else:
+ eeprom.append(standard_send_mailbox_offset[2:4])
+ eeprom.append(standard_send_mailbox_offset[0:2])
+ if standard_send_mailbox_size is None:
+ eeprom.append("00")
+ eeprom.append("00")
+ else:
+ eeprom.append(standard_send_mailbox_size[2:4])
+ eeprom.append(standard_send_mailbox_size[0:2])
+
+ # get supported mailbox protocols for EEPROM offset 0x0038-0x0039;
+ data = 0
+ for mbox, bit in [(device.getMailbox().getAoE(), 0),
+ (device.getMailbox().getEoE(), 1),
+ (device.getMailbox().getCoE(), 2),
+ (device.getMailbox().getFoE(), 3),
+ (device.getMailbox().getSoE(), 4),
+ (device.getMailbox().getVoE(), 5)]:
+ if mbox is not None:
+ data += 1<<bit
+ data = "{:0>4x}".format(data)
+ eeprom.append(data[2:4])
+ eeprom.append(data[0:2])
+
+ # resereved for EEPROM offset 0x003a-0x007b;
+ for i in range(0x007b-0x003a+0x0001):
+ eeprom.append("00")
+
+ # get EEPROM size for EEPROM offset 0x007c-0x007d;
+ data = ""
+ for eeprom_element in device.getEeprom().getcontent()["value"]:
+ if eeprom_element["name"] == "ByteSize":
+ eeprom_size = int(str(eeprom_element["value"]))
+ data = "{:0>4x}".format(int(eeprom_element["value"])/1024*8-1)
+
+ if data == "":
+ eeprom.append("00")
+ eeprom.append("00")
+ else:
+ eeprom.append(data[2:4])
+ eeprom.append(data[0:2])
+
+ # Version for EEPROM 0x007e-0x007f;
+ # According to "EtherCAT Slave Device Description(V0.3.0)"
+ eeprom.append("01")
+ eeprom.append("00")
+
+ # append String Category data
+ for data in self.ExtractEEPROMStringCategory(device):
+ eeprom.append(data)
+
+ # append General Category data
+ for data in self.ExtractEEPROMGeneralCategory(device):
+ eeprom.append(data)
+
+ # append FMMU Category data
+ for data in self.ExtractEEPROMFMMUCategory(device):
+ eeprom.append(data)
+
+ # append SyncM Category data
+ for data in self.ExtractEEPROMSyncMCategory(device):
+ eeprom.append(data)
+
+ # append TxPDO Category data
+ for data in self.ExtractEEPROMPDOCategory(device, "TxPdo"):
+ eeprom.append(data)
+
+ # append RxPDO Category data
+ for data in self.ExtractEEPROMPDOCategory(device, "RxPdo"):
+ eeprom.append(data)
+
+ # append DC Category data
+ for data in self.ExtractEEPROMDCCategory(device):
+ eeprom.append(data)
+
+ # append padding
+ padding = eeprom_size-len(eeprom)
+ for i in range(padding):
+ eeprom.append("ff")
+
+ # convert binary code
+ for index in range(eeprom_size):
+ eeprom_binary = eeprom_binary + eeprom[index].decode('hex')
+
+ return eeprom_binary
+
+ def ExtractEEPROMStringCategory(self, device):
+ """
+ Extract "Strings" category data from slave ESI XML and generate EEPROM image data.
+ @param device : 'device' object in the slave ESI XML
+ @return eeprom : "Strings" category EEPROM image data
+ """
+ eeprom = []
+ self.Strings = []
+ data = ""
+ count = 0 # string counter
+ padflag = False # padding flag if category length is odd
+
+ # index information for General Category in EEPROM
+ self.GroupIdx = 0
+ self.ImgIdx = 0
+ self.OrderIdx = 0
+ self.NameIdx = 0
+
+ # flag for preventing duplicated vendor specific data
+ typeflag = False
+ grouptypeflag = False
+ groupnameflag = False
+ devnameflag = False
+ imageflag = False
+
+ # vendor specific data
+ # element1; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Type>
+ # vendor_specific_data : vendor specific data (binary type)
+ vendor_specific_data = ""
+ # vendor_spec_strings : list of vendor specific "strings" for preventing duplicated strings
+ vendor_spec_strings = []
+ for element in device.getType().getcontent():
+ data += element
+ if data is not "" and type(data) == unicode:
+ for vendor_spec_string in vendor_spec_strings:
+ if data == vendor_spec_string:
+ self.OrderIdx = vendor_spec_strings.index(data)+1
+ typeflag = True
+ break
+ if typeflag is False:
+ count += 1
+ self.Strings.append(data)
+ vendor_spec_strings.append(data)
+ typeflag = True
+ self.OrderIdx = count
+ vendor_specific_data += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ vendor_specific_data += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # element2-1; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<GroupType>
+ data = device.getGroupType()
+ if data is not None and type(data) == unicode:
+ for vendor_spec_string in vendor_spec_strings:
+ if data == vendor_spec_string:
+ self.GroupIdx = vendor_spec_strings.index(data)+1
+ grouptypeflag = True
+ break
+ if grouptypeflag is False:
+ grouptype = data
+ count += 1
+ self.Strings.append(data)
+ vendor_spec_strings.append(data)
+ grouptypeflag = True
+ self.GroupIdx = count
+ vendor_specific_data += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ vendor_specific_data += "{:0>2x}".format(ord(data[character]))
+
+ # element2-2; <EtherCATInfo>-<Groups>-<Group>-<Type>
+ if grouptypeflag is False:
+ if self.Controler.CTNParent.CTNParent.ModulesLibrary.Library is not None:
+ for vendor_id, vendor in self.Controler.CTNParent.CTNParent.ModulesLibrary.Library.iteritems():
+ for group_type, group_etc in vendor["groups"].iteritems():
+ for device_item in group_etc["devices"]:
+ if device == device_item[1]:
+ data = group_type
+ if data is not None and type(data) == unicode:
+ for vendor_spec_string in vendor_spec_strings:
+ if data == vendor_spec_string:
+ self.GroupIdx = vendor_spec_strings.index(data)+1
+ grouptypeflag = True
+ break
+ if grouptypeflag is False:
+ grouptype = data
+ count += 1
+ self.Strings.append(data)
+ vendor_spec_strings.append(data)
+ grouptypeflag = True
+ self.GroupIdx = count
+ vendor_specific_data += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ vendor_specific_data += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # element3; <EtherCATInfo>-<Descriptions>-<Groups>-<Group>-<Name(LcId is "1033")>
+ if self.Controler.CTNParent.CTNParent.ModulesLibrary.Library is not None:
+ for vendorId, vendor in self.Controler.CTNParent.CTNParent.ModulesLibrary.Library.iteritems():
+ for group_type, group_etc in vendor["groups"].iteritems():
+ for device_item in group_etc["devices"]:
+ if device == device_item[1]:
+ data = group_etc["name"]
+ if data is not "" and type(data) == unicode:
+ for vendor_spec_string in vendor_spec_strings:
+ if data == vendor_spec_string:
+ groupnameflag = True
+ break
+ if groupnameflag is False:
+ count += 1
+ self.Strings.append(data)
+ vendor_spec_strings.append(data)
+ groupnameflag = True
+ vendor_specific_data += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ vendor_specific_data += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # element4; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Name(LcId is "1033" or "1"?)>
+ for element in device.getName():
+ if element.getLcId() == 1 or element.getLcId()==1033:
+ data = element.getcontent()
+ if data is not "" and type(data) == unicode:
+ for vendor_spec_string in vendor_spec_strings:
+ if data == vendor_spec_string:
+ self.NameIdx = vendor_spec_strings.index(data)+1
+ devnameflag = True
+ break
+ if devnameflag is False:
+ count += 1
+ self.Strings.append(data)
+ vendor_spec_strings.append(data)
+ devnameflag = True
+ self.NameIdx = count
+ vendor_specific_data += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ vendor_specific_data += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # element5-1; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Image16x14>
+ if device.getcontent() is not None:
+ data = device.getcontent()["value"]
+ if data is not None and type(data) == unicode:
+ for vendor_spec_string in vendor_spec_strings:
+ if data == vendor_spec_string:
+ self.ImgIdx = vendor_spec_strings.index(data)+1
+ imageflag = True
+ break
+ if imageflag is False:
+ count += 1
+ self.Strings.append(data)
+ vendor_spec_strings.append(data)
+ imageflag = True
+ self.ImgIdx = count
+ vendor_specific_data += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ vendor_specific_data += "{:0>2x}".format(ord(data[character]))
+
+ # element5-2; <EtherCATInfo>-<Descriptions>-<Groups>-<Group>-<Image16x14>
+ if imageflag is False:
+ if self.Controler.CTNParent.CTNParent.ModulesLibrary.Library is not None:
+ for vendor_id, vendor in self.Controler.CTNParent.CTNParent.ModulesLibrary.Library.iteritems():
+ for group_type, group_etc in vendor["groups"].iteritems():
+ for device_item in group_etc["devices"]:
+ if device == device_item[1]:
+ data = group_etc["value"]
+ if data is not None and type(data) == unicode:
+ for vendor_spec_string in vendor_spec_strings:
+ if data == vendor_spec_string:
+ self.ImgIdx = vendor_spec_strings.index(data)+1
+ imageflag = True
+ break
+ if imageflag is False:
+ count += 1
+ self.Strings.append(data)
+ vendor_spec_strings.append(data)
+ imageflag = True
+ self.ImgIdx = count
+ vendor_specific_data += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ vendor_specific_data += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # DC related elements
+ # <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Dc>-<OpMode>-<Name>
+ dc_related_elements = ""
+ if device.getDc() is not None:
+ for element in device.getDc().getOpMode():
+ data = element.getName()
+ if data is not "":
+ count += 1
+ self.Strings.append(data)
+ dc_related_elements += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ dc_related_elements += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # Input elements(TxPDO)
+ # <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<TxPdo>; Name
+ input_elements = ""
+ inputs = []
+ for element in device.getTxPdo():
+ for name in element.getName():
+ data = name.getcontent()
+ for input in inputs:
+ if data == input:
+ data = ""
+ if data is not "":
+ count += 1
+ self.Strings.append(data)
+ inputs.append(data)
+ input_elements += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ input_elements += "{:0>2x}".format(ord(data[character]))
+ data = ""
+ for entry in element.getEntry():
+ for name in entry.getName():
+ data = name.getcontent()
+ for input in inputs:
+ if data == input:
+ data = ""
+ if data is not "":
+ count += 1
+ self.Strings.append(data)
+ inputs.append(data)
+ input_elements += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ input_elements += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # Output elements(RxPDO)
+ # <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<RxPdo>; Name
+ output_elements = ""
+ outputs = []
+ for element in device.getRxPdo():
+ for name in element.getName():
+ data = name.getcontent()
+ for output in outputs:
+ if data == output:
+ data = ""
+ if data is not "":
+ count += 1
+ self.Strings.append(data)
+ outputs.append(data)
+ output_elements += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ output_elements += "{:0>2x}".format(ord(data[character]))
+ data = ""
+ for entry in element.getEntry():
+ for name in entry.getName():
+ data = name.getcontent()
+ for output in outputs:
+ if data == output:
+ data = ""
+ if data is not "":
+ count += 1
+ self.Strings.append(data)
+ outputs.append(data)
+ output_elements += "{:0>2x}".format(len(data))
+ for character in range(len(data)):
+ output_elements += "{:0>2x}".format(ord(data[character]))
+ data = ""
+
+ # form eeprom data
+ # category header
+ eeprom.append("0a")
+ eeprom.append("00")
+ # category length (word); 1 word is 4 bytes. "+2" is the length of string's total number
+ length = len(vendor_specific_data + dc_related_elements + input_elements + output_elements) + 2
+ if length%4 == 0:
+ pass
+ else:
+ length +=length%4
+ padflag = True
+ eeprom.append("{:0>4x}".format(length/4)[2:4])
+ eeprom.append("{:0>4x}".format(length/4)[0:2])
+ # total numbers of strings
+ eeprom.append("{:0>2x}".format(count))
+ for element in [vendor_specific_data,
+ dc_related_elements,
+ input_elements,
+ output_elements]:
+ for iter in range(len(element)/2):
+ if element == "":
+ eeprom.append("00")
+ else:
+ eeprom.append(element[0:2])
+ element = element[2:len(element)]
+ # padding if length is odd bytes
+ if padflag is True:
+ eeprom.append("ff")
+
+ return eeprom
+
+ def ExtractEEPROMGeneralCategory(self, device):
+ """
+ Extract "General" category data from slave ESI XML and generate EEPROM image data.
+ @param device : 'device' object in the slave ESI XML
+ @return eeprom : "Strings" category EEPROM image data
+ """
+ eeprom = []
+ data = ""
+
+ # category header
+ eeprom.append("1e")
+ eeprom.append("00")
+
+ # category length
+ eeprom.append("10")
+ eeprom.append("00")
+
+ # word 1 : Group Type index and Image index in STRINGS Category
+ eeprom.append("{:0>2x}".format(self.GroupIdx))
+ eeprom.append("{:0>2x}".format(self.ImgIdx))
+
+ # word 2 : Device Type index and Device Name index in STRINGS Category
+ eeprom.append("{:0>2x}".format(self.OrderIdx))
+ eeprom.append("{:0>2x}".format(self.NameIdx))
+
+ # word 3 : Physical Layer Port info. and CoE Details
+ eeprom.append("01") # Physical Layer Port info - assume 01
+ # CoE Details; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Mailbox>-<CoE>
+ coe_details = 0
+ if device.getMailbox().getCoE() is not None:
+ coe_details = 1 # sdo enabled
+ for attr, bit in [(device.getMailbox().getCoE().getSdoInfo(), 1),
+ (device.getMailbox().getCoE().getPdoAssign(), 2),
+ (device.getMailbox().getCoE().getPdoConfig(), 3),
+ (device.getMailbox().getCoE().getPdoUpload(), 4),
+ (device.getMailbox().getCoE().getCompleteAccess(), 5)]:
+ if attr==1 or attr==True:
+ coe_details += 1<<bit
+ eeprom.append("{:0>2x}".format(coe_details))
+
+ # word 4 : FoE Details and EoE Details
+ # FoE Details; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Mailbox>-<FoE>
+ if device.getMailbox().getFoE() is not None:
+ eeprom.append("01")
+ else:
+ eeprom.append("00")
+ # EoE Details; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Mailbox>-<EoE>
+ if device.getMailbox().getEoE() is not None:
+ eeprom.append("01")
+ else:
+ eeprom.append("00")
+
+ # word 5 : SoE Channels(reserved) and DS402 Channels
+ # SoE Details; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Mailbox>-<SoE>
+ if device.getMailbox().getSoE() is not None:
+ eeprom.append("01")
+ else:
+ eeprom.append("00")
+ # DS402Channels; <EtherCATInfo>-<Descriptions>-<Devices>-<Device>-<Mailbox>-<CoE>: DS402Channels
+ if device.getMailbox().getCoE().getDS402Channels() == True \
+ or device.getMailbox().getCoE().getDS402Channels() == 1:
+ eeprom.append("01")
+ else:
+ eeprom.append("00")
+
+ # word 6 : SysmanClass(reserved) and Flags
+ eeprom.append("00") # reserved
+ # Flags
+ en_safeop = False
+ en_lrw = False
+ if device.getType().getTcCfgModeSafeOp() == True \
+ or device.getType().getTcCfgModeSafeOp() == 1:
+ en_safeop = True
+ if device.getType().getUseLrdLwr() == True \
+ or device.getType().getUseLrdLwr() == 1:
+ en_lrw = True
+
+ flags = "0b"+"000000"+str(int(en_lrw))+str(int(en_safeop))
+ eeprom.append("{:0>2x}".format(int(flags, 2)))
+
+ # word 7 : Current On EBus (assume 0x0000)
+ eeprom.append("00")
+ eeprom.append("00")
+ # after word 7; couldn't analyze yet
+ eeprom.append("03")
+ eeprom.append("00")
+ eeprom.append("11")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+ eeprom.append("00")
+
+ return eeprom
+
+ def ExtractEEPROMFMMUCategory(self, device):
+ """
+ Extract "FMMU" category data from slave ESI XML and generate EEPROM image data.
+ @param device : 'device' object in the slave ESI XML
+ @return eeprom : "Strings" category EEPROM image data
+ """
+ eeprom = []
+ data = ""
+ count = 0 # number of FMMU
+ padflag = False
+
+ for fmmu in device.getFmmu():
+ count += 1
+ if fmmu.getcontent() == "Outputs":
+ data += "01"
+ if fmmu.getcontent() == "Inputs":
+ data += "02"
+ if fmmu.getcontent() == "MBoxState":
+ data += "03"
+
+ # construct of EEPROM data
+ if data is not "":
+ # category header
+ eeprom.append("28")
+ eeprom.append("00")
+ # category length
+ if count%2 == 1:
+ padflag = True
+ eeprom.append("{:0>4x}".format((count+1)/2)[2:4])
+ eeprom.append("{:0>4x}".format((count+1)/2)[0:2])
+ else:
+ eeprom.append("{:0>4x}".format((count)/2)[2:4])
+ eeprom.append("{:0>4x}".format((count)/2)[0:2])
+ for i in range(count):
+ if data == "":
+ eeprom.append("00")
+ else:
+ eeprom.append(data[0:2])
+ data = data[2:len(data)]
+ # padding if length is odd bytes
+ if padflag is True:
+ eeprom.append("ff")
+
+ return eeprom
+
+ def ExtractEEPROMSyncMCategory(self, device):
+ """
+ Extract "SyncM" category data from slave ESI XML and generate EEPROM image data.
+ @param device : 'device' object in the slave ESI XML
+ @return eeprom : "Strings" category EEPROM image data
+ """
+ eeprom = []
+ data = ""
+ number = {"MBoxOut":"01", "MBoxIn":"02", "Outputs":"03", "Inputs":"04"}
+
+ for sm in device.getSm():
+ for attr in [sm.getStartAddress(),
+ sm.getDefaultSize(),
+ sm.getControlByte()]:
+ if attr is not None:
+ data += "{:0>4x}".format(ExtractHexDecValue(attr))[2:4]
+ data += "{:0>4x}".format(ExtractHexDecValue(attr))[0:2]
+ else:
+ data += "0000"
+ if sm.getEnable() == "1" or sm.getEnable() == True:
+ data += "01"
+ else:
+ data += "00"
+ data += number[sm.getcontent()]
+
+ if data is not "":
+ # category header
+ eeprom.append("29")
+ eeprom.append("00")
+ # category length
+ eeprom.append("{:0>4x}".format(len(data)/4)[2:4])
+ eeprom.append("{:0>4x}".format(len(data)/4)[0:2])
+ for i in range(len(data)/2):
+ if data == "":
+ eeprom.append("00")
+ else:
+ eeprom.append(data[0:2])
+ data = data[2:len(data)]
+
+ return eeprom
+
+ def ExtractEEPROMPDOCategory(self, device, pdotype):
+ """
+ Extract ""PDO (Tx, Rx)"" category data from slave ESI XML and generate EEPROM image data.
+ @param device : 'device' object in the slave ESI XML
+ @param pdotype : identifier whether "TxPDO" or "RxPDO".
+ @return eeprom : "Strings" category EEPROM image data
+ """
+ eeprom = []
+ data = ""
+ count = 0
+ en_fixed = False
+ en_mandatory = False
+ en_virtual = False
+
+ for element in eval("device.get%s()"%pdotype):
+ # PDO Index
+ data += "{:0>4x}".format(ExtractHexDecValue(element.getIndex().getcontent()))[2:4]
+ data += "{:0>4x}".format(ExtractHexDecValue(element.getIndex().getcontent()))[0:2]
+ # Number of Entries
+ data += "{:0>2x}".format(len(element.getEntry()))
+ # About Sync Manager
+ if element.getSm() is not None:
+ data += "{:0>2x}".format(element.getSm())
+ else:
+ data += "ff"
+ # Reference to DC Synch (according to ET1100 documentation) - assume 0
+ data += "00"
+ # Name Index
+ objname = ""
+ for name in element.getName():
+ objname = name.getcontent()
+ for name in self.Strings:
+ count += 1
+ if objname == name:
+ break
+ if len(self.Strings)+1 == count:
+ data += "00"
+ else:
+ data += "{:0>2x}".format(count)
+ count = 0
+ # Flags; by Fixed, Mandatory, Virtual attributes ?
+ if element.getFixed() == True or 1:
+ en_fixed = True
+ if element.getMandatory() == True or 1:
+ en_mandatory = True
+ if element.getVirtual() == True or element.getVirtual():
+ en_virtual = True
+ data += str(int(en_fixed)) + str(int(en_mandatory)) + str(int(en_virtual)) + "0"
+
+ for entry in element.getEntry():
+ # Entry Index
+ data += "{:0>4x}".format(ExtractHexDecValue(entry.getIndex().getcontent()))[2:4]
+ data += "{:0>4x}".format(ExtractHexDecValue(entry.getIndex().getcontent()))[0:2]
+ # Subindex
+ data += "{:0>2x}".format(int(entry.getSubIndex()))
+ # Entry Name Index
+ objname = ""
+ for name in entry.getName():
+ objname = name.getcontent()
+ for name in self.Strings:
+ count += 1
+ if objname == name:
+ break
+ if len(self.Strings)+1 == count:
+ data += "00"
+ else:
+ data += "{:0>2x}".format(count)
+ count = 0
+ # DataType
+ if entry.getDataType() is not None:
+ if entry.getDataType().getcontent() in self.BaseDataTypeDict:
+ data += self.BaseDataTypeDict[entry.getDataType().getcontent()]
+ else:
+ data += "00"
+ else:
+ data += "00"
+ # BitLen
+ if entry.getBitLen() is not None:
+ data += "{:0>2x}".format(int(entry.getBitLen()))
+ else:
+ data += "00"
+ # Flags; by Fixed attributes ?
+ en_fixed = False
+ if entry.getFixed() == True or entry.getFixed() == 1:
+ en_fixed = True
+ data += str(int(en_fixed)) + "000"
+
+ if data is not "":
+ # category header
+ if pdotype == "TxPdo":
+ eeprom.append("32")
+ elif pdotype == "RxPdo":
+ eeprom.append("33")
+ else:
+ eeprom.append("00")
+ eeprom.append("00")
+ # category length
+ eeprom.append("{:0>4x}".format(len(data)/4)[2:4])
+ eeprom.append("{:0>4x}".format(len(data)/4)[0:2])
+ data = str(data.lower())
+ for i in range(len(data)/2):
+ if data == "":
+ eeprom.append("00")
+ else:
+ eeprom.append(data[0:2])
+ data = data[2:len(data)]
+
+ return eeprom
+
+ def ExtractEEPROMDCCategory(self, device):
+ """
+ Extract "DC(Distributed Clock)" category data from slave ESI XML and generate EEPROM image data.
+ @param device : 'device' object in the slave ESI XML
+ @return eeprom : "Strings" category EEPROM image data
+ """
+ eeprom = []
+ data = ""
+ count = 0
+ namecount = 0
+
+ if device.getDc() is not None:
+ for element in device.getDc().getOpMode():
+ count += 1
+ # assume that word 1-7 are 0x0000
+ data += "0000"
+ data += "0000"
+ data += "0000"
+ data += "0000"
+ data += "0000"
+ data += "0000"
+ data += "0000"
+ # word 8-10
+ # AssignActivate
+ if element.getAssignActivate() is not None:
+ data += "{:0>4x}".format(ExtractHexDecValue(element.getAssignActivate()))[2:4]
+ data += "{:0>4x}".format(ExtractHexDecValue(element.getAssignActivate()))[0:2]
+ else:
+ data += "0000"
+ # Factor of CycleTimeSync0 ? and default is 1?
+ if element.getCycleTimeSync0() is not None:
+ if element.getCycleTimeSync0().getFactor() is not None:
+ data += "{:0>2x}".format(int(element.getCycleTimeSync0().getFactor()))
+ data += "00"
+ else:
+ data += "0100"
+ else:
+ data += "0100"
+ # Index of Name in STRINGS Category
+ # Name Index
+ objname = ""
+ for name in element.getName():
+ objname += name
+ for name in self.Strings:
+ namecount += 1
+ if objname == name:
+ break
+ if len(self.Strings)+1 == namecount:
+ data += "00"
+ else:
+ data += "{:0>2x}".format(namecount)
+ namecount = 0
+ data += "00"
+ # assume that word 11-12 are 0x0000
+ data += "0000"
+ data += "0000"
+
+ if data is not "":
+ # category header
+ eeprom.append("3c")
+ eeprom.append("00")
+ # category length
+ eeprom.append("{:0>4x}".format(len(data)/4)[2:4])
+ eeprom.append("{:0>4x}".format(len(data)/4)[0:2])
+ data = str(data.lower())
+ for i in range(len(data)/2):
+ if data == "":
+ eeprom.append("00")
+ else:
+ eeprom.append(data[0:2])
+ data = data[2:len(data)]
+
+ return eeprom
+
+ #-------------------------------------------------------------------------------
+ # Used Register Access
+ #-------------------------------------------------------------------------------
+ def RegRead(self, offset, length):
+ """
+ Read slave ESC register content using "ethercat reg_read -p %d %s %s" command.
+ Command example : "ethercat reg_read -p 0 0x0c00 0x0400"
+ @param offset : register address
+ @param length : register length
+ @return return_val : register data
+ """
+ error, return_val = self.Controler.RemoteExec(REG_READ%(self.Controler.GetSlavePos(), offset, length), return_val = None)
+ return return_val
+
+ def RegWrite(self, address, data):
+ """
+ Write data to slave ESC register using "ethercat reg_write -p %d %s %s" command.
+ Command example : "ethercat reg_write -p 0 0x0c04 0x0001"
+ @param address : register address
+ @param data : data to write
+ @return return_val : the execution result of "ethercat reg_write" (for error check)
+ """
+ error, return_val = self.Controler.RemoteExec(REG_WRITE%(self.Controler.GetSlavePos(), address, data), return_val = None)
+ return return_val
+
+ def Rescan(self):
+ """
+ Synchronize EEPROM data in master controller with the data in slave device after EEPROM write.
+ Command example : "ethercat rescan -p 0"
+ """
+ error, return_val = self.Controler.RemoteExec(RESCAN%(self.Controler.GetSlavePos()), return_val = None)
+
+ #-------------------------------------------------------------------------------
+ # Common Use Methods
+ #-------------------------------------------------------------------------------
+ def CheckConnect(self, cyclic_flag):
+ """
+ Check connection status (1) between Beremiz and the master (2) between the master and the slave.
+ @param cyclic_flag: 0 - one shot, 1 - periodic
+ @return True or False
+ """
+ if self.Controler.GetCTRoot()._connector is not None:
+ # Check connection between the master and the slave.
+ # Command example : "ethercat xml -p 0"
+ error, return_val = self.Controler.RemoteExec(SLAVE_XML%(self.Controler.GetSlavePos()), return_val = None)
+ number_of_lines = return_val.split("\n")
+ if len(number_of_lines) <= 2 : # No slave connected to the master controller
+ if not cyclic_flag :
+ self.CreateErrorDialog('No connected slaves')
+ return False
+
+ elif len(number_of_lines) > 2 :
+ return True
+ else:
+ # The master controller is not connected to Beremiz host
+ if not cyclic_flag :
+ self.CreateErrorDialog('PLC not connected!')
+ return False
+
+ def CreateErrorDialog(self, mention):
+ """
+ Create a dialog to indicate error or warning.
+ @param mention : Error String
+ """
+ app_frame = self.Controler.GetCTRoot().AppFrame
+ dlg = wx.MessageDialog (app_frame, mention,
+ ' Warning...',
+ wx.OK | wx.ICON_INFORMATION)
+ dlg.ShowModal()
+ dlg.Destroy()
--- a/etherlab/ConfigEditor.py Mon Jun 03 08:24:08 2013 +0200
+++ b/etherlab/ConfigEditor.py Wed Apr 02 15:03:32 2014 +0200
@@ -13,6 +13,10 @@
from util.BitmapLibrary import GetBitmap
from controls.CustomStyledTextCtrl import NAVIGATION_KEYS
+# -----------------------------------------------------------------------
+from EtherCATManagementEditor import EtherCATManagementTreebook, MasterStatePanelClass
+# -----------------------------------------------------------------------
+
[ETHERCAT_VENDOR, ETHERCAT_GROUP, ETHERCAT_DEVICE] = range(3)
def AppendMenu(parent, help, id, kind, text):
@@ -240,7 +244,10 @@
class NodeEditor(ConfTreeNodeEditor):
CONFNODEEDITOR_TABS = [
- (_("Ethercat node"), "_create_EthercatNodeEditor")]
+ (_("Ethercat node"), "_create_EthercatNodeEditor"),
+ # Add Notebook Tab for EtherCAT Management Treebook
+ (_("EtherCAT Management"), "_create_EtherCATManagementEditor")
+ ]
def _create_EthercatNodeEditor(self, prnt):
self.EthercatNodeEditor = wx.Panel(prnt, style=wx.TAB_TRAVERSAL)
@@ -264,6 +271,9 @@
def __init__(self, parent, controler, window):
ConfTreeNodeEditor.__init__(self, parent, controler, window)
+ # add Contoler for use EthercatSlave.py Method
+ self.Controler = controler
+
def GetBufferState(self):
return False, False
@@ -272,8 +282,39 @@
self.NodeVariables.RefreshView()
+ # -------------------For EtherCAT Management ----------------------------------------------
+ def _create_EtherCATManagementEditor(self, prnt):
+ self.EtherCATManagementEditor = wx.ScrolledWindow(prnt,
+ style=wx.TAB_TRAVERSAL|wx.HSCROLL|wx.VSCROLL)
+ self.EtherCATManagementEditor.Bind(wx.EVT_SIZE, self.OnResize)
+
+ self.EtherCATManagermentEditor_Main_Sizer = wx.FlexGridSizer(cols=1, hgap=0, rows=2, vgap=5)
+ self.EtherCATManagermentEditor_Main_Sizer.AddGrowableCol(0)
+ self.EtherCATManagermentEditor_Main_Sizer.AddGrowableRow(0)
+
+ self.EtherCATManagementTreebook = EtherCATManagementTreebook(self.EtherCATManagementEditor, self.Controler, self)
+
+ self.EtherCATManagermentEditor_Main_Sizer.AddSizer(self.EtherCATManagementTreebook, border=10, flag=wx.GROW)
+
+ self.EtherCATManagementEditor.SetSizer(self.EtherCATManagermentEditor_Main_Sizer)
+ return self.EtherCATManagementEditor
+
+ def OnResize(self, event):
+ self.EtherCATManagementEditor.GetBestSize()
+ xstart, ystart = self.EtherCATManagementEditor.GetViewStart()
+ window_size = self.EtherCATManagementEditor.GetClientSize()
+ maxx, maxy = self.EtherCATManagementEditor.GetMinSize()
+ posx = max(0, min(xstart, (maxx - window_size[0]) / SCROLLBAR_UNIT))
+ posy = max(0, min(ystart, (maxy - window_size[1]) / SCROLLBAR_UNIT))
+ self.EtherCATManagementEditor.Scroll(posx, posy)
+ self.EtherCATManagementEditor.SetScrollbars(SCROLLBAR_UNIT, SCROLLBAR_UNIT,
+ maxx / SCROLLBAR_UNIT, maxy / SCROLLBAR_UNIT, posx, posy)
+ event.Skip()
+ # -------------------------------------------------------------------------------------------------------
+
CIA402NodeEditor = NodeEditor
+
def GetProcessVariablesTableColnames():
_ = lambda x : x
return ["#", _("Name"),
@@ -537,7 +578,36 @@
class MasterEditor(ConfTreeNodeEditor):
CONFNODEEDITOR_TABS = [
- (_("Network"), "_create_EthercatMasterEditor")]
+ (_("Network"), "_create_EthercatMasterEditor"),
+ (_("Master State"), "_create_MasterStateEditor")
+ ]
+
+ def _create_MasterStateEditor(self, prnt):
+ self.MasterStateEditor = wx.ScrolledWindow(prnt, style=wx.TAB_TRAVERSAL|wx.HSCROLL|wx.VSCROLL)
+ self.MasterStateEditor.Bind(wx.EVT_SIZE, self.OnResize)
+
+ self.MasterStateEditor_Panel_Main_Sizer = wx.FlexGridSizer(cols=1, hgap=0, rows=2, vgap=5)
+ self.MasterStateEditor_Panel_Main_Sizer.AddGrowableCol(0)
+ self.MasterStateEditor_Panel_Main_Sizer.AddGrowableRow(0)
+
+ self.MasterStateEditor_Panel = MasterStatePanelClass(self.MasterStateEditor, self.Controler)
+
+ self.MasterStateEditor_Panel_Main_Sizer.AddSizer(self.MasterStateEditor_Panel, border=10, flag=wx.GROW)
+
+ self.MasterStateEditor.SetSizer(self.MasterStateEditor_Panel_Main_Sizer)
+ return self.MasterStateEditor
+
+ def OnResize(self, event):
+ self.MasterStateEditor.GetBestSize()
+ xstart, ystart = self.MasterStateEditor.GetViewStart()
+ window_size = self.MasterStateEditor.GetClientSize()
+ maxx, maxy = self.MasterStateEditor.GetMinSize()
+ posx = max(0, min(xstart, (maxx - window_size[0]) / SCROLLBAR_UNIT))
+ posy = max(0, min(ystart, (maxy - window_size[1]) / SCROLLBAR_UNIT))
+ self.MasterStateEditor.Scroll(posx, posy)
+ self.MasterStateEditor.SetScrollbars(SCROLLBAR_UNIT, SCROLLBAR_UNIT,
+ maxx / SCROLLBAR_UNIT, maxy / SCROLLBAR_UNIT, posx, posy)
+ event.Skip()
def _create_EthercatMasterEditor(self, prnt):
self.EthercatMasterEditor = wx.ScrolledWindow(prnt,
@@ -639,6 +709,10 @@
def __init__(self, parent, controler, window):
ConfTreeNodeEditor.__init__(self, parent, controler, window)
+ # ------------------------------------------------------------------
+ self.Controler = controler
+ # ------------------------------------------------------------------
+
self.ProcessVariables = []
self.CellShown = None
self.NodesFilterFirstCharacter = True
@@ -968,6 +1042,33 @@
self.EthercatMasterEditor.SetScrollbars(SCROLLBAR_UNIT, SCROLLBAR_UNIT,
maxx / SCROLLBAR_UNIT, maxy / SCROLLBAR_UNIT, posx, posy)
event.Skip()
+
+ #def OnButtonClick(self, event):
+ # self.MasterState = self.Controler.getMasterState()
+ # if self.MasterState:
+ # self.Phase.SetValue(self.MasterState["phase"])
+ # self.Active.SetValue(self.MasterState["active"])
+ # self.SlaveCount.SetValue(self.MasterState["slave"])
+ # self.MacAddress.SetValue(self.MasterState["MAC"])
+ # self.LinkState.SetValue(self.MasterState["link"])
+ # self.TxFrames.SetValue(self.MasterState["TXframe"])
+ # self.RxFrames.SetValue(self.MasterState["RXframe"])
+ # self.TxByte.SetValue(self.MasterState["TXbyte"])
+ # self.TxError.SetValue(self.MasterState["TXerror"])
+ # self.LostFrames.SetValue(self.MasterState["lost"])
+
+ # self.TxFrameRate1.SetValue(self.MasterState["TXframerate1"])
+ # self.TxFrameRate2.SetValue(self.MasterState["TXframerate2"])
+ # self.TxFrameRate3.SetValue(self.MasterState["TXframerate3"])
+ # self.TxRate1.SetValue(self.MasterState["TXrate1"])
+ # self.TxRate2.SetValue(self.MasterState["TXrate2"])
+ # self.TxRate3.SetValue(self.MasterState["TXrate3"])
+ # self.LossRate1.SetValue(self.MasterState["loss1"])
+ # self.LossRate2.SetValue(self.MasterState["loss2"])
+ # self.LossRate3.SetValue(self.MasterState["loss3"])
+ # self.FrameLoss1.SetValue(self.MasterState["frameloss1"])
+ # self.FrameLoss2.SetValue(self.MasterState["frameloss2"])
+ # self.FrameLoss3.SetValue(self.MasterState["frameloss3"])
class LibraryEditorSizer(wx.FlexGridSizer):
@@ -1289,5 +1390,4 @@
self.ModuleLibraryEditor.SetScrollbars(SCROLLBAR_UNIT, SCROLLBAR_UNIT,
maxx / SCROLLBAR_UNIT, maxy / SCROLLBAR_UNIT, posx, posy)
event.Skip()
-
-
+
\ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/etherlab/EtherCATManagementEditor.py Wed Apr 02 15:03:32 2014 +0200
@@ -0,0 +1,2223 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+#This file is part of Beremiz, a Integrated Development Environment for
+#programming IEC 61131-3 automates supporting EtherCAT.
+#
+#Copyright (C) 2013: Real-Time & Embedded Systems (RTES) Lab., University of Seoul
+#
+#See COPYING file for copyrights details.
+#
+#This library 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.1 of the License, or (at your option) any later version.
+#
+#This library 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.
+#
+#You should have received a copy of the GNU General Public
+#License along with this library; if not, write to the Free Software
+#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+
+import os
+
+import wx
+import wx.grid
+import wx.gizmos
+import wx.lib.buttons
+
+# --------------------------------------------------------------------
+from controls import CustomGrid, CustomTable
+# --------------------------------------------------------------------
+
+# ------------ for SDO Management --------------------
+import string
+import wx.grid as gridlib
+#-------------------------------------------------------------
+
+# ------------ for register management ---------------
+from xml.dom import minidom
+#-------------------------------------------------------------
+
+# ----------------------------- For Sync Manager Table -----------------------------------
+def GetSyncManagersTableColnames():
+ """
+ Returns column names of SyncManager Table in Slave state panel.
+ """
+ _ = lambda x : x
+ return ["#", _("Name"), _("Start Address"), _("Default Size"), _("Control Byte"), _("Enable")]
+
+#-------------------------------------------------------------------------------
+# Sync Managers Table
+#-------------------------------------------------------------------------------
+class SyncManagersTable(CustomTable):
+ def GetValue(self, row, col):
+ if row < self.GetNumberRows():
+ if col == 0:
+ return row
+ return self.data[row].get(self.GetColLabelValue(col, False), "")
+
+#-------------------------------------------------------------------------------
+# EtherCAT Management Treebook
+#-------------------------------------------------------------------------------
+class EtherCATManagementTreebook(wx.Treebook):
+ def __init__(self, parent, controler, node_editor):
+ """
+ Constructor
+ @param parent: Reference to the parent wx.ScrolledWindow object
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ @param node_editor: Reference to Beremiz frame
+ """
+ wx.Treebook.__init__(self, parent, -1, size=wx.DefaultSize, style=wx.BK_DEFAULT)
+ self.parent = parent
+ self.Controler = controler
+ self.NodeEditor = node_editor
+
+ self.EtherCATManagementClassObject = {}
+
+ # fill EtherCAT Management Treebook
+ for pname, pclass, subs in [
+ ("Slave State", SlaveStatePanelClass, []),
+ ("SDO Management", SDOPanelClass, []),
+ ("PDO Monitoring", PDOPanelClass, []),
+ ("ESC Management", EEPROMAccessPanel, [
+ ("Smart View", SlaveSiiSmartView),
+ ("Hex View", HexView)]),
+ ("Register Access", RegisterAccessPanel, [])]:
+ self.AddPage(pclass(self, self.Controler), pname)
+ for spname, spclass in subs:
+ self.AddSubPage(spclass(self, self.Controler), spname)
+
+ self.Bind(wx.EVT_TREEBOOK_PAGE_CHANGED, self.OnPageChanged)
+ self.Bind(wx.EVT_TREEBOOK_PAGE_CHANGING, self.OnPageChanging)
+
+ def OnPageChanged(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = event.GetSelection()
+ event.Skip()
+
+ def OnPageChanging(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = event.GetSelection()
+ event.Skip()
+
+#-------------------------------------------------------------------------------
+# For SlaveState Panel
+#-------------------------------------------------------------------------------
+class SlaveStatePanelClass(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent EtherCATManagementTreebook class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Panel.__init__(self, parent, -1, (0, 0), size=wx.DefaultSize, style = wx.SUNKEN_BORDER)
+ self.Controler = controler
+ self.parent = parent
+
+ # initialize SlaveStatePanel UI dictionaries
+ self.StaticBoxDic = {}
+ self.StaticTextDic = {}
+ self.TextCtrlDic = {}
+ self.ButtonDic = {}
+
+ # iniitalize BoxSizer and FlexGridSizer
+ self.SizerDic = {
+ "SlaveState_main_sizer" : wx.BoxSizer(wx.VERTICAL),
+ "SlaveState_inner_main_sizer" : wx.FlexGridSizer(cols=1, hgap=50, rows=3, vgap=10),
+ "SlaveInfosDetailsInnerSizer" : wx.FlexGridSizer(cols=4, hgap=10, rows=2, vgap=10),
+ "SyncManagerInnerSizer" : wx.FlexGridSizer(cols=1, hgap=5, rows=1, vgap=5),
+ "SlaveState_sizer" : wx.FlexGridSizer(cols=1, hgap=10, rows=2, vgap=10),
+ "SlaveState_up_sizer" : wx.FlexGridSizer(cols=4, hgap=10, rows=2, vgap=10),
+ "SlaveState_down_sizer" : wx.FlexGridSizer(cols=2, hgap=10, rows=1, vgap=10)}
+
+ # initialize StaticBox and StaticBoxSizer
+ for box_name, box_label in [
+ ("SlaveInfosDetailsBox", "Slave Informations"),
+ ("SyncManagerBox", "Sync Manager"),
+ ("SlaveStateBox", "Slave State Transition && Monitoring")]:
+ self.StaticBoxDic[box_name] = wx.StaticBox(self, label=_(box_label))
+ self.SizerDic[box_name] = wx.StaticBoxSizer(self.StaticBoxDic[box_name])
+
+ for statictext_name, statictext_label, textctrl_name in [
+ ("VendorLabel", "Vendor:", "vendor"),
+ ("ProductcodeLabel", "Product code:", "product_code"),
+ ("RevisionnumberLabel", "Slave Count:", "revision_number"),
+ ("PhysicsLabel", "Physics:", "physics")]:
+ self.StaticTextDic[statictext_name] = wx.StaticText(self, label=_(statictext_label))
+ self.TextCtrlDic[textctrl_name] = wx.TextCtrl(self, size=wx.Size(130, 24), style=wx.TE_READONLY)
+ self.SizerDic["SlaveInfosDetailsInnerSizer"].AddMany([self.StaticTextDic[statictext_name],
+ self.TextCtrlDic[textctrl_name]])
+
+ self.SizerDic["SlaveInfosDetailsBox"].AddSizer(self.SizerDic["SlaveInfosDetailsInnerSizer"])
+
+ self.SyncManagersGrid = CustomGrid(self, size=wx.Size(605,155), style=wx.VSCROLL)
+
+ self.SizerDic["SyncManagerInnerSizer"].Add(self.SyncManagersGrid)
+ self.SizerDic["SyncManagerBox"].Add(self.SizerDic["SyncManagerInnerSizer"])
+
+ for button_name, button_id, button_label, button_tooltipstring, event_method, sub_item in [
+ ("InitButton", 0, "INIT", "State Transition to \"Init\" State", self.OnButtonClick, []),
+ ("PreOPButton", 1, "PREOP", "State Transition to \"PreOP\" State", self.OnButtonClick, [
+ ("TargetStateLabel", "Target State:" , "TargetState")]),
+ ("SafeOPButton", 2, "SAFEOP", "State Transition to \"SafeOP\" State", self.OnButtonClick, []),
+ ("OPButton", 3, "OP", "State Transition to \"OP\" State", self.OnButtonClick, [
+ ("CurrentStateLabel", "Current State:", "CurrentState")])]:
+ self.ButtonDic[button_name] = wx.Button(self, id=button_id ,label=_(button_label))
+ self.ButtonDic[button_name].Bind(wx.EVT_BUTTON, event_method)
+ self.ButtonDic[button_name].SetToolTipString(button_tooltipstring)
+ self.SizerDic["SlaveState_up_sizer"].Add(self.ButtonDic[button_name])
+ for statictext_name, statictext_label, textctrl_name in sub_item :
+ self.StaticTextDic[statictext_name] = wx.StaticText(self, label=_(statictext_label))
+ self.TextCtrlDic[textctrl_name] = wx.TextCtrl(self, size=wx.DefaultSize, style=wx.TE_READONLY)
+ self.SizerDic["SlaveState_up_sizer"].AddMany([self.StaticTextDic[statictext_name],
+ self.TextCtrlDic[textctrl_name]])
+
+ for button_name, button_label, button_tooltipstring, event_method in [
+ ("StartTimerButton", "Start State Monitoring", "Slave State Update Restart", self.StartTimer),
+ ("StopTimerButton", "Stop State Monitoring", "Slave State Update Stop", self.CurrentStateThreadStop)]:
+ self.ButtonDic[button_name] = wx.Button(self, label=_(button_label))
+ self.ButtonDic[button_name].Bind(wx.EVT_BUTTON, event_method)
+ self.ButtonDic[button_name].SetToolTipString(button_tooltipstring)
+ self.SizerDic["SlaveState_down_sizer"].Add(self.ButtonDic[button_name])
+
+ self.SizerDic["SlaveState_sizer"].AddMany([self.SizerDic["SlaveState_up_sizer"],
+ self.SizerDic["SlaveState_down_sizer"]])
+
+ self.SizerDic["SlaveStateBox"].Add(self.SizerDic["SlaveState_sizer"])
+
+ self.SizerDic["SlaveState_inner_main_sizer"].AddMany([
+ self.SizerDic["SlaveInfosDetailsBox"], self.SizerDic["SyncManagerBox"],
+ self.SizerDic["SlaveStateBox"]])
+
+ self.SizerDic["SlaveState_main_sizer"].Add(self.SizerDic["SlaveState_inner_main_sizer"])
+
+ self.SetSizer(self.SizerDic["SlaveState_main_sizer"])
+
+ # register a timer for periodic exectuion of slave state update (period: 1000 ms)
+ self.Bind(wx.EVT_TIMER, self.GetCurrentState)
+
+ self.CreateSyncManagerTable()
+
+ self.Centre()
+
+ def CreateSyncManagerTable(self):
+ """
+ Create grid for "SyncManager"
+ """
+ # declare Table object
+ self.SyncManagersTable = SyncManagersTable(self, [], GetSyncManagersTableColnames())
+ self.SyncManagersGrid.SetTable(self.SyncManagersTable)
+ # set grid alignment attr. (CENTER)
+ self.SyncManagersGridColAlignements = [wx.ALIGN_CENTRE, wx.ALIGN_CENTRE, wx.ALIGN_CENTRE,
+ wx.ALIGN_CENTRE, wx.ALIGN_CENTRE, wx.ALIGN_CENTRE]
+ # set grid size
+ self.SyncManagersGridColSizes = [40, 150, 100, 100, 100, 100]
+ self.SyncManagersGrid.SetRowLabelSize(0)
+ for col in range(self.SyncManagersTable.GetNumberCols()):
+ attr = wx.grid.GridCellAttr()
+ attr.SetAlignment(self.SyncManagersGridColAlignements[col], wx.ALIGN_CENTRE)
+ self.SyncManagersGrid.SetColAttr(col, attr)
+ self.SyncManagersGrid.SetColMinimalWidth(col, self.SyncManagersGridColSizes[col])
+ self.SyncManagersGrid.AutoSizeColumn(col, False)
+
+ self.RefreshSlaveInfos()
+
+ def RefreshSlaveInfos(self):
+ """
+ Fill data in "Slave Information" and "SyncManager"
+ """
+ slave_infos = self.Controler.GetSlaveInfos()
+ sync_manager_section = ["vendor", "product_code", "revision_number", "physics"]
+ if slave_infos is not None:
+ # this method is same as "TextCtrl.SetValue"
+ for textctrl_name in sync_manager_section:
+ self.TextCtrlDic[textctrl_name].SetValue(slave_infos[textctrl_name])
+ self.SyncManagersTable.SetData(slave_infos["sync_managers"])
+ self.SyncManagersTable.ResetView(self.SyncManagersGrid)
+ else:
+ for textctrl_name in sync_manager_section:
+ self.TextCtrlDic[textctrl_name].SetValue("")
+ self.SyncManagersTable.SetData([])
+ self.SyncManagersTable.ResetView(self.SyncManagersGrid)
+
+ def OnButtonClick(self, event):
+ """
+ Event handler for slave state transition button click (Init, PreOP, SafeOP, OP button)
+ @param event : wx.EVT_BUTTON object
+ """
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(False)
+ if check_connect_flag :
+ state_dic = ["INIT", "PREOP", "SAFEOP", "OP"]
+
+ # If target state is one of {INIT, PREOP, SAFEOP}, request slave state transition immediately.
+ if event.GetId() < 3 :
+ self.Controler.CommonMethod.RequestSlaveState(state_dic[event.GetId()])
+ self.TextCtrlDic["TargetState"].SetValue(state_dic[event.GetId()])
+
+ # If target state is OP, first check "PLC status".
+ # (1) If current PLC status is "Started", then request slave state transition
+ # (2) Otherwise, show error message and return
+ else :
+ status, count = self.Controler.GetCTRoot()._connector.GetPLCstatus()
+ if status == "Started" :
+ self.Controler.CommonMethod.RequestSlaveState("OP")
+ self.TextCtrlDic["TargetState"].SetValue("OP")
+ else :
+ self.Controler.CommonMethod.CreateErrorDialog("PLC is Not Started")
+
+ def GetCurrentState(self, event):
+ """
+ Timer event handler for periodic slave state monitoring (Default period: 1 sec = 1000 msec).
+ @param event : wx.TIMER object
+ """
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(True)
+ if check_connect_flag:
+ returnVal = self.Controler.CommonMethod.GetSlaveStateFromSlave()
+ line = returnVal.split("\n")
+ try :
+ self.SetCurrentState(line[self.Controler.GetSlavePos()])
+ except :
+ pass
+
+ def SetCurrentState(self, line):
+ """
+ Show current slave state using the executiob result of "ethercat slaves" command.
+ @param line : result of "ethercat slaves" command
+ """
+ state_array = ["INIT", "PREOP", "SAFEOP", "OP"]
+ try :
+ # parse the execution result of "ethercat slaves" command
+ # Result example : 0 0:0 PREOP + EL9800 (V4.30) (PIC24, SPI, ET1100)
+ token = line.split(" ")
+ if token[2] in state_array:
+ self.TextCtrlDic["CurrentState"].SetValue(token[2])
+ except :
+ pass
+
+ def StartTimer(self, event):
+ """
+ Event handler for "Start State Monitoring" button.
+ - start slave state monitoring thread
+ @param event : wx.EVT_BUTTON object
+ """
+ self.SlaveStateThread = wx.Timer(self)
+ # set timer period (1000 ms)
+ self.SlaveStateThread.Start(1000)
+
+ def CurrentStateThreadStop(self, event):
+ """
+ Event handler for "Stop State Monitoring" button.
+ - stop slave state monitoring thread
+ @param event : wx.EVT_BUTTON object
+ """
+ try:
+ self.SlaveStateThread.Stop()
+ except:
+ pass
+
+#-------------------------------------------------------------------------------
+# For SDO Management Panel
+#-------------------------------------------------------------------------------
+class SDOPanelClass(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent EtherCATManagementTreebook class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Panel.__init__(self, parent, -1)
+
+ self.DatatypeDescription, self.CommunicationObject, self.ManufacturerSpecific, \
+ self.ProfileSpecific, self.Reserved, self.AllSDOData = range(6)
+
+ self.Controler = controler
+
+ self.SDOManagementMainSizer = wx.BoxSizer(wx.VERTICAL)
+ self.SDOManagementInnerMainSizer = wx.FlexGridSizer(cols=1, hgap=10, rows=2, vgap=10)
+
+ self.SDOUpdate = wx.Button(self, label=_('update'))
+ self.SDOUpdate.Bind(wx.EVT_BUTTON, self.SDOInfoUpdate)
+
+ self.CallSDONoteBook = SDONoteBook(self, controler=self.Controler)
+ self.SDOManagementInnerMainSizer.Add(self.SDOUpdate)
+ self.SDOManagementInnerMainSizer.Add(self.CallSDONoteBook, wx.ALL | wx.EXPAND)
+
+ self.SDOManagementMainSizer.Add(self.SDOManagementInnerMainSizer)
+
+ self.SetSizer(self.SDOManagementMainSizer)
+
+ def SDOInfoUpdate(self, event):
+ """
+ Evenet handler for SDO "update" button.
+ - Load SDO data from current slave
+ @param event : wx.EVT_BUTTON object
+ """
+ self.Controler.CommonMethod.SaveSDOData = []
+ self.Controler.CommonMethod.ClearSDODataSet()
+ self.SDOFlag = False
+
+ # Check whether beremiz connected or not.
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(False)
+ if check_connect_flag:
+ self.SDOs = self.Controler.CommonMethod.GetSlaveSDOFromSlave()
+ # SDOFlag is "False", user click "Cancel" button
+ self.SDOFlag = self.SDOParser()
+
+ if self.SDOFlag :
+ self.CallSDONoteBook.CreateNoteBook()
+ self.Refresh()
+
+ def SDOParser(self):
+ """
+ Parse SDO data set that obtain "SDOInfoUpdate" Method
+ @return True or False
+ """
+
+ slaveSDO_progress = wx.ProgressDialog("Slave SDO Monitoring", "Now Uploading...",
+ maximum = len(self.SDOs.splitlines()), parent=self,
+ style = wx.PD_CAN_ABORT | wx.PD_APP_MODAL | wx.PD_ELAPSED_TIME |
+ wx.PD_ESTIMATED_TIME | wx.PD_REMAINING_TIME |
+ wx.PD_AUTO_HIDE | wx.PD_SMOOTH)
+
+ # If keep_going flag is False, SDOParser method is stop and return "False".
+ keep_going = True
+ count = 0
+
+ # SDO data example
+ # SDO 0x1000, "Device type"
+ # 0x1000:00,r-r-r-,uint32,32 bit,"Device type",0x00020192, 131474
+ for details_line in self.SDOs.splitlines():
+ count += 1
+ line_token = details_line.split("\"")
+ # len(line_token[2]) case : SDO 0x1000, "Device type"
+ if len(line_token[2]) == 0:
+ title_name = line_token[1]
+ # else case : 0x1000:00,r-r-r-,uint32,32 bit,"Device type",0x00020192, 131474
+ else :
+ # line_token = ['0x1000:00,r-r-r-,uint32,32 bit,', 'Device type', ',0x00020192, 131474']
+ token_head, name, token_tail = line_token
+
+ # token_head = ['0x1000:00', 'r-r-r-', 'uint32', '32 bit', '']
+ token_head = token_head.split(",")
+ ful_idx, access, type, size, empty = token_head
+ # ful_idx.split(":") = ['0x1000', '00']
+ idx, sub_idx = ful_idx.split(":")
+
+ # token_tail = ['', '0x00020192', '131474']
+ token_tail = token_tail.split(",")
+ try :
+ empty, hex_val, dec_val = token_tail
+
+ # SDO data is not return "dec value"
+ # line example :
+ # 0x1702:01,rwr-r-,uint32,32 bit," 1st mapping", ----
+ except :
+ empty, hex_val = token_tail
+
+ name_after_check = self.StringTest(name)
+
+ # convert hex type
+ sub_idx = "0x" + sub_idx
+
+ if type == "octet_string":
+ hex_val = ' ---- '
+
+ # SResult of SlaveSDO data parsing. (data type : dictionary)
+ self.Data = {'idx':idx.strip(), 'subIdx':sub_idx.strip(), 'access':access.strip(),
+ 'type':type.strip(), 'size':size.strip(), 'name':name_after_check.strip("\""),
+ 'value':hex_val.strip(), "category":title_name.strip("\"")}
+
+ category_divide_value = [0x1000, 0x2000, 0x6000, 0xa000, 0xffff]
+
+ for count in range(len(category_divide_value)) :
+ if int(idx, 0) < category_divide_value[count]:
+ self.Controler.CommonMethod.SaveSDOData[count].append(self.Data)
+ break
+
+ self.Controler.CommonMethod.SaveSDOData[self.AllSDOData].append(self.Data)
+
+ if count >= len(self.SDOs.splitlines()) / 2:
+ (keep_going, skip) = slaveSDO_progress.Update(count, "Please waiting a moment!!")
+ else:
+ (keep_going, skip) = slaveSDO_progress.Update(count)
+
+ # If user click "Cancel" loop suspend immediately
+ if (keep_going == False):
+ break
+
+ slaveSDO_progress.Destroy()
+ return keep_going
+
+ def StringTest(self, check_string):
+ """
+ Test value 'name' is alphanumeric
+ @param check_string : input data for check
+ @return result : output data after check
+ """
+ # string.printable is print this result
+ #'0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ
+ #!"#$%&\'()*+,-./:;<=>?@[\\]^_`{|}~ \t\n\r\x0b\x0c
+ allow_range = string.printable
+ result = check_string
+ for i in range(0, len(check_string)):
+ # string.isalnum() is check whether string is alphanumeric or not
+ if check_string[len(check_string)-1-i:len(check_string)-i] in allow_range :
+ result = check_string[:len(check_string) - i]
+ break
+ return result
+
+
+#-------------------------------------------------------------------------------
+# For SDO Notebook (divide category)
+#-------------------------------------------------------------------------------
+class SDONoteBook(wx.Notebook):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent SDOPanelClass class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Notebook.__init__(self, parent, id = -1, size=(850,500))
+ self.Controler = controler
+ self.parent = parent
+
+ self.CreateNoteBook()
+
+ self.Bind(wx.EVT_CHOICEBOOK_PAGE_CHANGED, self.OnPageChanged)
+ self.Bind(wx.EVT_CHOICEBOOK_PAGE_CHANGING, self.OnPageChanging)
+
+ def CreateNoteBook(self):
+ """
+ Create each NoteBook page, divided SDO index
+ According to EtherCAT Communication(03/2011), 158p
+ """
+ self.Data = []
+ count = 1
+
+ page_texts = [("all", self.parent.AllSDOData),
+ ("0x0000 - 0x0ff", self.parent.DatatypeDescription),
+ ("0x1000 - 0x1fff", self.parent.CommunicationObject),
+ ("0x2000 - 0x5fff", self.parent.ManufacturerSpecific),
+ ("0x6000 - 0x9fff", self.parent.ProfileSpecific),
+ ("0xa000 - 0xffff", self.parent.Reserved)]
+
+ page_tooltip_string = ["SDO Index 0x0000 - 0x0fff : Data Type Description",
+ "SDO Index 0x1000 - 0x1fff : Communication object",
+ "SDO Index 0x2000 - 0x5fff : Manufacturer specific",
+ "SDO Index 0x6000 - 0x9fff : Profile specific",
+ "SDO Index 0xa000 - 0xffff : Reserved",
+ "All SDO Object"]
+
+ self.DeleteAllPages()
+
+ for txt, count in page_texts:
+ self.Data = self.Controler.CommonMethod.SaveSDOData[count]
+ self.Win = SlaveSDOTable(self, self.Data)
+ self.AddPage(self.Win, txt)
+
+ def OnPageChanged(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+ def OnPageChanging(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+#-------------------------------------------------------------------------------
+# For SDO Grid (fill index, subindex, etc...)
+#-------------------------------------------------------------------------------
+class SlaveSDOTable(wx.grid.Grid):
+ def __init__(self, parent, data):
+ """
+ Constructor
+ @param parent: Reference to the parent SDOPanelClass class
+ @param data: SDO data after parsing "SDOParser" method
+ """
+ wx.grid.Grid.__init__(self, parent, -1, size=(830,490),
+ style=wx.EXPAND|wx.ALIGN_CENTRE_HORIZONTAL|wx.ALIGN_CENTER_VERTICAL)
+
+ self.Controler = parent.Controler
+ self.parent = parent
+ self.SDOFlag = True
+ if data is None :
+ self.SDOs = []
+ else :
+ self.SDOs = data
+
+ self.CreateGrid(len(self.SDOs), 8)
+ SDOCellSize = [(0, 65), (1, 65), (2, 50), (3, 55),
+ (4, 40), (5, 200), (6, 250), (7, 85)]
+
+ for (index, size) in SDOCellSize:
+ self.SetColSize(index, size)
+
+ self.SetRowLabelSize(0)
+
+ SDOTableLabel = [(0, "Index"), (1, "Subindex"), (2, "Access"),
+ (3, "Type"), (4, "Size"), (5, "Category"),
+ (6, "Name"), (7, "Value")]
+
+ for (index, label) in SDOTableLabel:
+ self.SetColLabelValue(index, label)
+ self.SetColLabelAlignment(index, wx.ALIGN_CENTRE)
+
+ attr = wx.grid.GridCellAttr()
+
+ # for SDO download
+ self.Bind(gridlib.EVT_GRID_CELL_LEFT_DCLICK, self.SDOModifyDialog)
+
+ for i in range(7):
+ self.SetColAttr(i,attr)
+
+ self.SetColLabelAlignment(wx.ALIGN_CENTER, wx.ALIGN_CENTER)
+
+ self.SetTableValue()
+
+ def SetTableValue(self):
+ """
+ Cell is filled by new parsing data
+ """
+ sdo_list = ['idx', 'subIdx', 'access', 'type', 'size', 'category', 'name', 'value']
+ for row_idx in range(len(self.SDOs)):
+ for col_idx in range(len(self.SDOs[row_idx])):
+ self.SetCellValue(row_idx, col_idx, self.SDOs[row_idx][sdo_list[col_idx]])
+ self.SetReadOnly(row_idx, col_idx, True)
+ if col_idx < 5 :
+ self.SetCellAlignment(row_idx, col_idx, wx.ALIGN_CENTRE, wx.ALIGN_CENTRE)
+
+ def CheckSDODataAccess(self, row):
+ """
+ CheckSDODataAccess method is checking that access data has "w"
+ Access field consist 6 char, if mean
+ rw rw rw
+ (preop) (safeop) (op)
+ Example Access field : rwrwrw, rwrw--
+ @param row : Selected cell by user
+ @return Write_flag : If data has "w", flag is true
+ """
+ write_flag = False
+ check = self.SDOs[row]['access']
+ if check[1:2] == 'w' :
+ self.Controler.CommonMethod.Check_PREOP = True
+ write_flag = True
+ if check[3:4] == 'w' :
+ self.Controler.CommonMethod.Check_SAFEOP = True
+ write_flag = True
+ if check[5:] =='w' :
+ self.Controler.CommonMethod.Check_OP = True
+ write_flag = True
+
+ return write_flag
+
+ def DecideSDODownload(self, state):
+ """
+ compare current state and "access" field,
+ result notify SDOModifyDialog method
+ @param state : current slave state
+ @return True or False
+ """
+ # Example of 'state' parameter : "0 0:0 PREOP + EL9800 (V4.30) (PIC24, SPI, ET1100)"
+ state = state[self.Controler.GetSlavePos()].split(" ")[2]
+ if state == "PREOP" and self.Controler.CommonMethod.Check_PREOP :
+ return True
+ elif state == "SAFEOP" and self.Controler.CommonMethod.Check_SAFEOP :
+ return True
+ elif state == "OP" and self.Controler.CommonMethod.Check_OP :
+ return True
+
+ return False
+
+ def ClearStateFlag(self):
+ """
+ Initialize StateFlag
+ StateFlag is notice SDOData access each slave state
+ """
+ self.Controler.CommonMethod.Check_PREOP = False
+ self.Controler.CommonMethod.Check_SAFEOP = False
+ self.Controler.CommonMethod.Check_OP = False
+
+ def SDOModifyDialog (self, event):
+ """
+ Create dialog for SDO value modify
+ if user enter data, perform command "ethercat download"
+ @param event : gridlib.EVT_GRID_CELL_LEFT_DCLICK object
+ """
+ self.ClearStateFlag()
+
+ # CheckSDODataAccess is checking that OD(Object Dictionary) has "w"
+ if event.GetCol() == 7 and self.CheckSDODataAccess(event.GetRow()) :
+ dlg = wx.TextEntryDialog (self, "Enter hex or dec value (if enter dec value, it automatically conversed hex value)",
+ "SDOModifyDialog", style = wx.OK | wx.CANCEL)
+
+ start_value = self.GetCellValue(event.GetRow(), event.GetCol())
+ dlg.SetValue(start_value)
+
+ if dlg.ShowModal() == wx.ID_OK:
+ try :
+ int(dlg.GetValue(), 0)
+ # check "Access" field
+ if self.DecideSDODownload(self.Controler.CommonMethod.SlaveState[self.Controler.GetSlavePos()]) :
+ # Request "SDODownload"
+ self.Controler.CommonMethod.SDODownload(self.SDOs[event.GetRow()]['type'], self.SDOs[event.GetRow()]['idx'],
+ self.SDOs[event.GetRow()]['subIdx'], dlg.GetValue())
+ self.SetCellValue(event.GetRow(), event.GetCol(), hex(int(dlg.GetValue(), 0)))
+ else :
+ self.Controler.CommonMethod.CreateErrorDialog('You cannot SDO download this state')
+ # Error occured process of "int(variable)"
+ # User input is not hex, dec value
+ except ValueError:
+ self.Controler.CommonMethod.CreateErrorDialog('You can input only hex, dec value')
+
+
+#-------------------------------------------------------------------------------
+# For PDO Monitoring Panel
+# PDO Class UI : Panel -> Choicebook (RxPDO, TxPDO) ->
+# Notebook (PDO Index) -> Grid (PDO entry)
+#-------------------------------------------------------------------------------
+class PDOPanelClass(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent EtherCATManagementTreebook class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Panel.__init__(self, parent, -1)
+ self.Controler = controler
+
+ self.PDOMonitoringEditorMainSizer = wx.BoxSizer(wx.VERTICAL)
+ self.PDOMonitoringEditorInnerMainSizer = wx.FlexGridSizer(cols=1, hgap=10, rows=2, vgap=10)
+
+ self.CallPDOChoicebook = PDOChoicebook(self, controler=self.Controler)
+ self.PDOMonitoringEditorInnerMainSizer.Add(self.CallPDOChoicebook, wx.ALL)
+
+ self.PDOMonitoringEditorMainSizer.Add(self.PDOMonitoringEditorInnerMainSizer)
+
+ self.SetSizer(self.PDOMonitoringEditorMainSizer)
+
+ def PDOInfoUpdate(self):
+ """
+ Call RequestPDOInfo method and create Choicebook
+ """
+ self.Controler.CommonMethod.RequestPDOInfo()
+ self.CallPDOChoicebook.Destroy()
+ self.CallPDOChoicebook = PDOChoicebook(self, controler=self.Controler)
+ self.Refresh()
+
+
+#-------------------------------------------------------------------------------
+# For PDO Choicebook (divide Tx, Rx PDO)
+#-------------------------------------------------------------------------------
+class PDOChoicebook(wx.Choicebook):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent PDOPanelClass class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Choicebook.__init__(self, parent, id=-1, size=(500, 500), style=wx.CHB_DEFAULT)
+ self.Controler = controler
+
+ RxWin = PDONoteBook(self, controler=self.Controler, name="Rx")
+ TxWin = PDONoteBook(self, controler=self.Controler, name="Tx")
+ self.AddPage(RxWin, "RxPDO")
+ self.AddPage(TxWin, "TxPDO")
+
+ self.Bind(wx.EVT_CHOICEBOOK_PAGE_CHANGED, self.OnPageChanged)
+ self.Bind(wx.EVT_CHOICEBOOK_PAGE_CHANGING, self.OnPageChanging)
+
+ def OnPageChanged(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+ def OnPageChanging(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+
+#-------------------------------------------------------------------------------
+# For PDO Notebook (divide PDO index)
+#-------------------------------------------------------------------------------
+class PDONoteBook(wx.Notebook):
+ def __init__(self, parent, name, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent PDOChoicebook class
+ @param name: identifier whether RxPDO or TxPDO
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Notebook.__init__(self, parent, id=-1, size=(640, 400))
+ self.Controler = controler
+
+ count = 0
+ page_texts = []
+
+ self.Controler.CommonMethod.RequestPDOInfo()
+
+ if name == "Tx" :
+ # obtain pdo_info and pdo_entry
+ # pdo_info include (PDO index, name, number of entry)
+ pdo_info = self.Controler.CommonMethod.GetTxPDOCategory()
+ pdo_entry = self.Controler.CommonMethod.GetTxPDOInfo()
+ for tmp in pdo_info :
+ title = str(hex(tmp['pdo_index']))
+ page_texts.append(title)
+ # RX PDO case
+ else :
+ pdo_info = self.Controler.CommonMethod.GetRxPDOCategory()
+ pdo_entry = self.Controler.CommonMethod.GetRxPDOInfo()
+ for tmp in pdo_info :
+ title = str(hex(tmp['pdo_index']))
+ page_texts.append(title)
+
+ # Add page depending on the number of pdo_info
+ for txt in page_texts:
+ win = PDOEntryTable(self, pdo_info, pdo_entry, count)
+ self.AddPage(win, txt)
+ count += 1
+
+ self.Bind(wx.EVT_CHOICEBOOK_PAGE_CHANGED, self.OnPageChanged)
+ self.Bind(wx.EVT_CHOICEBOOK_PAGE_CHANGING, self.OnPageChanging)
+
+ def OnPageChanged(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+ def OnPageChanging(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+
+#-------------------------------------------------------------------------------
+# For PDO Grid (fill entry index, subindex etc...)
+#-------------------------------------------------------------------------------
+class PDOEntryTable(wx.grid.Grid):
+ def __init__(self, parent, info, entry, count):
+ """
+ Constructor
+ @param parent: Reference to the parent PDONoteBook class
+ @param info : data structure including entry index, sub index, name, length, type
+ @param entry : data structure including index, name, entry number
+ @param count : page number
+ """
+ wx.grid.Grid.__init__(self, parent, -1, size=(500, 400), pos=wx.Point(0,0),
+ style=wx.EXPAND|wx.ALIGN_CENTRE_HORIZONTAL|wx.ALIGN_CENTER_VERTICAL)
+
+ self.Controler = parent.Controler
+
+ self.PDOInfo = info
+ self.PDOEntry = entry
+ self.Count = count
+
+ self.CreateGrid(self.PDOInfo[self.Count]['number_of_entry'], 5)
+ self.SetColLabelSize(25)
+ self.SetRowLabelSize(0)
+
+ PDOTableLabel = [(0, "Index"), (1, "Subindex"), (2, "Length"),
+ (3, "Type"), (4, "Name")]
+
+ for (index, label) in PDOTableLabel:
+ self.SetColLabelValue(index, label)
+
+ PDOCellSize = [(0, 45), (1, 65), (2, 55), (3, 40), (4, 300)]
+
+ for (index, size) in PDOCellSize:
+ self.SetColSize(index, size)
+ self.SetColLabelAlignment(index, wx.ALIGN_LEFT)
+
+ attr = wx.grid.GridCellAttr()
+
+ for i in range(5):
+ self.SetColAttr(i, attr)
+
+ self.SetTableValue()
+
+ def SetTableValue(self):
+ """
+ Cell is filled by new parsing data in XML
+ """
+ list_index = 0
+ # number of entry
+ for i in range(self.Count + 1) :
+ list_index += self.PDOInfo[i]['number_of_entry']
+
+ start_value = list_index - self.PDOInfo[self.Count]['number_of_entry']
+
+ pdo_list = ['entry_index', 'subindex', 'bitlen', 'type', 'name']
+ for row_idx in range(self.PDOInfo[self.Count]['number_of_entry']):
+ for col_idx in range(len(self.PDOEntry[row_idx])):
+ # entry index is converted hex value.
+ if col_idx == 0 :
+ self.SetCellValue(row_idx, col_idx, hex(self.PDOEntry[start_value][pdo_list[col_idx]]))
+ else :
+ self.SetCellValue(row_idx, col_idx, str(self.PDOEntry[start_value][pdo_list[col_idx]]))
+ if col_idx != 4 :
+ self.SetCellAlignment(row_idx, col_idx, wx.ALIGN_CENTRE, wx.ALIGN_CENTRE)
+ else :
+ self.SetCellAlignment(row_idx, col_idx, wx.ALIGN_LEFT, wx.ALIGN_CENTRE)
+ self.SetReadOnly(row_idx, col_idx, True)
+ self.SetRowSize(row_idx, 25)
+ start_value += 1
+
+
+#-------------------------------------------------------------------------------
+# For EEPROM Access Main Panel
+# (This class explain EEPROM Access)
+#-------------------------------------------------------------------------------
+class EEPROMAccessPanel(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent EtherCATManagementTreebook class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Panel.__init__(self, parent, -1)
+ sizer = wx.FlexGridSizer(cols=1, hgap=20,rows=3, vgap=20)
+
+ line = wx.StaticText(self, -1, "\n EEPROM Access is composed to SmartView and HexView. \
+ \n\n - SmartView shows Config Data, Device Identity, Mailbox settings, etc. \
+ \n\n - HexView shows EEPROM's contents.")
+
+ sizer.Add(line)
+
+ self.SetSizer(sizer)
+
+
+#-------------------------------------------------------------------------------
+# For Smart View Panel
+#-------------------------------------------------------------------------------
+class SlaveSiiSmartView(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent EtherCATManagementTreebook class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Panel.__init__(self, parent, -1)
+ self.parent = parent
+ self.Controler = controler
+
+ self.PDIType = {0 :['none', '00000000'],
+ 4 :['Digital I/O', '00000100'],
+ 5 :['SPI Slave', '00000101'],
+ 7 :['EtherCAT Bridge (port3)', '00000111'],
+ 8 :['uC async. 16bit', '00001000'],
+ 9 :['uC async. 8bit', '00001001'],
+ 10 :['uC sync. 16bit', '00001010'],
+ 11 :['uC sync. 8bit', '00001011'],
+ 16 :['32 Digtal Input and 0 Digital Output', '00010000'],
+ 17 :['24 Digtal Input and 8 Digital Output', '00010001'],
+ 18 :['16 Digtal Input and 16 Digital Output','00010010'],
+ 19 :['8 Digtal Input and 24 Digital Output', '00010011'],
+ 20 :['0 Digtal Input and 32 Digital Output', '00010100'],
+ 128:['On-chip bus', '11111111']
+ }
+
+ sizer = wx.FlexGridSizer(cols=1, hgap=5, rows=2, vgap=5)
+ button_sizer = wx.FlexGridSizer(cols=2, hgap=5, rows=1, vgap=5)
+
+ for button, mapping_method in [("Write EEPROM", self.WriteToEEPROM),
+ ("Read EEPROM", self.ReadFromEEPROM)]:
+ btn = wx.Button(self, -1, button, size=(150, 40))
+ button_sizer.Add(btn, border=10, flag=wx.ALL)
+ btn.Bind(wx.EVT_BUTTON, mapping_method)
+
+ self.TreeListCtrl = SmartViewTreeListCtrl(self, self.Controler)
+
+ sizer.Add(button_sizer, border=10, flag=wx.ALL)
+ sizer.Add(self.TreeListCtrl, border=10, flag=wx.ALL)
+ self.SetSizer(sizer)
+
+ self.Create_SmartView()
+
+ def Create_SmartView(self):
+ """
+ SmartView shows information based on XML as initial value.
+ """
+ self.Controler.CommonMethod.SmartViewInfosFromXML = self.Controler.CommonMethod.GetSmartViewInfos()
+ self.SetXMLData()
+
+ def WriteToEEPROM(self, event):
+ """
+ Open binary file (user select) and write the selected binary data to EEPROM
+ @param event : wx.EVT_BUTTON object
+ """
+ # Check whether beremiz connected or not, and whether status is "Started" or not.
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(False)
+ if check_connect_flag:
+ status, count = self.Controler.GetCTRoot()._connector.GetPLCstatus()
+ if status is not "Started":
+ dialog = wx.FileDialog(self, _("Choose a binary file"), os.getcwd(), "", _("bin files (*.bin)|*.bin"), wx.OPEN)
+
+ if dialog.ShowModal() == wx.ID_OK:
+ filepath = dialog.GetPath()
+ try:
+ binfile = open(filepath,"rb")
+ self.SiiBinary = binfile.read()
+ dialog.Destroy()
+
+ self.Controler.CommonMethod.SiiWrite(self.SiiBinary)
+ # refresh data structure kept by master
+ self.Controler.CommonMethod.Rescan()
+ # save binary data as inner global data of beremiz
+ # for fast loading when slave plugin node is reopened.
+ self.Controler.CommonMethod.SiiData = self.SiiBinary
+ self.SetEEPROMData()
+ except:
+ self.Controler.CommonMethod.CreateErrorDialog('The file does not exist!')
+ dialog.Destroy()
+
+ def ReadFromEEPROM(self, event):
+ """
+ Refresh displayed data based on slave EEPROM and save binary file through dialog
+ @param event : wx.EVT_BUTTON object
+ """
+ # Check whether beremiz connected or not.
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(False)
+ if check_connect_flag:
+ self.SiiBinary = self.Controler.CommonMethod.LoadData()
+ self.SetEEPROMData()
+ dialog = wx.FileDialog(self, _("Save as..."), os.getcwd(),
+ "slave0.bin", _("bin files (*.bin)|*.bin|All files|*.*"),
+ wx.SAVE|wx.OVERWRITE_PROMPT)
+
+ if dialog.ShowModal() == wx.ID_OK:
+ filepath = dialog.GetPath()
+ binfile = open(filepath,"wb")
+ binfile.write(self.SiiBinary)
+ binfile.close()
+
+ dialog.Destroy()
+
+ def SetXMLData(self):
+ """
+ Set data based on XML initially
+ """
+ # Config Data: EEPROM Size, PDI Type, Device Emulation
+ # Find PDI Type in pdiType dictionary
+ cnt_pdi_type = self.Controler.CommonMethod.SmartViewInfosFromXML["pdi_type"]
+ for i in self.PDIType.keys():
+ if cnt_pdi_type == i:
+ cnt_pdi_type = self.PDIType[i][0]
+ break
+ # Set Config Data
+ for treelist, data in [("EEPROM Size (Bytes)",
+ str(self.Controler.CommonMethod.SmartViewInfosFromXML["eeprom_size"])),
+ ("PDI Type",
+ cnt_pdi_type),
+ ("Device Emulation",
+ self.Controler.CommonMethod.SmartViewInfosFromXML["device_emulation"])]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.ConfigData[treelist], data, 1)
+
+ # Device Identity: Vendor ID, Product Code, Revision No., Serial No.
+ # Set Device Identity
+ for treelist, data in [("Vendor ID", self.Controler.CommonMethod.SmartViewInfosFromXML["vendor_id"]),
+ ("Product Code", self.Controler.CommonMethod.SmartViewInfosFromXML["product_code"]),
+ ("Revision No.", self.Controler.CommonMethod.SmartViewInfosFromXML["revision_no"]),
+ ("Serial No.", self.Controler.CommonMethod.SmartViewInfosFromXML["serial_no"])]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.DeviceIdentity[treelist], data, 1)
+
+ # Mailbox: Supported Mailbox, Bootstrap Configuration, Standard Configuration
+ # Set Mailbox
+ for treelist, data in [("Supported Mailbox", self.Controler.CommonMethod.SmartViewInfosFromXML["supported_mailbox"]),
+ ("Bootstrap Configuration", ""),
+ ("Standard Configuration", "")]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.Mailbox[treelist], data, 1)
+ # Set Bootstrap Configuration: Receive Offset, Receive Size, Send Offset, Send Size
+ for treelist, data in [("Receive Offset", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_bootstrapconf_outstart"]),
+ ("Receive Size", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_bootstrapconf_outlength"]),
+ ("Send Offset", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_bootstrapconf_instart"]),
+ ("Send Size", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_bootstrapconf_inlength"])]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.BootstrapConfig[treelist], data, 1)
+ # Set Standard Configuration: Receive Offset, Receive Size, Send Offset, Send Size
+ for treelist, data in [("Receive Offset", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_standardconf_outstart"]),
+ ("Receive Size", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_standardconf_outlength"]),
+ ("Send Offset", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_standardconf_instart"]),
+ ("Send Size", self.Controler.CommonMethod.SmartViewInfosFromXML["mailbox_standardconf_inlength"])]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.StandardConfig[treelist], data, 1)
+
+ def SetEEPROMData(self):
+ """
+ Set data based on slave EEPROM.
+ """
+ # sii_dict = { Parameter : (WordAddress, WordSize) }
+ sii_dict= { 'PDIControl' : ( '0', 1),
+ 'PDIConfiguration' : ( '1', 1),
+ 'PulseLengthOfSYNCSignals' : ( '2', 1),
+ 'ExtendedPDIConfiguration' : ( '3', 1),
+ 'ConfiguredStationAlias' : ( '4', 1),
+ 'Checksum' : ( '7', 1),
+ 'VendorID' : ( '8', 2),
+ 'ProductCode' : ( 'a', 2),
+ 'RevisionNumber' : ( 'c', 2),
+ 'SerialNumber' : ( 'e', 2),
+ 'Execution Delay' : ('10', 1),
+ 'Port0Delay' : ('11', 1),
+ 'Port1Delay' : ('12', 1),
+ 'BootstrapReceiveMailboxOffset' : ('14', 1),
+ 'BootstrapReceiveMailboxSize' : ('15', 1),
+ 'BootstrapSendMailboxOffset' : ('16', 1),
+ 'BootstrapSendMailboxSize' : ('17', 1),
+ 'StandardReceiveMailboxOffset' : ('18', 1),
+ 'StandardReceiveMailboxSize' : ('19', 1),
+ 'StandardSendMailboxOffset' : ('1a', 1),
+ 'StandardSendMailboxSize' : ('1b', 1),
+ 'MailboxProtocol' : ('1c', 1),
+ 'Size' : ('3e', 1),
+ 'Version' : ('3f', 1),
+ 'First Category Type/Vendor Specific' : ('40', 1),
+ 'Following Category Word Size' : ('41', 1),
+ 'Category Data' : ('42', 1),
+ }
+
+ # Config Data: EEPROM Size, PDI Type, Device Emulation
+ # EEPROM's data in address '0x003f' is Size of EEPROM in KBit-1
+ eeprom_size = str((int(self.GetWordAddressData( sii_dict.get('Size'),10 ))+1)/8*1024)
+ # Find PDI Type in pdiType dictionary
+ cnt_pdi_type = int(self.GetWordAddressData( sii_dict.get('PDIControl'),16 ).split('x')[1][2:4], 16)
+ for i in self.PDIType.keys():
+ if cnt_pdi_type == i:
+ cnt_pdi_type = self.PDIType[i][0]
+ break
+ # Get Device Emulation
+ device_emulation = str(bool(int("{:0>16b}".format(int(self.GetWordAddressData( sii_dict.get('PDIControl'),16 ), 16))[7])))
+ # Set Config Data
+ for treelist, data in [("EEPROM Size (Bytes)", eeprom_size),
+ ("PDI Type", cnt_pdi_type),
+ ("Device Emulation", device_emulation)]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.ConfigData[treelist], data, 1)
+
+ # Device Identity: Vendor ID, Product Code, Revision No., Serial No.
+ # Set Device Identity
+ for treelist, data in [("Vendor ID", self.GetWordAddressData( sii_dict.get('VendorID'),16 )),
+ ("Product Code", self.GetWordAddressData( sii_dict.get('ProductCode'),16 )),
+ ("Revision No.", self.GetWordAddressData( sii_dict.get('RevisionNumber'),16 )),
+ ("Serial No.", self.GetWordAddressData( sii_dict.get('SerialNumber'),16 ))]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.DeviceIdentity[treelist], data, 1)
+
+ # Mailbox
+ # EEORPOM's word address '1c' indicates supported mailbox protocol.
+ # each value of mailbox protocol :
+ # VoE(0x0020), SoE(0x0010), FoE(0x0008), CoE(0x0004), EoE(0x0002), AoE(0x0001)
+ supported_mailbox = ""
+ mailbox_protocol=["VoE, ", "SoE, ", "FoE, ", "CoE, ", "EoE, ", "AoE, "]
+ mailbox_data = "{:0>8b}".format(int(self.GetWordAddressData( sii_dict.get('MailboxProtocol'),16 ), 16))
+ for protocol in range(6):
+ if mailbox_data[protocol+2] == '1':
+ supported_mailbox += mailbox_protocol[protocol]
+ supported_mailbox = supported_mailbox.strip(", ")
+ # Set Mailbox
+ for treelist, data in [("Supported Mailbox", supported_mailbox),
+ ("Bootstrap Configuration", ""),
+ ("Standard Configuration", "")]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.Mailbox[treelist], data, 1)
+ # Set Bootstrap Configuration: Receive Offset, Receive Size, Send Offset, Send Size
+ for treelist, data in [("Receive Offset", self.GetWordAddressData( sii_dict.get('BootstrapReceiveMailboxOffset'),10 )),
+ ("Receive Size", self.GetWordAddressData( sii_dict.get('BootstrapReceiveMailboxSize'),10 )),
+ ("Send Offset", self.GetWordAddressData( sii_dict.get('BootstrapSendMailboxOffset'),10 )),
+ ("Send Size", self.GetWordAddressData( sii_dict.get('BootstrapSendMailboxSize'),10 ))]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.BootstrapConfig[treelist], data, 1)
+ # Set Standard Configuration: Receive Offset, Receive Size, Send Offset, Send Size
+ for treelist, data in [("Receive Offset", self.GetWordAddressData( sii_dict.get('StandardReceiveMailboxOffset'),10 )),
+ ("Receive Size", self.GetWordAddressData( sii_dict.get('StandardReceiveMailboxSize'),10 )),
+ ("Send Offset", self.GetWordAddressData( sii_dict.get('StandardSendMailboxOffset'),10 )),
+ ("Send Size", self.GetWordAddressData( sii_dict.get('StandardSendMailboxSize'),10 ))]:
+ self.TreeListCtrl.Tree.SetItemText(self.TreeListCtrl.StandardConfig[treelist], data, 1)
+
+ def MakeStaticBoxSizer(self, boxlabel):
+ """
+ Make StaticBoxSizer
+ @param boxlabel : label of box sizer
+ @return sizer : the StaticBoxSizer labeled 'boxlabel'
+ """
+ box = wx.StaticBox(self, -1, boxlabel)
+ sizer = wx.StaticBoxSizer(box, wx.VERTICAL)
+
+ return sizer
+
+ def GetWordAddressData(self, dict_tuple, format):
+ """
+ This method converts word address data from EEPROM binary.
+ @param dict_tuple : element of 'sii_dict' dictionary in SetEEPROMData()
+ @param format : format of data. It can be 16(hex), 10(decimal) and 2(binary).
+ @return formatted value
+ """
+ offset = int(str(dict_tuple[0]), 16) * 2
+ length = int(str(dict_tuple[1]), 16) * 2
+ list = []
+ data = ''
+ for index in range(length):
+ hexdata = hex(ord(self.SiiBinary[offset + index]))[2:]
+ list.append(hexdata.zfill(2))
+
+ list.reverse()
+ data = list[0:length]
+
+ if format == 16:
+ return '0x' + ''.join(data)
+ elif format == 10:
+ return str(int(str(''.join(data)), 16))
+ elif format == 2:
+ ''.join(data)
+
+
+#-------------------------------------------------------------------------------
+# For Smart View TreeListCtrl
+#-------------------------------------------------------------------------------
+class SmartViewTreeListCtrl(wx.Panel):
+ def __init__(self, parent, Controler):
+ """
+ Constructor
+ @param parent: Reference to the parent SlaveSiiSmartView class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+
+ wx.Panel.__init__(self, parent, -1, size=(350, 500))
+
+ self.Tree = wx.gizmos.TreeListCtrl(self, -1, size=(350, 500),
+ style=wx.TR_DEFAULT_STYLE
+ |wx.TR_FULL_ROW_HIGHLIGHT
+ |wx.TR_HIDE_ROOT
+ |wx.TR_COLUMN_LINES
+ |wx.TR_ROW_LINES)
+
+ self.Tree.AddColumn("Description", width=200)
+ self.Tree.AddColumn("Value", width=140)
+ self.Tree.SetMainColumn(0)
+
+ self.Root = self.Tree.AddRoot("")
+
+ # Add item
+ # Level 1 nodes
+ self.Level1Nodes = {}
+ for lv1 in ["Config Data", "Device Identity", "Mailbox"]:
+ self.Level1Nodes[lv1] = self.Tree.AppendItem(self.Root, lv1)
+
+ # Level 2 nodes
+ # Config Data
+ self.ConfigData = {}
+ for lv2 in ["EEPROM Size (Bytes)", "PDI Type", "Device Emulation"]:
+ self.ConfigData[lv2] = self.Tree.AppendItem(self.Level1Nodes["Config Data"], lv2)
+ # Device Identity
+ self.DeviceIdentity = {}
+ for lv2 in ["Vendor ID", "Product Code", "Revision No.", "Serial No."]:
+ self.DeviceIdentity[lv2] = self.Tree.AppendItem(self.Level1Nodes["Device Identity"], lv2)
+ # Mailbox
+ self.Mailbox = {}
+ for lv2 in ["Supported Mailbox", "Bootstrap Configuration", "Standard Configuration"]:
+ self.Mailbox[lv2] = self.Tree.AppendItem(self.Level1Nodes["Mailbox"], lv2)
+
+ # Level 3 nodes
+ # Children of Bootstrap Configuration
+ self.BootstrapConfig = {}
+ for lv3 in ["Receive Offset", "Receive Size", "Send Offset", "Send Size"]:
+ self.BootstrapConfig[lv3] = self.Tree.AppendItem(self.Mailbox["Bootstrap Configuration"], lv3)
+ # Children of Standard Configuration
+ self.StandardConfig = {}
+ for lv3 in ["Receive Offset", "Receive Size", "Send Offset", "Send Size"]:
+ self.StandardConfig[lv3] = self.Tree.AppendItem(self.Mailbox["Standard Configuration"], lv3)
+
+ # Expand Tree
+ for tree in [self.Root,
+ self.Level1Nodes["Config Data"],
+ self.Level1Nodes["Device Identity"],
+ self.Level1Nodes["Mailbox"],
+ self.Mailbox["Bootstrap Configuration"],
+ self.Mailbox["Standard Configuration"]]:
+ self.Tree.Expand(tree)
+
+
+#-------------------------------------------------------------------------------
+# For Hex View Panel
+# shows EEPROM binary as hex data and characters.
+#-------------------------------------------------------------------------------
+class HexView(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: Reference to the parent EtherCATManagementTreebook class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Panel.__init__(self, parent, -1)
+ self.parent = parent
+ self.Controler = controler
+
+ self.HexRow = 8
+ self.HexCol = 17
+
+ self.HexViewSizer = {"view" : wx.FlexGridSizer(cols=1, hgap=10, rows=2, vgap=10),
+ "siiButton" : wx.BoxSizer()}
+ self.HexViewButton = {}
+
+ for key, evt_handler in [("Sii Upload", self.OnButtonSiiUpload),
+ ("Sii Download", self.OnButtonSiiDownload),
+ ("Write to File", self.OnButtonWriteToBinFile),
+ ("Read from File", self.OnButtonReadFromBinFile),
+ ("XML to EEPROM Image", self.OnButtonXmlToEEPROMImg)]:
+ self.HexViewButton[key] = wx.Button(self, -1, key)
+ self.HexViewButton[key].Bind(wx.EVT_BUTTON, evt_handler)
+ self.HexViewSizer["siiButton"].Add(self.HexViewButton[key])
+
+ self.SiiBinary = self.Controler.CommonMethod.XmlToEeprom()
+ self.HexCode, self.HexRow, self.HexCol = self.Controler.CommonMethod.HexRead(self.SiiBinary)
+ self.SiiGrid = SiiGridTable(self, self.Controler, self.HexRow, self.HexCol)
+ self.HexViewSizer["view"].AddMany([self.HexViewSizer["siiButton"], self.SiiGrid])
+ self.SiiGrid.CreateGrid(self.HexRow, self.HexCol)
+ self.SetSizer(self.HexViewSizer["view"])
+ self.HexViewSizer["view"].FitInside(self.parent.parent)
+ self.parent.parent.FitInside()
+ self.SiiGrid.SetValue(self.HexCode)
+ self.SiiGrid.Update()
+
+ def UpdateSiiGridTable(self, row, col):
+ """
+ Destroy existing grid and recreate
+ @param row, col : Hex View grid size
+ """
+ self.HexViewSizer["view"].Detach(self.SiiGrid)
+ self.SiiGrid.Destroy()
+ self.SiiGrid = SiiGridTable(self, self.Controler, row, col)
+ self.HexViewSizer["view"].Add(self.SiiGrid)
+ self.SiiGrid.CreateGrid(row, col)
+ self.SetSizer(self.HexViewSizer["view"])
+ self.HexViewSizer["view"].FitInside(self.parent.parent)
+ self.parent.parent.FitInside()
+
+ def OnButtonSiiUpload(self, event):
+ """
+ Load EEPROM data from slave and refresh Hex View grid
+ Binded to 'Sii Upload' button.
+ @param event : wx.EVT_BUTTON object
+ """
+ # Check whether beremiz connected or not.
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(False)
+ if check_connect_flag:
+ # load from EEPROM data and parsing
+ self.SiiBinary = self.Controler.CommonMethod.LoadData()
+ self.HexCode, self.HexRow, self.HexCol = self.Controler.CommonMethod.HexRead(self.SiiBinary)
+ self.UpdateSiiGridTable(self.HexRow, self.HexCol)
+ self.SiiGrid.SetValue(self.HexCode)
+ self.SiiGrid.Update()
+
+ def OnButtonSiiDownload(self, event):
+ """
+ Write current EEPROM data to slave and refresh data structure kept by master
+ Binded to 'Sii Download' button.
+ @param event : wx.EVT_BUTTON object
+ """
+ # Check whether beremiz connected or not,
+ # and whether status is "Started" or not.
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(False)
+ if check_connect_flag:
+ status, count = self.Controler.GetCTRoot()._connector.GetPLCstatus()
+ if status is not "Started":
+ self.Controler.CommonMethod.SiiWrite(self.SiiBinary)
+ self.Controler.CommonMethod.Rescan()
+
+ def OnButtonWriteToBinFile(self, event):
+ """
+ Save current EEPROM data to binary file through FileDialog
+ Binded to 'Write to File' button.
+ @param event : wx.EVT_BUTTON object
+ """
+ dialog = wx.FileDialog(self, _("Save as..."), os.getcwd(), "slave0.bin",
+ _("bin files (*.bin)|*.bin|All files|*.*"), wx.SAVE|wx.OVERWRITE_PROMPT)
+
+ if dialog.ShowModal() == wx.ID_OK:
+ filepath = dialog.GetPath()
+ binfile = open(filepath,"wb")
+ binfile.write(self.SiiBinary)
+ binfile.close()
+
+ dialog.Destroy()
+
+ def OnButtonReadFromBinFile(self, event):
+ """
+ Load binary file through FileDialog
+ Binded to 'Read from File' button.
+ @param event : wx.EVT_BUTTON object
+ """
+ dialog = wx.FileDialog(self, _("Choose a binary file"), os.getcwd(), "",
+ _("bin files (*.bin)|*.bin"), wx.OPEN)
+
+ if dialog.ShowModal() == wx.ID_OK:
+ filepath = dialog.GetPath()
+
+ try:
+ binfile = open(filepath, "rb")
+ self.SiiBinary = binfile.read()
+ self.HexCode, self.HexRow, self.HexCol = self.Controler.CommonMethod.HexRead(self.SiiBinary)
+ self.UpdateSiiGridTable(self.HexRow, self.HexCol)
+ self.SiiGrid.SetValue(self.HexCode)
+ self.SiiGrid.Update()
+ except:
+ self.Controler.CommonMethod.CreateErrorDialog('The file does not exist!')
+
+ dialog.Destroy()
+
+ def OnButtonXmlToEEPROMImg(self, event):
+ """
+ Create EEPROM data based XML data that current imported
+ Binded to 'XML to EEPROM' button.
+ @param event : wx.EVT_BUTTON object
+ """
+ self.SiiBinary = self.Controler.CommonMethod.XmlToEeprom()
+ self.HexCode, self.HexRow, self.HexCol = self.Controler.CommonMethod.HexRead(self.SiiBinary)
+ self.UpdateSiiGridTable(self.HexRow, self.HexCol)
+ self.SiiGrid.SetValue(self.HexCode)
+ self.SiiGrid.Update()
+
+
+#-------------------------------------------------------------------------------
+# For Hex View grid (fill hex data)
+#-------------------------------------------------------------------------------
+class SiiGridTable(wx.grid.Grid):
+ def __init__(self, parent, controler, row, col):
+ """
+ Constructor
+ @param parent: Reference to the parent HexView class
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ @param row, col: Hex View grid size
+ """
+ self.parent = parent
+ self.Controler = controler
+ self.Row = row
+ self.Col = col
+
+ wx.grid.Grid.__init__(self, parent, -1, size=(830,450),
+ style=wx.ALIGN_CENTRE_HORIZONTAL|wx.ALIGN_CENTER_VERTICAL)
+
+ def SetValue(self, value):
+ """
+ Set data in the table
+ @param value: EEPROM data list of which element is 1 Byte hex data
+ """
+ # set label name and size
+ self.SetRowLabelSize(100)
+ for col in range(self.Col):
+ if col == 16:
+ self.SetColLabelValue(16, "Text View")
+ self.SetColSize(16, (self.GetSize().x-120)*4/20)
+ else:
+ self.SetColLabelValue(col, '%s'%col)
+ self.SetColSize(col, (self.GetSize().x-120)/20)
+
+ # set data into table
+ row = col = 0
+ for row_idx in value:
+ col = 0
+ self.SetRowLabelValue(row, "0x"+"{:0>4x}".format(row*(self.Col-1)))
+ for hex in row_idx:
+ self.SetCellValue(row, col, hex)
+
+ if col == 16:
+ self.SetCellAlignment(row, col, wx.ALIGN_LEFT, wx.ALIGN_CENTER)
+ else:
+ self.SetCellAlignment(row, col, wx.ALIGN_CENTRE, wx.ALIGN_CENTER)
+
+ self.SetReadOnly(row, col, True)
+ col = col + 1
+ row = row + 1
+
+
+#-------------------------------------------------------------------------------
+# For Register Access Panel
+#-------------------------------------------------------------------------------
+class RegisterAccessPanel(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: EEPROMAccessPanel object
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ self.parent = parent
+ self.Controler = controler
+ self.__init_data()
+
+ wx.Panel.__init__(self, parent, -1)
+
+ sizer = wx.FlexGridSizer(cols=1, hgap=20, rows=2, vgap=5)
+ button_sizer = wx.FlexGridSizer(cols=2, hgap=10, rows=1, vgap=10)
+
+ self.ReloadButton = wx.Button(self, -1, "Reload")
+ self.CompactViewCheckbox = wx.CheckBox(self, -1, "Compact View")
+ self.RegisterNotebook = RegisterNotebook(self, self.Controler)
+
+ button_sizer.AddMany([self.ReloadButton, self.CompactViewCheckbox])
+ sizer.AddMany([button_sizer, self.RegisterNotebook])
+ self.SetSizer(sizer)
+
+ self.ReloadButton.Bind(wx.EVT_BUTTON, self.OnReloadButton)
+ self.CompactViewCheckbox.Bind(wx.EVT_CHECKBOX, self.ToggleCompactViewCheckbox)
+
+ for index in range(4):
+ self.RegisterNotebook.RegPage[index].MainTable.CreateGrid(self.MainRow[index], self.MainCol)
+ self.RegisterNotebook.RegPage[index].MainTable.SetValue(self, 0, index*512, (index+1)*512)
+
+ # data default setting
+ if self.Controler.CommonMethod.RegData == "":
+ self.CompactViewCheckbox.Disable()
+ for index in range(4):
+ self.RegisterNotebook.RegPage[index].MainTable.SetValue(self, 0, index*512, (index+1)*512)
+ else: # If data was saved,
+ self.BasicSetData()
+ self.ParseData()
+ for index in range(4):
+ self.RegisterNotebook.RegPage[index].MainTable.SetValue(self, self.RegMonitorData, index*512, (index+1)*512)
+
+ def __init_data(self):
+ """
+ Declare initial data.
+ """
+ # flag for compact view
+ self.CompactFlag = False
+
+ # main grid의 rows and cols
+ self.MainRow = [512, 512, 512, 512]
+ self.MainCol = 4
+
+ # main grids' data range
+ self.PageRange = []
+ for index in range(4):
+ self.PageRange.append([512*index, 512*(index+1)])
+
+ # Previous value of register data for register description configuration
+ self.PreRegSpec = {"ESCType": "",
+ "FMMUNumber": "",
+ "SMNumber": "",
+ "PDIType": ""}
+
+ def LoadData(self):
+ """
+ Get data from the register.
+ """
+ self.Controler.CommonMethod.RegData = ""
+ #ethercat reg_read
+ #ex : ethercat reg_read -p 0 0x0000 0x0001
+ #return value : 0x11
+ for index in range(4):
+ self.Controler.CommonMethod.RegData = self.Controler.CommonMethod.RegData + " " + self.Controler.CommonMethod.RegRead("0x"+"{:0>4x}".format(index*1024), "0x0400")
+
+ # store previous value
+ # (ESC type, port number of FMMU, port number of SM, and PDI type))
+ for reg_spec in ["ESCType","FMMUNumber","SMNumber", "PDIType"]:
+ self.PreRegSpec[reg_spec] = self.Controler.CommonMethod.CrtRegSpec[reg_spec]
+
+ # update registers' description
+ # (ESC type, port number of FMMU, port number of SM, and PDI type)
+ for reg_spec, address in [("ESCType", "0x0000"),
+ ("FMMUNumber", "0x0004"),
+ ("SMNumber", "0x0005"),
+ ("PDIType", "0x0140")]:
+ self.Controler.CommonMethod.CrtRegSpec[reg_spec] = self.Controler.CommonMethod.RegRead(address, "0x0001")
+
+ # Enable compactView checkbox
+ self.CompactViewCheckbox.Enable()
+
+ def BasicSetData(self):
+ """
+ Get and save the description of registers.
+ It's done by parsing register_information.xml.
+ """
+ # parse the above register's value
+ # If the value is 0x12, the result is 12
+ self.ESCType = self.Controler.CommonMethod.CrtRegSpec["ESCType"].split('x')[1]
+ self.PDIType = self.Controler.CommonMethod.CrtRegSpec["PDIType"].split('x')[1]
+ # If the value is 0x12, the result is 18 (It's converted to decimal value)
+ self.FMMUNumber = int(self.Controler.CommonMethod.CrtRegSpec["FMMUNumber"], 16)
+ self.SMNumber = int(self.Controler.CommonMethod.CrtRegSpec["SMNumber"], 16)
+
+ # initialize description dictionary of register main table and register sub table.
+ self.RegisterDescriptionDict = {}
+ self.RegisterSubGridDict = {}
+
+ # ./EthercatMaster/register_information.xml contains register description.
+ if wx.Platform == '__WXMSW__':
+ reg_info_file = open("../../EthercatMaster/register_information.xml", 'r')
+ else:
+ reg_info_file = open("./EthercatMaster/register_information.xml", 'r')
+ reg_info_tree = minidom.parse(reg_info_file)
+ reg_info_file.close()
+
+ # parse register description
+ for register_info in reg_info_tree.childNodes:
+ for register in register_info.childNodes:
+ if register.nodeType == reg_info_tree.ELEMENT_NODE and register.nodeName == "Register":
+ # If it depends on the property(ESC type, PDI type, FMMU number, SM number)
+ for property, type, value in [("esc", "type", self.ESCType),
+ ("pdi", "type", self.PDIType),
+ ("fmmu", "number", self.FMMUNumber),
+ ("sm", "number", self.SMNumber)]:
+ if property in register.attributes.keys():
+ if type == "type":
+ if register.attributes[property].value == value:
+ self.GetRegisterInfo(reg_info_tree, register)
+ break
+ else: # type == "number"
+ if register.attributes[property].value < value:
+ self.GetRegisterInfo(reg_info_tree, register)
+ break
+ else:
+ self.GetRegisterInfo(reg_info_tree, register)
+ break
+
+ def GetRegisterInfo(self, reg_info_tree, register):
+ """
+ Save the register's description into the dictionary.
+ reg_info_tree is based on the register_information.xml.
+ @param reg_info_tree: XML tree
+ @param register: register which you want to get the description
+ """
+ # temporary variables for register main table idescription dictionary
+ reg_index = ""
+ reg_main_description = ""
+
+ for data in register.childNodes:
+ if data.nodeType == reg_info_tree.ELEMENT_NODE and data.nodeName == "Index":
+ for index in data.childNodes:
+ reg_index = index.nodeValue
+ if data.nodeType == reg_info_tree.ELEMENT_NODE and data.nodeName == "Description":
+ for description in data.childNodes:
+ reg_main_description = description.nodeValue
+
+ # Add description for register main table
+ if reg_index is not "" and reg_main_description is not "":
+ self.RegisterDescriptionDict[reg_index] = reg_main_description
+
+ if data.nodeType == reg_info_tree.ELEMENT_NODE and data.nodeName == "Details":
+ # declare register sub table description dictionary about this index
+ self.RegisterSubGridDict[reg_index] = []
+
+ for detail in data.childNodes:
+ if detail.nodeType == reg_info_tree.ELEMENT_NODE and detail.nodeName == "Detail":
+ # If it depends on the property(ESC type, PDI type, FMMU number, SM number)
+ for property, type, value in [("esc", "type", self.ESCType),
+ ("pdi", "type", self.PDIType),
+ ("fmmu", "number", self.FMMUNumber),
+ ("sm", "number", self.SMNumber)]:
+ if property in detail.attributes.keys():
+ if type == "type":
+ if detail.attributes[property].value == value:
+ self.GetRegisterDetailInfo(reg_info_tree, reg_index, detail)
+ break
+ else: # type == "number"
+ if detail.attributes[property].value < value:
+ self.GetRegisterDetailInfo(reg_info_tree, reg_index, detail)
+ break
+ else:
+ self.GetRegisterDetailInfo(reg_info_tree, reg_index, detail)
+ break
+
+ def GetRegisterDetailInfo(self, reg_info_tree, reg_index, detail):
+ """
+ Get the resgister's detailed description(for sub table) from the reg_info_tree.
+ @param reg_info_tree: XML tree (register_information.xml)
+ @param reg_index: index of the register
+ @param detail: description of the register
+ """
+ # temporary variables for register sub table description dictionary
+ # - It is initialized in every sub description
+ reg_bit_range = ""
+ reg_sub_description = ""
+ reg_enum_dictionary = {}
+
+ for detail_data in detail.childNodes:
+ if detail_data.nodeType == reg_info_tree.ELEMENT_NODE and detail_data.nodeName == "Range":
+ for range in detail_data.childNodes:
+ reg_bit_range = range.nodeValue
+ if detail_data.nodeType == reg_info_tree.ELEMENT_NODE and detail_data.nodeName == "Description":
+ for description in detail_data.childNodes:
+ reg_sub_description = description.nodeValue
+
+ if detail_data.nodeType == reg_info_tree.ELEMENT_NODE and detail_data.nodeName == "Enum":
+ for enum in detail_data.childNodes:
+ if enum.nodeType == reg_info_tree.ELEMENT_NODE and enum.nodeName == "item":
+
+ # temporary variables for a description of each value
+ # For example, if the bit is 1, it is 'enabled'('On', 'True', etc.),
+ # otherwise 'disabled'('Off', 'False', etc.).
+ reg_sub_value = ""
+ reg_sub_value_description = ""
+
+ for item in enum.childNodes:
+ if item.nodeType == reg_info_tree.ELEMENT_NODE and item.nodeName == "value":
+ for value in item.childNodes:
+ reg_sub_value = value.nodeValue
+ if item.nodeType == reg_info_tree.ELEMENT_NODE and item.nodeName == "Description":
+ for description in item.childNodes:
+ reg_sub_value_description = description.nodeValue
+
+ # Add a description of each value to register enum dictionary
+ if reg_sub_value is not "" and reg_sub_value_description is not "":
+ reg_enum_dictionary[reg_sub_value] = reg_sub_value_description
+
+ # add a description to register sub table description dictionary
+ if reg_bit_range is not "" and reg_sub_description is not "":
+ self.RegisterSubGridDict[reg_index].append([reg_bit_range,
+ reg_sub_description, reg_enum_dictionary])
+
+ def ParseData(self):
+ """
+ Transform the data into dec, hex, string, and description
+ """
+ row_data = []
+ self.RegMonitorData = []
+ reg_word = ""
+
+ reg_data = self.Controler.CommonMethod.RegData.split()
+
+ # loop for register(0x0000:0x0fff)
+ for address in range(0x1000):
+ # arrange 2 Bytes of register data
+ reg_word = reg_data[address].split('x')[1] + reg_word
+ if (address%2) == 1:
+ # append address
+ hex_address = "{:0>4x}".format(address-1)
+ row_data.append(hex_address)
+
+ # append description
+ if self.RegisterDescriptionDict.has_key(hex_address):
+ row_data.append(self.RegisterDescriptionDict[hex_address])
+ else:
+ row_data.append("")
+
+ # append Decimal value
+ row_data.append(str(int(reg_word, 16)))
+
+ # append Hex value
+ row_data.append('0x'+reg_word)
+
+ # append ASCII value
+ char_data = ""
+ for iter in range(2):
+ if int(reg_word[iter*2:iter*2+2], 16)>=32 and int(reg_word[iter*2:iter*2+2], 16)<=126:
+ char_data = char_data + chr(int(reg_word[iter*2:iter*2+2], 16))
+ else:
+ char_data = char_data + "."
+ row_data.append(char_data)
+
+ self.RegMonitorData.append(row_data)
+ reg_word = "" # initialize regWord
+ row_data = []
+
+ def OnReloadButton(self, event):
+ """
+ Handle the click event of the 'Reload' button.
+ Get the data from registers again, and update the table.
+ @param event: wx.EVT_BUTTON object
+ """
+ # Check whether beremiz connected or not.
+ check_connect_flag = self.Controler.CommonMethod.CheckConnect(False)
+ if check_connect_flag:
+ self.LoadData()
+ self.BasicSetData()
+ self.ParseData()
+ # set data into UI
+ if self.CompactFlag:
+ self.ToggleCompactViewCheckbox(True)
+ else :
+ for index in range(4):
+ self.RegisterNotebook.RegPage[index].UpdateMainTable(self.MainRow[index], self.MainCol,
+ self.PageRange[index][0], self.PageRange[index][1],
+ self.RegMonitorData)
+
+ def ToggleCompactViewCheckbox(self, event):
+ """
+ Handles the event of the 'Compact view' check box.
+ If it's checked, show only the registers that have a description.
+ If not, show all the registers.
+ @param event: wx.EVT_CHECKBOX object
+ """
+
+ # If "Compact View" Checkbox is True
+ ## 'event' is argument of this method or event of checkbox.
+ if event==True or event.GetEventObject().GetValue():
+ self.CompactFlag = True
+
+ reg_compact_data = []
+ page_row = [0, 0, 0, 0]
+ for index in range(4):
+ self.PageRange[index] = [0, 0]
+
+ for reg_row_data in self.RegMonitorData:
+ if reg_row_data[1] is not "":
+ # data structure for "compact view"
+ reg_compact_data.append(reg_row_data)
+ # count for each register notebooks' row
+ # It compare with register's address.
+ for index in range(4):
+ if int('0x'+reg_row_data[0], 16) < (index+1)*1024:
+ page_row[index] += 1
+ break
+
+ # Setting tables' rows and cols, range for compact view
+ for index in range(4):
+ self.MainRow[index] = page_row[index]
+ self.PageRange[index][1] = page_row[index]
+ for iter in range(index):
+ self.PageRange[index][0] += page_row[iter]
+ self.PageRange[index][1] += page_row[iter]
+
+ # Update table
+ for index in range(4):
+ self.RegisterNotebook.RegPage[index].UpdateMainTable(self.MainRow[index], self.MainCol,
+ self.PageRange[index][0], self.PageRange[index][1],
+ reg_compact_data)
+
+ # Compact View Checkbox is False
+ else:
+ self.CompactFlag = False
+ # Setting original rows, cols and range
+ self.MainRow = [512, 512, 512, 512]
+ self.PageRange = []
+
+ for index in range(4):
+ self.PageRange.append([512*index, 512*(index+1)])
+
+ # Update table
+ for index in range(4):
+ self.RegisterNotebook.RegPage[index].UpdateMainTable(self.MainRow[index], self.MainCol,
+ self.PageRange[index][0], self.PageRange[index][1],
+ self.RegMonitorData)
+
+
+#-------------------------------------------------------------------------------
+# For Register Access Notebook (divide index range)
+#-------------------------------------------------------------------------------
+class RegisterNotebook(wx.Notebook):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: RegisterAccessPanel object
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Notebook.__init__(self, parent, id = -1)
+
+ self.parent = parent
+ self.Controler = controler
+
+ # Initialize pages
+ self.RegPage = []
+ for iter in range(4):
+ self.RegPage.append(None)
+
+ for index in range(4):
+ self.RegPage[index] = RegisterNotebookPanel(self, self.Controler,
+ parent.MainRow[index], parent.MainCol)
+ self.AddPage(self.RegPage[index],
+ "0x"+"{:0>4x}".format(index*1024)+" - 0x"+"{:0>4x}".format((index+1)*1024-1))
+
+ self.Bind(wx.EVT_NOTEBOOK_PAGE_CHANGED, self.OnPageChanged)
+ self.Bind(wx.EVT_NOTEBOOK_PAGE_CHANGING, self.OnPageChanging)
+
+ def OnPageChanged(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+ def OnPageChanging(self, event):
+ old = event.GetOldSelection()
+ new = event.GetSelection()
+ sel = self.GetSelection()
+ event.Skip()
+
+
+#-------------------------------------------------------------------------------
+# For Register Access Notebook Panel
+# (Main UI : including main, sub table)
+#-------------------------------------------------------------------------------
+class RegisterNotebookPanel(wx.Panel):
+ def __init__(self, parent, controler, row, col):
+ """
+ Constructor
+ @param parent: RegisterAccessPanel object
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ @param row, col: size of the table
+ """
+ wx.Panel.__init__(self, parent, -1)
+
+ self.parent = parent
+ self.Controler = controler
+ self.Row = row
+ self.Col = col
+ sub_row = 0
+ sub_col = 4
+
+ self.Sizer = wx.FlexGridSizer(cols=1, hgap=10, rows=2, vgap=30)
+
+ self.MainTable = RegisterMainTable(self, self.Row, self.Col, self.Controler)
+ self.SubTable = RegisterSubTable(self, sub_row, sub_col)
+
+ self.SubTable.CreateGrid(sub_row, sub_col)
+ self.SubTable.SetValue(self, [])
+
+ self.Sizer.AddMany([self.MainTable, self.SubTable])
+
+ self.SetSizer(self.Sizer)
+
+ def UpdateMainTable(self, row, col, low_index, high_index, data):
+ """
+ Updates main table.
+ It's done by deleting the main table and creating it again.
+ @param row, col: size of the table
+ @param low_index: the lowest index of the page
+ @param high_index: the highest index of the page
+ @param data: data
+ """
+ self.MainTable.Destroy()
+ self.MainTable = RegisterMainTable(self, row, col, self.Controler)
+ self.Sizer.Detach(self.SubTable)
+ self.Sizer.AddMany([self.MainTable, self.SubTable])
+ self.SetSizer(self.Sizer)
+ self.MainTable.CreateGrid(row, col)
+ self.MainTable.SetValue(self, data, low_index, high_index)
+ self.MainTable.Update()
+
+ def UpdateSubTable(self, row, col, data):
+ """
+ Updates sub table.
+ It's done by deleting the sub table and creating it again.
+ @param row, col: size of the table
+ @param data: data
+ """
+ self.SubTable.Destroy()
+ self.SubTable = RegisterSubTable(self, row, col)
+ self.Sizer.Detach(self.MainTable)
+ self.Sizer.AddMany([self.MainTable, self.SubTable])
+ self.Sizer.Layout()
+ self.SetSizer(self.Sizer)
+ self.SubTable.CreateGrid(row, col)
+ self.SubTable.SetValue(self, data)
+ self.SubTable.Update()
+
+
+#-------------------------------------------------------------------------------
+# For Register Access Notebook Panel (Main Table)
+#-------------------------------------------------------------------------------
+class RegisterMainTable(wx.grid.Grid):
+ def __init__(self, parent, row, col, controler):
+ """
+ Constructor
+ @param parent: RegisterNotebook object
+ @param row, col: size of the table
+ @param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ self.parent = parent
+ self.Data = {}
+ self.Row = row
+ self.Col = col
+ self.Controler = controler
+ self.RegisterAccessPanel = self.parent.parent.parent
+
+ wx.grid.Grid.__init__(self, parent, -1, size=(820,300),
+ style=wx.EXPAND|wx.ALIGN_CENTRE_HORIZONTAL|wx.ALIGN_CENTER_VERTICAL)
+
+ for evt, mapping_method in [(gridlib.EVT_GRID_CELL_LEFT_CLICK, self.OnSelectCell),
+ (gridlib.EVT_GRID_CELL_LEFT_CLICK, self.OnSelectCell),
+ (gridlib.EVT_GRID_CELL_LEFT_DCLICK, self.OnRegModifyDialog)]:
+ self.Bind(evt, mapping_method)
+
+ def SetValue(self, parent, reg_monitor_data, low_index, high_index):
+ """
+ Set the RegMonitorData into the main table.
+ @param parent: RegisterNotebook object
+ @param reg_monitor_data: data
+ @param low_index: the lowest index of the page
+ @param high_index: the highest index of the page
+ """
+ self.RegMonitorData = reg_monitor_data
+
+ # set label name and size
+ register_maintable_label = [(0, "Description"), (1, "Dec"),
+ (2, "Hex"), (3, "Char")]
+
+ for (index, label) in register_maintable_label:
+ self.SetColLabelValue(index, label)
+
+ self.SetColSize(0, 200)
+
+ # if reg_monitor_data is 0, it is initialization of register access.
+ if reg_monitor_data == 0:
+ return 0
+
+ # set data into UI
+ row = col = 0
+ for row_index in reg_monitor_data[low_index:high_index]:
+ col = 0
+ self.SetRowLabelValue(row, row_index[0])
+ for data_index in range(4):
+ self.SetCellValue(row, col, row_index[data_index+1])
+ self.SetCellAlignment(row, col, wx.ALIGN_CENTRE, wx.ALIGN_CENTER)
+ self.SetReadOnly(row, col, True)
+ col = col + 1
+ row = row + 1
+
+ def OnSelectCell(self, event):
+ """
+ Handles the event of the cell of the main table.
+ @param event: gridlib object (left click)
+ """
+ # if reg_monitor_data is 0, it is initialization of register access.
+ if self.RegMonitorData == 0:
+ event.Skip()
+ return 0
+
+ sub_row = 0
+ sub_col = 4
+
+ address = self.GetRowLabelValue(event.GetRow())
+
+ reg_sub_grid_data = []
+
+ BIT_RANGE, NAME, DESCRIPTIONS = range(3)
+
+ # Check if this register's detail description is exist or not,
+ # and create data structure for the detail description table ; sub grid
+ if address in self.RegisterAccessPanel.RegisterSubGridDict:
+ for element in self.RegisterAccessPanel.RegisterSubGridDict[address]:
+ row_data =[]
+ row_data.append(element[BIT_RANGE])
+ row_data.append(element[NAME])
+ bin_data = "{:0>16b}".format(int(self.GetCellValue(event.GetRow(), 1)))
+ value_range = element[BIT_RANGE].split('-')
+ value = (bin_data[8:16][::-1]+bin_data[0:8][::-1])[int(value_range[0]):(int(value_range[-1])+1)][::-1]
+ row_data.append(str(int(('0b'+str(value)), 2)))
+ if value in element[DESCRIPTIONS]:
+ row_data.append(element[DESCRIPTIONS][value])
+ else:
+ row_data.append('')
+ reg_sub_grid_data.append(row_data)
+ sub_row = sub_row + 1
+
+ self.parent.UpdateSubTable(sub_row, sub_col, reg_sub_grid_data)
+ # event.Skip() updates UI of selecting cell
+ event.Skip()
+
+ def OnRegModifyDialog(self, event):
+ """
+ Handle the event of the cell of the main table.
+ Display the window where the user modifies the value of the cell.
+ @param event: gridlib object (double click)
+ """
+ # user can enter a value in case that user double-clicked 'Dec' or 'Hex' value.
+ if event.GetCol() == 1 or event.GetCol() == 2:
+ dlg = wx.TextEntryDialog(self, "Enter hex(0xnnnn) or dec(n) value",
+ "Register Modify Dialog", style = wx.OK|wx.CANCEL)
+
+ # Setting value in initial dialog value
+ start_value = self.GetCellValue(event.GetRow(), event.GetCol())
+ dlg.SetValue(start_value)
+
+ if dlg.ShowModal() == wx.ID_OK:
+ try:
+ # It int(input) success, this input is dev or hex value.
+ # Otherwise, it's error, so it goes except.
+ int(dlg.GetValue(), 0)
+
+ # reg_write
+ # ex) ethercat reg_write -p 0 -t uint16 0x0000 0x0000
+ return_val = self.Controler.CommonMethod.RegWrite('0x'+self.GetRowLabelValue(event.GetRow()), dlg.GetValue())
+
+ if len(return_val)==0:
+ # set dec
+ self.SetCellValue(event.GetRow(), 1, str(int(dlg.GetValue(), 0)))
+ # set hex
+ hex_data = '0x'+"{:0>4x}".format(int(dlg.GetValue(), 0))
+ self.SetCellValue(event.GetRow(), 2, hex_data)
+ # set char
+ char_data = ""
+ # If hex_data is been able to convert to ascii code, append ascii code.
+ for iter in range(2):
+ if int(hex_data[(iter+1)*2:(iter+2)*2], 16)>=32 and int(hex_data[(iter+1)*2:(iter+2)*2], 16)<=126:
+ char_data = char_data + chr(int(hex_data[(iter+1)*2:(iter+2)*2], 16))
+ else:
+ char_data = char_data + "."
+
+ self.SetCellValue(event.GetRow(), 3, char_data)
+
+ else:
+ self.Controler.CommonMethod.CreateErrorDialog('You can\'t modify it. This register is read-only or it\'s not connected.')
+
+ except ValueError:
+ self.Controler.CommonMethod.CreateErrorDialog('You entered wrong value. You can enter dec or hex value only.')
+
+
+#-------------------------------------------------------------------------------
+# For Register Access Notebook Panel (Sub Table)
+#-------------------------------------------------------------------------------
+class RegisterSubTable(wx.grid.Grid):
+ def __init__(self, parent, row, col):
+ """
+ Constructor
+ @param parent: RegisterNotebook object
+ @param row, col: size of the table
+ """
+ self.parent = parent
+ self.Data = {}
+ self.Row = row
+ self.Col = col
+
+ wx.grid.Grid.__init__(self, parent, -1, size=(820,150),
+ style=wx.EXPAND|wx.ALIGN_CENTRE_HORIZONTAL|wx.ALIGN_CENTER_VERTICAL)
+
+ def SetValue(self, parent, data):
+ """
+ Set the data into the subtable.
+ @param parent: RegisterNotebook object
+ @param data: data
+ """
+ # lset label name and size
+ Register_SubTable_Label = [(0, "Bits"), (1, "Name"),
+ (2, "Value"), (3, "Enum")]
+
+ for (index, label) in Register_SubTable_Label:
+ self.SetColLabelValue(index, label)
+
+ self.SetColSize(1, 200)
+ self.SetColSize(3, 200)
+
+ # set data into table
+ row = col = 0
+ for rowData in data:
+ col = 0
+ for element in rowData:
+ self.SetCellValue(row, col, element)
+ self.SetCellAlignment(row, col, wx.ALIGN_CENTRE, wx.ALIGN_CENTER)
+ self.SetReadOnly(row, col, True)
+ col = col + 1
+ row = row + 1
+
+
+#-------------------------------------------------------------------------------
+# For Master State Panel
+#-------------------------------------------------------------------------------
+class MasterStatePanelClass(wx.Panel):
+ def __init__(self, parent, controler):
+ """
+ Constructor
+ @param parent: wx.ScrollWindow object
+ @Param controler: _EthercatSlaveCTN class in EthercatSlave.py
+ """
+ wx.Panel.__init__(self, parent, -1, (0, 0),
+ size=wx.DefaultSize, style = wx.SUNKEN_BORDER)
+ self.Controler = controler
+ self.parent = parent
+ self.StaticBox = {}
+ self.StaticText = {}
+ self.TextCtrl = {}
+
+ # ----------------------- Main Sizer and Update Button --------------------------------------------
+ self.MasterStateSizer = {"main" : wx.BoxSizer(wx.VERTICAL)}
+ for key, attr in [
+ ("innerMain", [1, 10, 2, 10]),
+ ("innerTopHalf", [2, 10, 1, 10]),
+ ("innerBottomHalf", [2, 10, 1, 10]),
+ ("innerMasterState", [2, 10, 3, 10]),
+ ("innerDeviceInfo", [4, 10, 3, 10]),
+ ("innerFrameInfo", [4, 10, 5, 10])]:
+ self.MasterStateSizer[key] = wx.FlexGridSizer(cols=attr[0], hgap=attr[1], rows=attr[2], vgap=attr[3])
+
+
+ self.UpdateButton = wx.Button(self, label=_('Update'))
+ self.UpdateButton.Bind(wx.EVT_BUTTON, self.OnButtonClick)
+
+ for key, label in [
+ ('masterState', 'EtherCAT Master State'),
+ ('deviceInfo', 'Ethernet Network Card Information'),
+ ('frameInfo', 'Network Frame Information')]:
+ self.StaticBox[key] = wx.StaticBox(self, label=_(label))
+ self.MasterStateSizer[key] = wx.StaticBoxSizer(self.StaticBox[key])
+
+
+ # ----------------------- Master State -----------------------------------------------------------
+ for key, label in [
+ ('Phase', 'Phase:'),
+ ('Active', 'Active:'),
+ ('Slaves', 'Slave Count:')]:
+ self.StaticText[key] = wx.StaticText(self, label=_(label))
+ self.TextCtrl[key] = wx.TextCtrl(self, size=wx.Size(130, 24), style=wx.TE_READONLY)
+ self.MasterStateSizer['innerMasterState'].AddMany([self.StaticText[key], self.TextCtrl[key]])
+
+ self.MasterStateSizer['masterState'].AddSizer(self.MasterStateSizer['innerMasterState'])
+
+ # ----------------------- Ethernet Network Card Information ---------------------------------------
+ for key, label in [
+ ('Main', 'MAC Address:'),
+ ('Link', 'Link State:'),
+ ('Tx frames', 'Tx Frames:'),
+ ('Rx frames', 'Rx Frames:'),
+ ('Lost frames', 'Lost Frames:')]:
+ self.StaticText[key] = wx.StaticText(self, label=_(label))
+ self.TextCtrl[key] = wx.TextCtrl(self, size=wx.Size(130, 24), style=wx.TE_READONLY)
+ self.MasterStateSizer['innerDeviceInfo'].AddMany([self.StaticText[key], self.TextCtrl[key]])
+
+ self.MasterStateSizer['deviceInfo'].AddSizer(self.MasterStateSizer['innerDeviceInfo'])
+
+ # ----------------------- Network Frame Information -----------------------------------------------
+ for key, label in [
+ ('Tx frame rate [1/s]', 'Tx Frame Rate [1/s]:'),
+ ('Rx frame rate [1/s]', 'Tx Rate [kByte/s]:'),
+ ('Loss rate [1/s]', 'Loss Rate [1/s]:'),
+ ('Frame loss [%]', 'Frame Loss [%]:')]:
+ self.StaticText[key] = wx.StaticText(self, label=_(label))
+ self.MasterStateSizer['innerFrameInfo'].Add(self.StaticText[key])
+ self.TextCtrl[key] = {}
+ for index in ['0', '1', '2']:
+ self.TextCtrl[key][index] = wx.TextCtrl(self, size=wx.Size(130, 24), style=wx.TE_READONLY)
+ self.MasterStateSizer['innerFrameInfo'].Add(self.TextCtrl[key][index])
+
+ self.MasterStateSizer['frameInfo'].AddSizer(self.MasterStateSizer['innerFrameInfo'])
+
+ # --------------------------------- Main Sizer ----------------------------------------------------
+ for key, sub, in [
+ ('innerTopHalf', [
+ 'masterState', 'deviceInfo']),
+ ('innerBottomHalf', [
+ 'frameInfo']),
+ ('innerMain', [
+ 'innerTopHalf', 'innerBottomHalf'])]:
+ for key2 in sub:
+ self.MasterStateSizer[key].AddSizer(self.MasterStateSizer[key2])
+
+ self.MasterStateSizer['main'].AddSizer(self.UpdateButton)
+ self.MasterStateSizer['main'].AddSizer(self.MasterStateSizer['innerMain'])
+
+ self.SetSizer(self.MasterStateSizer['main'])
+
+ def OnButtonClick(self, event):
+ """
+ Handle the event of the 'Update' button.
+ Update the data of the master state.
+ @param event: wx.EVT_BUTTON object
+ """
+ if self.Controler.GetCTRoot()._connector is not None:
+ self.MasterState = self.Controler.CommonMethod.GetMasterState()
+ # Update each TextCtrl
+ if self.MasterState:
+ for key in self.TextCtrl:
+ if isinstance(self.TextCtrl[key], dict):
+ for index in self.TextCtrl[key]:
+ self.TextCtrl[key][index].SetValue(self.MasterState[key][int(index)])
+ else:
+ self.TextCtrl[key].SetValue(self.MasterState[key][0])
+ else :
+ self.Controler.CommonMethod.CreateErrorDialog('PLC not connected!')
--- a/etherlab/EthercatCIA402Slave.py Mon Jun 03 08:24:08 2013 +0200
+++ b/etherlab/EthercatCIA402Slave.py Wed Apr 02 15:03:32 2014 +0200
@@ -5,9 +5,13 @@
from PLCControler import LOCATION_CONFNODE, LOCATION_MODULE, LOCATION_GROUP, LOCATION_VAR_INPUT, LOCATION_VAR_OUTPUT, LOCATION_VAR_MEMORY
from MotionLibrary import Headers, AxisXSD
-from EthercatSlave import _EthercatSlaveCTN
+from EthercatSlave import _EthercatSlaveCTN, _CommonSlave
from ConfigEditor import CIA402NodeEditor
+#------------------------------------------
+#from CommonSlave import _CommonSlave
+#------------------------------------------
+
NODE_VARIABLES = [
("ControlWord", 0x6040, 0x00, "UINT", "Q"),
("TargetPosition", 0x607a, 0x00, "DINT", "Q"),
@@ -102,7 +106,15 @@
"tooltip" : _("Initiate Drag'n drop of Axis ref located variable"),
"method" : "_getCIA402AxisRef",
"push": True},
- ]
+ ]
+
+#--------------------------------------------------
+# class code
+#--------------------------------------------------
+
+ def __init__(self):
+ # ----------- call ethercat mng. function --------------
+ self.CommonMethod = _CommonSlave(self)
def GetIconName(self):
return "CIA402Slave"
@@ -268,3 +280,4 @@
cia402nodefile.close()
return [(Gen_CIA402Nodefile_path, '"-I%s"'%os.path.abspath(self.GetCTRoot().GetIECLibPath()))],"",True
+
\ No newline at end of file
--- a/etherlab/EthercatMaster.py Mon Jun 03 08:24:08 2013 +0200
+++ b/etherlab/EthercatMaster.py Wed Apr 02 15:03:32 2014 +0200
@@ -11,7 +11,7 @@
from dialogs import BrowseValuesLibraryDialog
from IDEFrame import TITLE, FILEMENU, PROJECTTREE
-from EthercatSlave import _EthercatSlaveCTN, ExtractHexDecValue, GenerateHexDecValue, TYPECONVERSION, VARCLASSCONVERSION
+from EthercatSlave import _EthercatSlaveCTN, ExtractHexDecValue, GenerateHexDecValue, TYPECONVERSION, VARCLASSCONVERSION, _CommonSlave
from EthercatCFileGenerator import _EthercatCFileGenerator
from ConfigEditor import MasterEditor
from POULibrary import POULibrary
@@ -73,6 +73,7 @@
ethelabfile.write(etherlab_ext_code)
ethelabfile.close()
+ runtimefile_path = os.path.join(os.path.split(__file__)[0], "runtime_etherlab.py")
return ((["etherlab_ext"], [(Gen_etherlabfile_path, IECCFLAGS)], True), "",
("runtime_etherlab.py", file(GetLocalPath("runtime_etherlab.py"))))
@@ -208,7 +209,7 @@
ProcessVariablesClasses = GenerateClassesFromXSDstring(ProcessVariablesXSD)
class _EthercatCTN:
-
+
CTNChildrenTypes = [("EthercatSlave", _EthercatSlaveCTN, "Ethercat Slave")]
if HAS_MCL:
CTNChildrenTypes.append(("EthercatCIA402Slave", _EthercatCIA402SlaveCTN, "Ethercat CIA402 Slave"))
@@ -246,6 +247,9 @@
else:
self.CreateBuffer(False)
self.OnCTNSave()
+
+ # ----------- call ethercat mng. function --------------
+ self.CommonMethod = _CommonSlave(self)
def GetIconName(self):
return "Ethercat"
@@ -539,6 +543,7 @@
device, module_extra_params = self.GetModuleInfos(type_infos)
if device is not None:
entries = device.GetEntriesList(limits)
+ #print entries
entries_list = entries.items()
entries_list.sort()
entries = []
--- a/etherlab/EthercatSlave.py Mon Jun 03 08:24:08 2013 +0200
+++ b/etherlab/EthercatSlave.py Wed Apr 02 15:03:32 2014 +0200
@@ -5,6 +5,11 @@
from ConfigEditor import NodeEditor
+#------------------------------------------
+from CommonEtherCATFunction import _CommonSlave
+#------------------------------------------
+
+
TYPECONVERSION = {"BOOL" : "X", "SINT" : "B", "INT" : "W", "DINT" : "D", "LINT" : "L",
"USINT" : "B", "UINT" : "W", "UDINT" : "D", "ULINT" : "L",
"BYTE" : "B", "WORD" : "W", "DWORD" : "D", "LWORD" : "L"}
@@ -42,15 +47,19 @@
return name.getcontent()
return default
+
#--------------------------------------------------
# Ethercat Node
#--------------------------------------------------
class _EthercatSlaveCTN:
-
NODE_PROFILE = None
EditorType = NodeEditor
+ def __init__(self):
+ # ----------- call ethercat mng. function --------------
+ self.CommonMethod = _CommonSlave(self)
+
def GetIconName(self):
return "Slave"
@@ -97,12 +106,18 @@
return params
def SetParamsAttribute(self, path, value):
+ self.GetSlaveInfos()
position = self.BaseParams.getIEC_Channel()
if path == "SlaveParams.Type":
self.CTNParent.SetSlaveType(position, value)
slave_type = self.CTNParent.GetSlaveType(self.GetSlavePos())
value = (slave_type["device_type"], slave_type)
+ #if self._View is not None:
+ #wx.CallAfter(self._View.EtherCATManagementTreebook.SlaveStatePanel.RefreshSlaveInfos())
+ #self._View.EtherCATManagementTreebook.SlaveStatePanel.RefreshSlaveInfos()
+ #self._View.EtherCATManagementTreebook.PDOMonitoringPanel.PDOInfoUpdate()
+ #self._View.EtherCATManagementTreebook.SmartView.Create_SmartView()
return value, True
elif path == "SlaveParams.Alias":
self.CTNParent.SetSlaveAlias(position, value)
--- a/etherlab/etherlab.py Mon Jun 03 08:24:08 2013 +0200
+++ b/etherlab/etherlab.py Wed Apr 02 15:03:32 2014 +0200
@@ -159,7 +159,7 @@
"BitSize": object.getBitSize(),
"Access": entry_access,
"PDOMapping": entry_pdomapping}
-
+
for TxPdo in self.getTxPdo():
ExtractPdoInfos(TxPdo, "Transmit", entries, limits)
for RxPdo in self.getRxPdo():
@@ -167,7 +167,7 @@
return entries
setattr(cls, "GetEntriesList", GetEntriesList)
-
+
def GetSyncManagers(self):
sync_managers = []
for sync_manager in self.getSm():
@@ -287,33 +287,36 @@
xml_tree = minidom.parse(xmlfile)
xmlfile.close()
- modules_infos = None
+ self.modules_infos = None
for child in xml_tree.childNodes:
if child.nodeType == xml_tree.ELEMENT_NODE and child.nodeName == "EtherCATInfo":
- modules_infos = EtherCATInfoClasses["EtherCATInfo.xsd"]["EtherCATInfo"]()
- modules_infos.loadXMLTree(child)
+ self.modules_infos = EtherCATInfoClasses["EtherCATInfo.xsd"]["EtherCATInfo"]()
+ self.modules_infos.loadXMLTree(child)
- if modules_infos is not None:
- vendor = modules_infos.getVendor()
+ if self.modules_infos is not None:
+ vendor = self.modules_infos.getVendor()
vendor_category = self.Library.setdefault(ExtractHexDecValue(vendor.getId()),
{"name": ExtractName(vendor.getName(), _("Miscellaneous")),
"groups": {}})
- for group in modules_infos.getDescriptions().getGroups().getGroup():
+ for group in self.modules_infos.getDescriptions().getGroups().getGroup():
group_type = group.getType()
vendor_category["groups"].setdefault(group_type, {"name": ExtractName(group.getName(), group_type),
"parent": group.getParentGroup(),
"order": group.getSortOrder(),
+ "value": group.getcontent()["value"],
"devices": []})
- for device in modules_infos.getDescriptions().getDevices().getDevice():
+ for device in self.modules_infos.getDescriptions().getDevices().getDevice():
device_group = device.getGroupType()
if not vendor_category["groups"].has_key(device_group):
raise ValueError, "Not such group \"%\"" % device_group
vendor_category["groups"][device_group]["devices"].append((device.getType().getcontent(), device))
+ return self.Library
+
def GetModulesLibrary(self, profile_filter=None):
if self.Library is None:
self.LoadModules()
@@ -375,6 +378,8 @@
revision_number = ExtractHexDecValue(device_infos.getType().getRevisionNo())
if (product_code == ExtractHexDecValue(module_infos["product_code"]) and
revision_number == ExtractHexDecValue(module_infos["revision_number"])):
+ self.cntdevice = device_infos
+ self.cntdeviceType = device_type
return device_infos, self.GetModuleExtraParams(vendor, product_code, revision_number)
return None, None
@@ -459,7 +464,8 @@
CTNChildrenTypes = [("EthercatNode",_EthercatCTN,"Ethercat Master")]
EditorType = LibraryEditor
-
+
+
def __init__(self):
self.ModulesLibrary = None
self.LoadModulesLibrary()
@@ -502,4 +508,3 @@
def GetModuleInfos(self, module_infos):
return self.ModulesLibrary.GetModuleInfos(module_infos)
-
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/etherlab/register_information.xml Wed Apr 02 15:03:32 2014 +0200
@@ -0,0 +1,7114 @@
+<?xml version="1.0" encoding="utf-8"?>
+<RegisterInfo>
+ <!--ESC Information-->
+ <Register>
+ <Index>0000</Index>
+ <Description>ESC Rev/Type</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Type</Description>
+ <Enum>
+ <item>
+ <value>00000010</value>
+ <Description>ESC10/ESC20</Description>
+ </item>
+ <item>
+ <value>00000100</value>
+ <Description>IP Core</Description>
+ </item>
+ <item>
+ <value>00010001</value>
+ <Description>ET1100</Description>
+ </item>
+ <item>
+ <value>00010010</value>
+ <Description>ET1200</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>Revision</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0002</Index>
+ <Description>ESC Build</Description>
+ <Details>
+ <Detail esc="04">
+ <Range>0-3</Range>
+ <Description>Maintenance version</Description>
+ </Detail>
+ <Detail esc="04">
+ <Range>4-7</Range>
+ <Description>Minor version</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0004</Index>
+ <Description>SM/FMMU Cnt</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>FMMU cnt</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>SM cnt</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0006</Index>
+ <Description>Ports/DPRAM</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>DPRAM (Kbyte)</Description>
+ </Detail>
+ <Detail>
+ <Range>8-9</Range>
+ <Description>Port A</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Not implemented</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Not configured (EEPROM)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>MII/RMII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10-11</Range>
+ <Description>Port B</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Not implemented</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Not configured (EEPROM)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>MII/RMII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12-13</Range>
+ <Description>Port C</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Not implemented</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Not configured (EEPROM)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>MII/RMII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14-15</Range>
+ <Description>Port D</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Not implemented</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Not configured (EEPROM)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>MII/RMII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0008</Index>
+ <Description>Features</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>FMMU Operation</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Bit oriented</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Byte oriented</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>DC support</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>DC 64 bit support</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE
+</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>E-Bus low jitter</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>E-Bus ext. link detection</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>MII ext. link detection</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>Separate Handling of FCS Errors</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>DC SYNC ext. Activation</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>EtherCAT LRW cmd. support</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>EtherCAT R/W cmd. support</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>Fixed FMMU/SM Cfg.</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--Station Address-->
+ <Register>
+ <Index>0010</Index>
+ <Description>Phys Addr</Description>
+ </Register>
+ <Register>
+ <Index>0012</Index>
+ <Description>Configured Station Alias</Description>
+ </Register>
+ <!--Write Protection-->
+ <Register>
+ <Index>0020</Index>
+ <Description>Register Protect</Description>
+ </Register>
+ <Register>
+ <Index>0030</Index>
+ <Description>Access Protect</Description>
+ </Register>
+ <!--Data Link Layer-->
+ <Register>
+ <Index>0040</Index>
+ <Description>ESC Reset</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>ESC reset ECAT</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>ESC reset PDI</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0100</Index>
+ <Description>ESC Ctrl</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Kill non EtherCATframes</Description>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Temporary loop control</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Permanent use</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Use for about 1 sec.</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8-9</Range>
+ <Description>Port A</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Auto loop</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Auto close</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10-11</Range>
+ <Description>Port B</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Auto loop</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Auto close</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12-13</Range>
+ <Description>Port C</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Auto loop</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Auto close</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14-15</Range>
+ <Description>Port D</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Auto loop</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Auto close</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0102</Index>
+ <Description>ESC Ctrl Ext</Description>
+ <Details>
+ <Detail>
+ <Range>0-2</Range>
+ <Description>RX FIFO size</Description>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>EBUS Low jitter</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Normal jitter</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Reducedjitter</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>EBUSremote link down signaling time</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Default</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Reduced</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Station alias</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Ignore</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Available</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0108</Index>
+ <Description>Phys. RW Offset</Description>
+ </Register>
+ <Register>
+ <Index>0110</Index>
+ <Description>ESC Status</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Operation</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>PDI watchdog</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>expired</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>reloaded</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Enh. Link Detection</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Deactive</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Physical link Port A</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Physical link Port B</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>Physical link Port C</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>Physical link Port D</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8-9</Range>
+ <Description>Port A</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Loop Open, no link</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Loop closed, no link</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open, with link</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed, with link</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10-11</Range>
+ <Description>Port B</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Loop Open, no link</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Loop closed, no link</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open, with link</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed, with link</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12-13</Range>
+ <Description>Port C</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Loop Open, no link</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Loop closed, no link</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open, with link</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed, with link</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14-15</Range>
+ <Description>Port D</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Loop Open, no link</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Loop closed, no link</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Loop open, with link</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Loop closed, with link</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--Application Layer-->
+ <Register>
+ <Index>0120</Index>
+ <Description>AL Ctrl</Description>
+ <Details>
+ <Detail>
+ <Range>0-3</Range>
+ <Description>AL Ctrl</Description>
+ <Enum>
+ <item>
+ <value>0000</value>
+ <Description>INIT</Description>
+ </item>
+ <item>
+ <value>0011</value>
+ <Description>Bootstrap</Description>
+ </item>
+ <item>
+ <value>0010</value>
+ <Description>PREOP</Description>
+ </item>
+ <item>
+ <value>0100</value>
+ <Description>SAFEOP</Description>
+ </item>
+ <item>
+ <value>1000</value>
+ <Description>OP</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Error Ack</Description>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Device Identification</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>No request</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Device Identification request</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0130</Index>
+ <Description>AL Status</Description>
+ <Details>
+ <Detail>
+ <Range>0-3</Range>
+ <Description>AL Status</Description>
+ <Enum>
+ <item>
+ <value>0000</value>
+ <Description>INIT</Description>
+ </item>
+ <item>
+ <value>0011</value>
+ <Description>Bootstrap</Description>
+ </item>
+ <item>
+ <value>0010</value>
+ <Description>PREOP</Description>
+ </item>
+ <item>
+ <value>0100</value>
+ <Description>SAFEOP</Description>
+ </item>
+ <item>
+ <value>1000</value>
+ <Description>OP</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Error</Description>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Device Identification</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>not valid</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>loaded</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0134</Index>
+ <Description>AL Status Code</Description>
+ </Register>
+ <Register>
+ <Index>0138</Index>
+ <Description>RUN/ERR LED Override</Description>
+ <Details>
+ <Detail esc="04">
+ <Range>0-3</Range>
+ <Description>RUN LED Code</Description>
+ <Enum>
+ <item>
+ <value>0000</value>
+ <Description>Off</Description>
+ </item>
+ <item>
+ <value>0001</value>
+ <Description>Flash 1x</Description>
+ </item>
+ <item>
+ <value>0010</value>
+ <Description>Flash 2x</Description>
+ </item>
+ <item>
+ <value>0011</value>
+ <Description>Flash 3x</Description>
+ </item>
+ <item>
+ <value>0100</value>
+ <Description>Flash 4x</Description>
+ </item>
+ <item>
+ <value>0101</value>
+ <Description>Flash 5x</Description>
+ </item>
+ <item>
+ <value>0110</value>
+ <Description>Flash 6x</Description>
+ </item>
+ <item>
+ <value>0111</value>
+ <Description>Flash 7x</Description>
+ </item>
+ <item>
+ <value>1000</value>
+ <Description>Flash 8x</Description>
+ </item>
+ <item>
+ <value>1001</value>
+ <Description>Flash 9x</Description>
+ </item>
+ <item>
+ <value>1010</value>
+ <Description>Flash 10x</Description>
+ </item>
+ <item>
+ <value>1011</value>
+ <Description>Flash 11x</Description>
+ </item>
+ <item>
+ <value>1100</value>
+ <Description>Flash 12x</Description>
+ </item>
+ <item>
+ <value>1101</value>
+ <Description>Blinking</Description>
+ </item>
+ <item>
+ <value>1110</value>
+ <Description>Flickering</Description>
+ </item>
+ <item>
+ <value>1111</value>
+ <Description>On</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>4</Range>
+ <Description>Enable RUN LED Override</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>8-11</Range>
+ <Description>ERR LED Code</Description>
+ <Enum>
+ <item>
+ <value>0000</value>
+ <Description>Off</Description>
+ </item>
+ <item>
+ <value>0001</value>
+ <Description>Flash 1x</Description>
+ </item>
+ <item>
+ <value>0010</value>
+ <Description>Flash 2x</Description>
+ </item>
+ <item>
+ <value>0011</value>
+ <Description>Flash 3x</Description>
+ </item>
+ <item>
+ <value>0100</value>
+ <Description>Flash 4x</Description>
+ </item>
+ <item>
+ <value>0101</value>
+ <Description>Flash 5x</Description>
+ </item>
+ <item>
+ <value>0110</value>
+ <Description>Flash 6x</Description>
+ </item>
+ <item>
+ <value>0111</value>
+ <Description>Flash 7x</Description>
+ </item>
+ <item>
+ <value>1000</value>
+ <Description>Flash 8x</Description>
+ </item>
+ <item>
+ <value>1001</value>
+ <Description>Flash 9x</Description>
+ </item>
+ <item>
+ <value>1010</value>
+ <Description>Flash 10x</Description>
+ </item>
+ <item>
+ <value>1011</value>
+ <Description>Flash 11x</Description>
+ </item>
+ <item>
+ <value>1100</value>
+ <Description>Flash 12x</Description>
+ </item>
+ <item>
+ <value>1101</value>
+ <Description>Blinking</Description>
+ </item>
+ <item>
+ <value>1110</value>
+ <Description>Flickering</Description>
+ </item>
+ <item>
+ <value>1111</value>
+ <Description>On</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>12</Range>
+ <Description>Enable ERR LED Override</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--PDI/ESC Configuration-->
+ <Register>
+ <Index>0140</Index>
+ <Description>PDI Ctrl</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>PDI</Description>
+ <Enum>
+ <item>
+ <value>00000000</value>
+ <Description>none</Description>
+ </item>
+ <item>
+ <value>00000001</value>
+ <Description>4 Digital Input</Description>
+ </item>
+ <item>
+ <value>00000010</value>
+ <Description>4 Digital Output</Description>
+ </item>
+ <item>
+ <value>00000011</value>
+ <Description>2 DI and 2 DO</Description>
+ </item>
+ <item>
+ <value>00000100</value>
+ <Description>Digital I/O</Description>
+ </item>
+ <item>
+ <value>00000101</value>
+ <Description>SPI Slave</Description>
+ </item>
+ <item>
+ <value>00000110</value>
+ <Description>Oversampling I/O</Description>
+ </item>
+ <item>
+ <value>00000111</value>
+ <Description>EtherCAT Bridge (port3)</Description>
+ </item>
+ <item>
+ <value>00001000</value>
+ <Description>uC async. 16bit</Description>
+ </item>
+ <item>
+ <value>00001001</value>
+ <Description>uC async. 8bit</Description>
+ </item>
+ <item>
+ <value>00001010</value>
+ <Description>uC sync. 16bit</Description>
+ </item>
+ <item>
+ <value>00001011</value>
+ <Description>uC sync. 8bit</Description>
+ </item>
+ <item>
+ <value>00010000</value>
+ <Description>32 Digital Input and 0 Digital Output</Description>
+ </item>
+ <item>
+ <value>00010001</value>
+ <Description>24 Digital Input and 8 Digital Output</Description>
+ </item>
+ <item>
+ <value>00010010</value>
+ <Description>16 Digital Input and 16 Digital Output</Description>
+ </item>
+ <item>
+ <value>00010011</value>
+ <Description>8 Digital Input and 24 Digital Output</Description>
+ </item>
+ <item>
+ <value>00010100</value>
+ <Description>0 Digital Input and 32 Digital Output</Description>
+ </item>
+ <item>
+ <value>11111111</value>
+ <Description>On-chip bus</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Device emulation</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Enhanced link detection all ports</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>DC SYNC Out Unit</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>DC Latch In Unit</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>Enhanced link port 0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Enhanced link port 1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>Enhanced link port 2</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>Enhanced link port 3</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>014e</Index>
+ <Description>PDI Information</Description>
+ <Details>
+ <Detail esc="04">
+ <Range>0</Range>
+ <Description>PDI register function ack. by write </Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>1</Range>
+ <Description>PDI configured</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>2</Range>
+ <Description>PDI Active</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>3</Range>
+ <Description>PDI config. invalid</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="04">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>OUTVALID polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active high</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active low</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>OUTVALID mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Output event signaling</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>WD_TRIG signaling</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>mode of direction</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Unidirectional</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Bidirectional</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Watchdog behavior</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Immediately output reset</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Wait output reset</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4-5</Range>
+ <Description>Input data is sampled at</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Start of Frame</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Rising edge of LATCH_IN</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>DC SYNC0 event</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>DC SYNC1 event</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6-7</Range>
+ <Description>Input data is sampled at</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>End of Frame</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>DC SYNC0 event</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>DC SYNC1 event</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="05">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>SPI mode</Description>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>SPI IRQ output driver</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push-Pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>SPI IRQ polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>SPI SEL polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Data output sample mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Normal</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Late</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>SYNC0 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>SYNC0 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>SYNC1 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>SYNC1 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="08">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>BUSY output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-Pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-Pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2-3</Range>
+ <Description>IRQ output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-Pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-Pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>BHE polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>RD polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>SYNC0 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>SYNC0 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>SYNC1 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>SYNC1 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="09">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>BUSY output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-Pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-Pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2-3</Range>
+ <Description>IRQ output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-Pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-Pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>BHE polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>RD polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>SYNC0 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>SYNC0 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>SYNC1 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>SYNC1 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="0a">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>TA output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open Source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2-3</Range>
+ <Description>IRQ output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open Source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>BHE polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>ADR(0) polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>Byte accessmode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>BHE or Byte select mode</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Transfer size mode</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>TS polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>SYNC0 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>SYNC0 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>SYNC1 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>SYNC1 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="0b">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>TA output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open Source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2-3</Range>
+ <Description>IRQ output driver/polarity</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Push-pull active low</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Open Drain (Active low)</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Push-pull active high</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Open Source (Active high)</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>BHE polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>ADR(0) polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>Byte accessmode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>BHE or Byte select mode</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Transfer size mode</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>TS polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>SYNC0 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>SYNC0 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>SYNC1 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>SYNC1 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="07">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Bridge port physical layer</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>MII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>SYNC0 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>SYNC0 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>SYNC1 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>SYNC1 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="ff">
+ <Index>0150</Index>
+ <Description>PDI Cfg</Description>
+ <Details>
+ <Detail>
+ <Range>0-6</Range>
+ <Description>Bus clock multiplication factor</Description>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>On-chip bus</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Altera Avalon</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Xilinx OPB</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>SYNC0 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>SYNC0 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>SYNC0 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Push pull</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Open</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>SYNC1 polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>SYNC1 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>SYNC1 to AL event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="04">
+ <Index>0152</Index>
+ <Description>PDI Cfg Ext</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Direction of I/O[1:0]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Direction of I/O[3:2]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Direction of I/O[5:4]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Direction of I/O[7:6]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Direction of I/O[9:8]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Direction of I/O[11:10]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>Direction of I/O[13:12]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>Direction of I/O[15:14]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Direction of I/O[17:16]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Direction of I/O[19:18]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>Direction of I/O[21:20]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>Direction of I/O[23:22]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>Direction of I/O[25:24]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Direction of I/O[27:26]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>Direction of I/O[29:28]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>Direction of I/O[31:30]</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Input</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Output</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="08">
+ <Index>0152</Index>
+ <Description>PDI Cfg Ext</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Read BUSY delay</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Normal read</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Delayed read</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="09">
+ <Index>0152</Index>
+ <Description>PDI Cfg Ext</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Read BUSY delay</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Normal read</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Delayed read</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="0a">
+ <Index>0152</Index>
+ <Description>PDI Cfg Ext</Description>
+ <Details>
+ <Detail>
+ <Range>8</Range>
+ <Description>Write data valid</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Oneclock cycle after CS</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Together with CS</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Read mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Use Byte Select</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Always read 16 bit</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>CS mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Sample with rising edge</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Sample with falling edge</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>TA/IRQ mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Update with rising edge</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Update with falling edge</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="0b">
+ <Index>0152</Index>
+ <Description>PDI Cfg Ext</Description>
+ <Details>
+ <Detail>
+ <Range>8</Range>
+ <Description>Write data valid</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Oneclock cycle after CS</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Together with CS</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Read mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Use Byte Select</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Always read 16 bit</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>CS mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Sample with rising edge</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Sample with falling edge</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>TA/IRQ mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Update with rising edge</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Update with falling edge</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="ff">
+ <Index>0152</Index>
+ <Description>PDI Cfg Ext</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>Data bus width</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>4Bytes</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>1Byte</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>2Bytes</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--Interrupts-->
+ <Register>
+ <Index>0200</Index>
+ <Description>ECAT IRQ Mask</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Latch event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>ESC Status event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>AL Status event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="0">
+ <Range>4</Range>
+ <Description>SM0 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="1">
+ <Range>5</Range>
+ <Description>SM1 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="2">
+ <Range>6</Range>
+ <Description>SM2 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="3">
+ <Range>7</Range>
+ <Description>SM3 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="4">
+ <Range>8</Range>
+ <Description>SM4 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="5">
+ <Range>9</Range>
+ <Description>SM5 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="6">
+ <Range>10</Range>
+ <Description>SM6 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="7">
+ <Range>11</Range>
+ <Description>SM7 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0204</Index>
+ <Description>PDI IRQ Mask L</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>AL Ctrl</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Latch input</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>SYNC 0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>SYNC 1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="02">
+ <Range>4</Range>
+ <Description>SM Changed</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>EEPROM command pending</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="0">
+ <Range>8</Range>
+ <Description>SM0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="1">
+ <Range>9</Range>
+ <Description>SM1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="2">
+ <Range>10</Range>
+ <Description>SM2</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="3">
+ <Range>11</Range>
+ <Description>SM3</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="4">
+ <Range>12</Range>
+ <Description>SM4</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="5">
+ <Range>13</Range>
+ <Description>SM5</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="6">
+ <Range>14</Range>
+ <Description>SM6</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="7">
+ <Range>15</Range>
+ <Description>SM7</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0206</Index>
+ <Description>PDI IRQ Mask H</Description>
+ <Details>
+ <Detail sm="8">
+ <Range>0</Range>
+ <Description>SM8</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="9">
+ <Range>1</Range>
+ <Description>SM9</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="10">
+ <Range>2</Range>
+ <Description>SM10</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="11">
+ <Range>3</Range>
+ <Description>SM11</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="12">
+ <Range>4</Range>
+ <Description>SM12</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="13">
+ <Range>5</Range>
+ <Description>SM13</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="14">
+ <Range>6</Range>
+ <Description>SM14</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="15">
+ <Range>7</Range>
+ <Description>SM15</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0210</Index>
+ <Description>ECAT IRQ</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Latch event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>ESC Status event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>AL Status event</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="0">
+ <Range>4</Range>
+ <Description>SM0 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="1">
+ <Range>5</Range>
+ <Description>SM1 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="2">
+ <Range>6</Range>
+ <Description>SM2 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="3">
+ <Range>7</Range>
+ <Description>SM3 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="4">
+ <Range>8</Range>
+ <Description>SM4 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="5">
+ <Range>9</Range>
+ <Description>SM5 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="6">
+ <Range>10</Range>
+ <Description>SM6 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="7">
+ <Range>11</Range>
+ <Description>SM7 IRQ</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0220</Index>
+ <Description>PDI IRQ 1</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>AL Ctrl</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Latch input</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>DC SYNC 0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>DC SYNC 1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>SM activation reg. changed</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>EEPROM command pending</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>Watchdog Process Data expired</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="0">
+ <Range>8</Range>
+ <Description>SM0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="1">
+ <Range>9</Range>
+ <Description>SM1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="2">
+ <Range>10</Range>
+ <Description>SM2</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="3">
+ <Range>11</Range>
+ <Description>SM3</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="4">
+ <Range>12</Range>
+ <Description>SM4</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="5">
+ <Range>13</Range>
+ <Description>SM5</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="6">
+ <Range>14</Range>
+ <Description>SM6</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="7">
+ <Range>15</Range>
+ <Description>SM7</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0222</Index>
+ <Description>PDI IRQ 2</Description>
+ <Details>
+ <Detail sm="8">
+ <Range>0</Range>
+ <Description>SM8</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="9">
+ <Range>1</Range>
+ <Description>SM9</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="10">
+ <Range>2</Range>
+ <Description>SM10</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="11">
+ <Range>3</Range>
+ <Description>SM11</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="12">
+ <Range>4</Range>
+ <Description>SM12</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="13">
+ <Range>5</Range>
+ <Description>SM13</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="14">
+ <Range>6</Range>
+ <Description>SM14</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail sm="15">
+ <Range>7</Range>
+ <Description>SM15</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--Error Counters-->
+ <Register>
+ <Index>0300</Index>
+ <Description>CRC A</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Invalid frame</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>RX error</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0302</Index>
+ <Description>CRC B</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Invalid frame</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>RX error</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0304</Index>
+ <Description>CRC C</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Invalid frame</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>RX error</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0306</Index>
+ <Description>CRC D</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Invalid frame</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>RX error</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0308</Index>
+ <Description>Forw. CRC A/B</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Port A</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>Port B</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>030a</Index>
+ <Description>Forw. CRC C/D</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Port C</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>Port D</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>030c</Index>
+ <Description>Proc. CRC/PDI Err</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Process unit error</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>PDI error</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="05">
+ <Index>030e</Index>
+ <Description>PDI Error Code</Description>
+ <Details>
+ <Detail>
+ <Range>0-2</Range>
+ <Description>Number of SPI CLK cycles of whole access</Description>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Busy violation during read access</Description>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Read termination missing</Description>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Access continued</Description>
+ </Detail>
+ <Detail>
+ <Range>6-7</Range>
+ <Description>SPI command</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="08" esc="04">
+ <Index>030e</Index>
+ <Description>PDI Error Code</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Busy violation during read access</Description>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Busy violation during write access</Description>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Addressing error for a read access</Description>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Addressing error for a write access</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="09" esc="04">
+ <Index>030e</Index>
+ <Description>PDI Error Code</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Busy violation during read access</Description>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Busy violation during write access</Description>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Addressing error for a read access</Description>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Addressing error for a write access</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="0a" esc="04">
+ <Index>030e</Index>
+ <Description>PDI Error Code</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Busy violation during read access</Description>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Busy violation during write access</Description>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Addressing error for a read access</Description>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Addressing error for a write access</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register pdi="0b" esc="04">
+ <Index>030e</Index>
+ <Description>PDI Error Code</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Busy violation during read access</Description>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Busy violation during write access</Description>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Addressing error for a read access</Description>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Addressing error for a write access</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0310</Index>
+ <Description>Link Lost A/B</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Port A</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>Port B</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0312</Index>
+ <Description>Link Lost C/D</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>Port C</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>Port D</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <!--Watchdogs-->
+ <Register>
+ <Index>0400</Index>
+ <Description>WD Divisor</Description>
+ </Register>
+ <Register>
+ <Index>0410</Index>
+ <Description>WD Time PDI</Description>
+ </Register>
+ <Register>
+ <Index>0420</Index>
+ <Description>WD Time SM</Description>
+ </Register>
+ <Register>
+ <Index>0440</Index>
+ <Description>WD Status</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>PD watchdog</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>expired</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>active or disabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0442</Index>
+ <Description>WD PDI/SM Counter</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>SM watchdog cnt</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>PDI watchdog cnt</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <!--SII EEPROM Interface-->
+ <Register>
+ <Index>0500</Index>
+ <Description>EEPROM Assign</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>EEPROM access ctrl</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>ECAT</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>PDI</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Reset PDIaccess</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Do not change Bit 501.0</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Reset Bit 501.0 to 0</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>EEPROM access status</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>ECAT</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>PDI</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0502</Index>
+ <Description>EEPROM Ctrl/Status</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Write access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>EEPROM emulation</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Normal operation</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>PDI emulates EEPROM</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>8 byte access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>2 byte address</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Read access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Write access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>Reload access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>CRC error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>Load error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Cmd error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>Write error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>Busy</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0504</Index>
+ <Description>EEPROM Address L</Description>
+ </Register>
+ <Register>
+ <Index>0506</Index>
+ <Description>EEPROM Address H</Description>
+ </Register>
+ <Register>
+ <Index>0508</Index>
+ <Description>EEPROM Data 0</Description>
+ </Register>
+ <Register>
+ <Index>050a</Index>
+ <Description>EEPROM Data 1</Description>
+ </Register>
+ <Register>
+ <Index>050c</Index>
+ <Description>EEPROM Data 2</Description>
+ </Register>
+ <Register>
+ <Index>050e</Index>
+ <Description>EEPROM Data 3</Description>
+ </Register>
+ <!--MII Management Interface-->
+ <Register>
+ <Index>0510</Index>
+ <Description>Phy MIO Ctrl/Status</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Write enable</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>PDI control possible</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Link detection active</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3-7</Range>
+ <Description>Phy address offset</Description>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Read access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Write access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Read error occured</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>Write error occured</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>Busy</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0512</Index>
+ <Description>Phy MIO Address</Description>
+ <Details>
+ <Detail>
+ <Range>0-4</Range>
+ <Description>Phy address</Description>
+ </Detail>
+ <Detail>
+ <Range>8-11</Range>
+ <Description>MIO address</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0514</Index>
+ <Description>Phy MIO Data</Description>
+ </Register>
+ <Register>
+ <Index>0516</Index>
+ <Description>MIO Access</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>ECAT claims exclusive access</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>PDI hasaccess to MII management</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Force PDI to reset 517.0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0518</Index>
+ <Description>MIO Port Status A/B</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Port A: Physical link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Port A: Link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Port A: Link status error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Port A: Read error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Port A: Link partner error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Port A: Phy config updated</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Port B: Physical link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Port B: Link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>Port B: Link status error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>Port B: Read error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>Port B: Link partner error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Port B: Phy config updated</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>051a</Index>
+ <Description>MIO Port Status C/D</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Port C: Physical link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Port C: Link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Port C: Link status eror</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Port C: Read error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Port C: Link partner error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Port C: Phy config updated</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Port D: Physical link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Port D: Link detected</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>Port D: Link status error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>Port D: Read error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>Port D: Link partner error</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Port D: Phy config updated</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--FMMU-->
+ <Register fmmu="0">
+ <Index>0600</Index>
+ <Description>F0 lStart L</Description>
+ </Register>
+ <Register fmmu="0">
+ <Index>0602</Index>
+ <Description>F0 lStart H</Description>
+ </Register>
+ <Register fmmu="0">
+ <Index>0604</Index>
+ <Description>F0 lLength</Description>
+ </Register>
+ <Register fmmu="0">
+ <Index>0606</Index>
+ <Description>F0 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="0">
+ <Index>0608</Index>
+ <Description>F0 pStart</Description>
+ </Register>
+ <Register fmmu="0">
+ <Index>060a</Index>
+ <Description>F0 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="0">
+ <Index>060c</Index>
+ <Description>F0 Enable</Description>
+ </Register>
+ <Register fmmu="1">
+ <Index>0610</Index>
+ <Description>F1 lStart L</Description>
+ </Register>
+ <Register fmmu="1">
+ <Index>0612</Index>
+ <Description>F1 lStart H</Description>
+ </Register>
+ <Register fmmu="1">
+ <Index>0614</Index>
+ <Description>F1 lLength</Description>
+ </Register>
+ <Register fmmu="1">
+ <Index>0616</Index>
+ <Description>F1 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="1">
+ <Index>0618</Index>
+ <Description>F1 pStart</Description>
+ </Register>
+ <Register fmmu="1">
+ <Index>061a</Index>
+ <Description>F01 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="1">
+ <Index>061c</Index>
+ <Description>F1 Enable</Description>
+ </Register>
+ <Register fmmu="2">
+ <Index>0620</Index>
+ <Description>F2 lStart L</Description>
+ </Register>
+ <Register fmmu="2">
+ <Index>0622</Index>
+ <Description>F2 lStart H</Description>
+ </Register>
+ <Register fmmu="2">
+ <Index>0624</Index>
+ <Description>F2 lLength</Description>
+ </Register>
+ <Register fmmu="2">
+ <Index>0626</Index>
+ <Description>F2 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="2">
+ <Index>0628</Index>
+ <Description>F2 pStart</Description>
+ </Register>
+ <Register fmmu="2">
+ <Index>062a</Index>
+ <Description>F2 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="2">
+ <Index>062c</Index>
+ <Description>F2 Enable</Description>
+ </Register>
+ <Register fmmu="3">
+ <Index>0630</Index>
+ <Description>F3 lStart L</Description>
+ </Register>
+ <Register fmmu="3">
+ <Index>0632</Index>
+ <Description>F3 lStart H</Description>
+ </Register>
+ <Register fmmu="3">
+ <Index>0634</Index>
+ <Description>F3 lLength</Description>
+ </Register>
+ <Register fmmu="3">
+ <Index>0636</Index>
+ <Description>F3 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="3">
+ <Index>0638</Index>
+ <Description>F3 pStart</Description>
+ </Register>
+ <Register fmmu="3">
+ <Index>063a</Index>
+ <Description>F3 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="3">
+ <Index>063c</Index>
+ <Description>F3 Enable</Description>
+ </Register>
+ <Register fmmu="4">
+ <Index>0640</Index>
+ <Description>F4 lStart L</Description>
+ </Register>
+ <Register fmmu="4">
+ <Index>0642</Index>
+ <Description>F4 lStart H</Description>
+ </Register>
+ <Register fmmu="4">
+ <Index>0644</Index>
+ <Description>F4 lLength</Description>
+ </Register>
+ <Register fmmu="4">
+ <Index>0646</Index>
+ <Description>F4 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="4">
+ <Index>0648</Index>
+ <Description>F4 pStart</Description>
+ </Register>
+ <Register fmmu="4">
+ <Index>064a</Index>
+ <Description>F4 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="4">
+ <Index>064c</Index>
+ <Description>F4 Enable</Description>
+ </Register>
+ <Register fmmu="5">
+ <Index>0650</Index>
+ <Description>F5 lStart L</Description>
+ </Register>
+ <Register fmmu="5">
+ <Index>0652</Index>
+ <Description>F5 lStart H</Description>
+ </Register>
+ <Register fmmu="5">
+ <Index>0654</Index>
+ <Description>F5 lLength</Description>
+ </Register>
+ <Register fmmu="5">
+ <Index>0656</Index>
+ <Description>F5 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="5">
+ <Index>0658</Index>
+ <Description>F5 pStart</Description>
+ </Register>
+ <Register fmmu="5">
+ <Index>065a</Index>
+ <Description>F5 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="5">
+ <Index>065c</Index>
+ <Description>F5 Enable</Description>
+ </Register>
+ <Register fmmu="6">
+ <Index>0660</Index>
+ <Description>F6 lStart L</Description>
+ </Register>
+ <Register fmmu="6">
+ <Index>0662</Index>
+ <Description>F6 lStart H</Description>
+ </Register>
+ <Register fmmu="6">
+ <Index>0664</Index>
+ <Description>F6 lLength</Description>
+ </Register>
+ <Register fmmu="6">
+ <Index>0666</Index>
+ <Description>F6 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="6">
+ <Index>0668</Index>
+ <Description>F6 pStart</Description>
+ </Register>
+ <Register fmmu="6">
+ <Index>066a</Index>
+ <Description>F6 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="6">
+ <Index>066c</Index>
+ <Description>F6 Enable</Description>
+ </Register>
+ <Register fmmu="7">
+ <Index>0670</Index>
+ <Description>F7 lStart L</Description>
+ </Register>
+ <Register fmmu="7">
+ <Index>0672</Index>
+ <Description>F7 lStart H</Description>
+ </Register>
+ <Register fmmu="7">
+ <Index>0674</Index>
+ <Description>F7 lLength</Description>
+ </Register>
+ <Register fmmu="7">
+ <Index>0676</Index>
+ <Description>F7 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="7">
+ <Index>0678</Index>
+ <Description>F7 pStart</Description>
+ </Register>
+ <Register fmmu="7">
+ <Index>067a</Index>
+ <Description>F7 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="7">
+ <Index>067c</Index>
+ <Description>F7 Enable</Description>
+ </Register>
+ <Register fmmu="8">
+ <Index>0680</Index>
+ <Description>F8 lStart L</Description>
+ </Register>
+ <Register fmmu="8">
+ <Index>0682</Index>
+ <Description>F8 lStart H</Description>
+ </Register>
+ <Register fmmu="8">
+ <Index>0684</Index>
+ <Description>F8 lLength</Description>
+ </Register>
+ <Register fmmu="8">
+ <Index>0686</Index>
+ <Description>F8 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="8">
+ <Index>0688</Index>
+ <Description>F8 pStart</Description>
+ </Register>
+ <Register fmmu="8">
+ <Index>068a</Index>
+ <Description>F8 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="8">
+ <Index>068c</Index>
+ <Description>F8 Enable</Description>
+ </Register>
+ <Register fmmu="9">
+ <Index>0690</Index>
+ <Description>F9 lStart L</Description>
+ </Register>
+ <Register fmmu="9">
+ <Index>0692</Index>
+ <Description>F9 lStart H</Description>
+ </Register>
+ <Register fmmu="9">
+ <Index>0694</Index>
+ <Description>F9 lLength</Description>
+ </Register>
+ <Register fmmu="9">
+ <Index>0696</Index>
+ <Description>F9 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="9">
+ <Index>0698</Index>
+ <Description>F9 pStart</Description>
+ </Register>
+ <Register fmmu="9">
+ <Index>069a</Index>
+ <Description>F9 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="9">
+ <Index>069c</Index>
+ <Description>F9 Enable</Description>
+ </Register>
+ <Register fmmu="10">
+ <Index>06a0</Index>
+ <Description>F10 lStart L</Description>
+ </Register>
+ <Register fmmu="10">
+ <Index>06a2</Index>
+ <Description>F10 lStart H</Description>
+ </Register>
+ <Register fmmu="10">
+ <Index>06a4</Index>
+ <Description>F10 lLength</Description>
+ </Register>
+ <Register fmmu="10">
+ <Index>06a6</Index>
+ <Description>F10 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="10">
+ <Index>06a8</Index>
+ <Description>F10 pStart</Description>
+ </Register>
+ <Register fmmu="10">
+ <Index>06aa</Index>
+ <Description>F10 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="10">
+ <Index>06ac</Index>
+ <Description>F10 Enable</Description>
+ </Register>
+ <Register fmmu="11">
+ <Index>06b0</Index>
+ <Description>F11 lStart L</Description>
+ </Register>
+ <Register fmmu="11">
+ <Index>06b2</Index>
+ <Description>F11 lStart H</Description>
+ </Register>
+ <Register fmmu="11">
+ <Index>06b4</Index>
+ <Description>F11 lLength</Description>
+ </Register>
+ <Register fmmu="11">
+ <Index>06b6</Index>
+ <Description>F11 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="11">
+ <Index>06b8</Index>
+ <Description>F11 pStart</Description>
+ </Register>
+ <Register fmmu="11">
+ <Index>06ba</Index>
+ <Description>F11 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="11">
+ <Index>06bc</Index>
+ <Description>F11 Enable</Description>
+ </Register>
+ <Register fmmu="12">
+ <Index>06c0</Index>
+ <Description>F12 lStart L</Description>
+ </Register>
+ <Register fmmu="12">
+ <Index>06c2</Index>
+ <Description>F12 lStart H</Description>
+ </Register>
+ <Register fmmu="12">
+ <Index>06c4</Index>
+ <Description>F12 lLength</Description>
+ </Register>
+ <Register fmmu="12">
+ <Index>06c6</Index>
+ <Description>F12 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="12">
+ <Index>06c8</Index>
+ <Description>F12 pStart</Description>
+ </Register>
+ <Register fmmu="12">
+ <Index>06ca</Index>
+ <Description>F12 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="12">
+ <Index>06cc</Index>
+ <Description>F12 Enable</Description>
+ </Register>
+ <Register fmmu="13">
+ <Index>06d0</Index>
+ <Description>F13 lStart L</Description>
+ </Register>
+ <Register fmmu="13">
+ <Index>06d2</Index>
+ <Description>F13 lStart H</Description>
+ </Register>
+ <Register fmmu="13">
+ <Index>06d4</Index>
+ <Description>F13 lLength</Description>
+ </Register>
+ <Register fmmu="13">
+ <Index>06d6</Index>
+ <Description>F13 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="13">
+ <Index>06d8</Index>
+ <Description>F13 pStart</Description>
+ </Register>
+ <Register fmmu="13">
+ <Index>06da</Index>
+ <Description>F13 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="13">
+ <Index>06dc</Index>
+ <Description>F13 Enable</Description>
+ </Register>
+ <Register fmmu="14">
+ <Index>06e0</Index>
+ <Description>F14 lStart L</Description>
+ </Register>
+ <Register fmmu="14">
+ <Index>06e2</Index>
+ <Description>F14 lStart H</Description>
+ </Register>
+ <Register fmmu="14">
+ <Index>06e4</Index>
+ <Description>F14 lLength</Description>
+ </Register>
+ <Register fmmu="14">
+ <Index>06e6</Index>
+ <Description>F14 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="14">
+ <Index>06e8</Index>
+ <Description>F14 pStart</Description>
+ </Register>
+ <Register fmmu="14">
+ <Index>06ea</Index>
+ <Description>F14 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="14">
+ <Index>06ec</Index>
+ <Description>F14 Enable</Description>
+ </Register>
+ <Register fmmu="15">
+ <Index>06f0</Index>
+ <Description>F15 lStart L</Description>
+ </Register>
+ <Register fmmu="15">
+ <Index>06f2</Index>
+ <Description>F15 lStart H</Description>
+ </Register>
+ <Register fmmu="15">
+ <Index>06f4</Index>
+ <Description>F15 lLength</Description>
+ </Register>
+ <Register fmmu="15">
+ <Index>06f6</Index>
+ <Description>F15 lStartEndBit</Description>
+ </Register>
+ <Register fmmu="15">
+ <Index>06f8</Index>
+ <Description>F15 pStart</Description>
+ </Register>
+ <Register fmmu="15">
+ <Index>06fa</Index>
+ <Description>F15 pStartBit/Dir</Description>
+ </Register>
+ <Register fmmu="15">
+ <Index>06fc</Index>
+ <Description>F15 Enable</Description>
+ </Register>
+ <!--SyncManager-->
+ <Register sm="0">
+ <Index>0800</Index>
+ <Description>SM0 Start</Description>
+ </Register>
+ <Register sm="0">
+ <Index>0802</Index>
+ <Description>SM0 Length</Description>
+ </Register>
+ <Register sm="0">
+ <Index>0804</Index>
+ <Description>SM0 Ctrl/Status</Description>
+ </Register>
+ <Register sm="0">
+ <Index>0806</Index>
+ <Description>SM0 Enable</Description>
+ </Register>
+ <Register sm="1">
+ <Index>0808</Index>
+ <Description>SM1 Start</Description>
+ </Register>
+ <Register sm="1">
+ <Index>080a</Index>
+ <Description>SM1 Length</Description>
+ </Register>
+ <Register sm="1">
+ <Index>080c</Index>
+ <Description>SM1 Ctrl/Status</Description>
+ </Register>
+ <Register sm="1">
+ <Index>080e</Index>
+ <Description>SM1 Enable</Description>
+ </Register>
+ <Register sm="2">
+ <Index>0810</Index>
+ <Description>SM2 Start</Description>
+ </Register>
+ <Register sm="2">
+ <Index>0812</Index>
+ <Description>SM2 Length</Description>
+ </Register>
+ <Register sm="2">
+ <Index>0814</Index>
+ <Description>SM2 Ctrl/Status</Description>
+ </Register>
+ <Register sm="2">
+ <Index>0816</Index>
+ <Description>SM2 Enable</Description>
+ </Register>
+ <Register sm="3">
+ <Index>0818</Index>
+ <Description>SM3 Start</Description>
+ </Register>
+ <Register sm="3">
+ <Index>081a</Index>
+ <Description>SM3 Length</Description>
+ </Register>
+ <Register sm="3">
+ <Index>081c</Index>
+ <Description>SM3 Ctrl/Status</Description>
+ </Register>
+ <Register sm="3">
+ <Index>081e</Index>
+ <Description>SM3 Enable</Description>
+ </Register>
+ <Register sm="4">
+ <Index>0820</Index>
+ <Description>SM4 Start</Description>
+ </Register>
+ <Register sm="4">
+ <Index>0822</Index>
+ <Description>SM4 Length</Description>
+ </Register>
+ <Register sm="4">
+ <Index>0824</Index>
+ <Description>SM4 Ctrl/Status</Description>
+ </Register>
+ <Register sm="4">
+ <Index>0826</Index>
+ <Description>SM4 Enable</Description>
+ </Register>
+ <Register sm="5">
+ <Index>0828</Index>
+ <Description>SM5 Start</Description>
+ </Register>
+ <Register sm="5">
+ <Index>082a</Index>
+ <Description>SM5 Length</Description>
+ </Register>
+ <Register sm="5">
+ <Index>082c</Index>
+ <Description>SM5 Ctrl/Status</Description>
+ </Register>
+ <Register sm="5">
+ <Index>082e</Index>
+ <Description>SM5 Enable</Description>
+ </Register>
+ <Register sm="6">
+ <Index>0830</Index>
+ <Description>SM6 Start</Description>
+ </Register>
+ <Register sm="6">
+ <Index>0832</Index>
+ <Description>SM6 Length</Description>
+ </Register>
+ <Register sm="6">
+ <Index>0834</Index>
+ <Description>SM6 Ctrl/Status</Description>
+ </Register>
+ <Register sm="6">
+ <Index>0836</Index>
+ <Description>SM6 Enable</Description>
+ </Register>
+ <Register sm="7">
+ <Index>0838</Index>
+ <Description>SM7 Start</Description>
+ </Register>
+ <Register sm="7">
+ <Index>083a</Index>
+ <Description>SM7 Length</Description>
+ </Register>
+ <Register sm="7">
+ <Index>083c</Index>
+ <Description>SM7 Ctrl/Status</Description>
+ </Register>
+ <Register sm="7">
+ <Index>083e</Index>
+ <Description>SM7 Enable</Description>
+ </Register>
+ <Register sm="8">
+ <Index>0840</Index>
+ <Description>SM8 Start</Description>
+ </Register>
+ <Register sm="8">
+ <Index>0842</Index>
+ <Description>SM8 Length</Description>
+ </Register>
+ <Register sm="8">
+ <Index>0844</Index>
+ <Description>SM8 Ctrl/Status</Description>
+ </Register>
+ <Register sm="8">
+ <Index>0846</Index>
+ <Description>SM8 Enable</Description>
+ </Register>
+ <Register sm="9">
+ <Index>0848</Index>
+ <Description>SM9 Start</Description>
+ </Register>
+ <Register sm="9">
+ <Index>084a</Index>
+ <Description>SM9 Length</Description>
+ </Register>
+ <Register sm="9">
+ <Index>084c</Index>
+ <Description>SM9 Ctrl/Status</Description>
+ </Register>
+ <Register sm="9">
+ <Index>084e</Index>
+ <Description>SM9 Enable</Description>
+ </Register>
+ <Register sm="10">
+ <Index>0850</Index>
+ <Description>SM10 Start</Description>
+ </Register>
+ <Register sm="10">
+ <Index>0852</Index>
+ <Description>SM10 Length</Description>
+ </Register>
+ <Register sm="10">
+ <Index>0854</Index>
+ <Description>SM10 Ctrl/Status</Description>
+ </Register>
+ <Register sm="10">
+ <Index>0856</Index>
+ <Description>SM10 Enable</Description>
+ </Register>
+ <Register sm="11">
+ <Index>0858</Index>
+ <Description>SM11 Start</Description>
+ </Register>
+ <Register sm="11">
+ <Index>085a</Index>
+ <Description>SM11 Length</Description>
+ </Register>
+ <Register sm="11">
+ <Index>085c</Index>
+ <Description>SM11 Ctrl/Status</Description>
+ </Register>
+ <Register sm="11">
+ <Index>085e</Index>
+ <Description>SM11 Enable</Description>
+ </Register>
+ <Register sm="12">
+ <Index>0860</Index>
+ <Description>SM12 Start</Description>
+ </Register>
+ <Register sm="12">
+ <Index>0862</Index>
+ <Description>SM12 Length</Description>
+ </Register>
+ <Register sm="12">
+ <Index>0864</Index>
+ <Description>SM12 Ctrl/Status</Description>
+ </Register>
+ <Register sm="12">
+ <Index>0866</Index>
+ <Description>SM12 Enable</Description>
+ </Register>
+ <Register sm="13">
+ <Index>0868</Index>
+ <Description>SM13 Start</Description>
+ </Register>
+ <Register sm="13">
+ <Index>086a</Index>
+ <Description>SM13 Length</Description>
+ </Register>
+ <Register sm="13">
+ <Index>086c</Index>
+ <Description>SM13 Ctrl/Status</Description>
+ </Register>
+ <Register sm="13">
+ <Index>086e</Index>
+ <Description>SM13 Enable</Description>
+ </Register>
+ <Register sm="14">
+ <Index>0870</Index>
+ <Description>SM14 Start</Description>
+ </Register>
+ <Register sm="14">
+ <Index>0872</Index>
+ <Description>SM14 Length</Description>
+ </Register>
+ <Register sm="14">
+ <Index>0874</Index>
+ <Description>SM14 Ctrl/Status</Description>
+ </Register>
+ <Register sm="14">
+ <Index>0876</Index>
+ <Description>SM14 Enable</Description>
+ </Register>
+ <Register sm="15">
+ <Index>0878</Index>
+ <Description>SM15 Start</Description>
+ </Register>
+ <Register sm="15">
+ <Index>087a</Index>
+ <Description>SM15 Length</Description>
+ </Register>
+ <Register sm="15">
+ <Index>087c</Index>
+ <Description>SM15 Ctrl/Status</Description>
+ </Register>
+ <Register sm="15">
+ <Index>087e</Index>
+ <Description>SM15 Enable</Description>
+ </Register>
+ <!--DC - Receive Times-->
+ <Register>
+ <Index>0900</Index>
+ <Description>DC RecvTimeL_A</Description>
+ </Register>
+ <Register>
+ <Index>0902</Index>
+ <Description>DC RecvTimeH_A</Description>
+ </Register>
+ <Register>
+ <Index>0904</Index>
+ <Description>DC RecvTimeL_B</Description>
+ </Register>
+ <Register>
+ <Index>0906</Index>
+ <Description>DC RecvTimeH_B</Description>
+ </Register>
+ <Register>
+ <Index>0908</Index>
+ <Description>DC RecvTimeL_C</Description>
+ </Register>
+ <Register>
+ <Index>090a</Index>
+ <Description>DC RecvTimeH_C</Description>
+ </Register>
+ <Register>
+ <Index>090c</Index>
+ <Description>DC RecvTimeL_D</Description>
+ </Register>
+ <Register>
+ <Index>090e</Index>
+ <Description>DC RecvTimeH_D</Description>
+ </Register>
+ <!--DC - Time Loop Control Unit-->
+ <Register>
+ <Index>0910</Index>
+ <Description>DC SysTimeLL</Description>
+ </Register>
+ <Register>
+ <Index>0912</Index>
+ <Description>DC SysTimeLH</Description>
+ </Register>
+ <Register>
+ <Index>0914</Index>
+ <Description>DC SysTimeHL</Description>
+ </Register>
+ <Register>
+ <Index>0916</Index>
+ <Description>DC SysTimeHH</Description>
+ </Register>
+ <Register>
+ <Index>0918</Index>
+ <Description>DC RecvTimeLL_A</Description>
+ </Register>
+ <Register>
+ <Index>091a</Index>
+ <Description>DC RecvTimeLH_A</Description>
+ </Register>
+ <Register>
+ <Index>091c</Index>
+ <Description>DC RecvTimeHL_A</Description>
+ </Register>
+ <Register>
+ <Index>091e</Index>
+ <Description>DC RecvTimeHH_A</Description>
+ </Register>
+ <Register>
+ <Index>0920</Index>
+ <Description>DC SysTimeOffsLL</Description>
+ </Register>
+ <Register>
+ <Index>0922</Index>
+ <Description>DC SysTimeOffsLH</Description>
+ </Register>
+ <Register>
+ <Index>0924</Index>
+ <Description>DC SysTimeOffsHL</Description>
+ </Register>
+ <Register>
+ <Index>0926</Index>
+ <Description>DC SysTimeOffsHH
+</Description>
+ </Register>
+ <Register>
+ <Index>0928</Index>
+ <Description>DC SysTimeDelayL</Description>
+ </Register>
+ <Register>
+ <Index>092a</Index>
+ <Description>DC SysTimeDelayH</Description>
+ </Register>
+ <Register>
+ <Index>092c</Index>
+ <Description>DC CtrlErrorL</Description>
+ </Register>
+ <Register>
+ <Index>092e</Index>
+ <Description>DC CtrlErrorH</Description>
+ </Register>
+ <Register>
+ <Index>0930</Index>
+ <Description>DC SpeedStart</Description>
+ </Register>
+ <Register>
+ <Index>0932</Index>
+ <Description>DC SpeedDiff</Description>
+ </Register>
+ <Register>
+ <Index>0934</Index>
+ <Description>DC FiltExp</Description>
+ <Details>
+ <Detail>
+ <Range>0-7</Range>
+ <Description>System time diff</Description>
+ </Detail>
+ <Detail>
+ <Range>8-15</Range>
+ <Description>Speed counter</Description>
+ </Detail>
+ </Details>
+ </Register>
+ <Register esc="02">
+ <Index>0936</Index>
+ <Description>Receive Time Latch Mode</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Receive Time Latch Mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Forwarding mode</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Reverse mode</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register esc="12">
+ <Index>0936</Index>
+ <Description>Receive Time Latch Mode</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Receive Time Latch Mode</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Forwarding mode</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Reverse mode</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--DC - Cyclic Unit Control / SYNC Out Unit-->
+ <Register>
+ <Index>0980</Index>
+ <Description>DC Assign/Active</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Write access cyclic</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>ECAT</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>PDI</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Write access Latch 0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>ECAT</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>PDI</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Write access Latch 1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>ECAT</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>PDI</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Sync out unit activation</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Deactivated</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Activated</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Generate SYNC 0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>Generate SYNC 1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>Auto activation</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>Start time extension 32-&gt;64</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Start time check</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>Half range</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>15</Range>
+ <Description>Debuspulse</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0982</Index>
+ <Description>DC CycImpulse</Description>
+ </Register>
+ <Register>
+ <Index>0984</Index>
+ <Description>DC Activation Status</Description>
+ <Details>
+ <Detail esc="04">
+ <Range>0</Range>
+ <Description>SYNC0 pending</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>1</Range>
+ <Description>SYNC1 pending</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail esc="04">
+ <Range>2</Range>
+ <Description>Start Time</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Within near future</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Out of near future</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>098e</Index>
+ <Description>DC CycSync State</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>SYNC 0 triggered</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>SYNC 1 triggered</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>0990</Index>
+ <Description>DC StartTime0 LL</Description>
+ </Register>
+ <Register>
+ <Index>0992</Index>
+ <Description>DC StartTime0 LH</Description>
+ </Register>
+ <Register>
+ <Index>0994</Index>
+ <Description>DC StartTime0 HL</Description>
+ </Register>
+ <Register>
+ <Index>0996</Index>
+ <Description>DC StartTime0 HH</Description>
+ </Register>
+ <Register>
+ <Index>0998</Index>
+ <Description>DC StartTime1 LL</Description>
+ </Register>
+ <Register>
+ <Index>099a</Index>
+ <Description>DC StartTime1 LH</Description>
+ </Register>
+ <Register>
+ <Index>099c</Index>
+ <Description>DC StartTime1 HL</Description>
+ </Register>
+ <Register>
+ <Index>099e</Index>
+ <Description>DC StartTime1 HH</Description>
+ </Register>
+ <Register>
+ <Index>09a0</Index>
+ <Description>DC CycTime0 L</Description>
+ </Register>
+ <Register>
+ <Index>09a2</Index>
+ <Description>DC CycTime0 H</Description>
+ </Register>
+ <Register>
+ <Index>09a4</Index>
+ <Description>DC CycTime1 L</Description>
+ </Register>
+ <Register>
+ <Index>09a6</Index>
+ <Description>DC CycTime1 H</Description>
+ </Register>
+ <!--DC - Latch In Unit-->
+ <Register>
+ <Index>09a8</Index>
+ <Description>DC Latch Ctrl</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Latch 0 pos</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Continuous</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Single event</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Latch 0 neg</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Continuous</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Single event</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Latch 1 pos</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Continuous</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Single event</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Latch 1 neg</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Continuous</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Single event</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>09ae</Index>
+ <Description>DC Latch Status</Description>
+ <Details>
+ <Detail>
+ <Range>0</Range>
+ <Description>Event Latch 0 pos</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>1</Range>
+ <Description>Event Latch 0 neg</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Latch 0 pin state</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8</Range>
+ <Description>Event Latch 1 pos</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>9</Range>
+ <Description>Event Latch 1 neg</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>Latch 1 pin state</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>FALSE</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>TRUE</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register>
+ <Index>09b0</Index>
+ <Description>DC Latch0 Pos LL</Description>
+ </Register>
+ <Register>
+ <Index>09b2</Index>
+ <Description>DC Latch0 Pos LH</Description>
+ </Register>
+ <Register>
+ <Index>09b4</Index>
+ <Description>DC Latch0 Pos HL</Description>
+ </Register>
+ <Register>
+ <Index>09b6</Index>
+ <Description>DC Latch0 Pos HH</Description>
+ </Register>
+ <Register>
+ <Index>09b8</Index>
+ <Description>DC Latch0 Neg LL</Description>
+ </Register>
+ <Register>
+ <Index>09ba</Index>
+ <Description>DC Latch0 Neg LH</Description>
+ </Register>
+ <Register>
+ <Index>09bc</Index>
+ <Description>DC Latch0 Neg HL</Description>
+ </Register>
+ <Register>
+ <Index>09be</Index>
+ <Description>DC Latch0 Neg HH</Description>
+ </Register>
+ <Register>
+ <Index>09c0</Index>
+ <Description>DC Latch1 Pos LL</Description>
+ </Register>
+ <Register>
+ <Index>09c2</Index>
+ <Description>DC Latch1 Pos LH</Description>
+ </Register>
+ <Register>
+ <Index>09c4</Index>
+ <Description>DC Latch1 Pos HL</Description>
+ </Register>
+ <Register>
+ <Index>09c6</Index>
+ <Description>DC Latch1 Pos HH</Description>
+ </Register>
+ <Register>
+ <Index>09c8</Index>
+ <Description>DC Latch1 Neg LL</Description>
+ </Register>
+ <Register>
+ <Index>09ca</Index>
+ <Description>DC Latch1 Neg LH</Description>
+ </Register>
+ <Register>
+ <Index>09cc</Index>
+ <Description>DC Latch1 Neg HL</Description>
+ </Register>
+ <Register>
+ <Index>09ce</Index>
+ <Description>DC Latch1 Neg HH</Description>
+ </Register>
+ <!--DC - SyncManager Event Times-->
+ <Register>
+ <Index>09f0</Index>
+ <Description>DC RecvSMChange L</Description>
+ </Register>
+ <Register>
+ <Index>09f2</Index>
+ <Description>DC RecvSMChange H</Description>
+ </Register>
+ <Register>
+ <Index>09f8</Index>
+ <Description>DC PDISMStart L</Description>
+ </Register>
+ <Register>
+ <Index>09fa</Index>
+ <Description>DC PDISMStart H</Description>
+ </Register>
+ <Register>
+ <Index>09fc</Index>
+ <Description>DC PDISMChange L</Description>
+ </Register>
+ <Register>
+ <Index>09fe</Index>
+ <Description>DC PDISMChange H</Description>
+ </Register>
+ <!--ESC specific-->
+ <Register esc="04">
+ <Index>0e00</Index>
+ <Description>Product ID</Description>
+ </Register>
+ <Register esc="04">
+ <Index>0e02</Index>
+ <Description>Product ID</Description>
+ </Register>
+ <Register esc="04">
+ <Index>0e04</Index>
+ <Description>Product ID
+</Description>
+ </Register>
+ <Register esc="04">
+ <Index>0e06</Index>
+ <Description>Product ID</Description>
+ </Register>
+ <Register esc="04">
+ <Index>0e08</Index>
+ <Description>Vendor ID
+</Description>
+ </Register>
+ <Register esc="04">
+ <Index>0e0a</Index>
+ <Description>Vendor ID</Description>
+ </Register>
+ <Register esc="04">
+ <Index>0e0c</Index>
+ <Description>Vendor ID</Description>
+ </Register>
+ <Register esc="04">
+ <Index>0e0e</Index>
+ <Description>Vendor ID</Description>
+ </Register>
+ <Register esc="11">
+ <Index>0e00</Index>
+ <Description>Power On</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>Port mode</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Port 0, 1</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>Port 0, 1, 2</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Port 0, 1, 3</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Port 0, 1, 2, 3</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2</Range>
+ <Description>Logical port 0</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>MII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>3</Range>
+ <Description>Logical port 1</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>MII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4</Range>
+ <Description>Logical port 2</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>MII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>5</Range>
+ <Description>Logical port 3</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>EBUS</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>MII</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6-7</Range>
+ <Description>CPU clock output</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Off - PDI[7] available as PDI port</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>PDI[7]=25MHz</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>PDI[7]=20MHz</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>PDI[7]=10MHz</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>8-9</Range>
+ <Description>TX signal shift</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>MII TX shifted 0</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>MII TX shifted 90</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>MII TX shifted 180</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>MII TX shifted 270</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>10</Range>
+ <Description>Clock 25 output</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>11</Range>
+ <Description>Transparent mode MII</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>12</Range>
+ <Description>Digital Ctrl/Status move</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>PDI[39:32]</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>the highest available PDI Byte</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>13</Range>
+ <Description>Phy offset</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>No offset</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>16 offset</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>14</Range>
+ <Description>Phy link polarity</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Active low</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Active high</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <Register esc="12">
+ <Index>0e00</Index>
+ <Description>Power On</Description>
+ <Details>
+ <Detail>
+ <Range>0-1</Range>
+ <Description>Chip mode</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Port0:EBUS, Port1:EBUS, 18bit PDI</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>Port0:MII, Port1:EBUS, 8bit PDI</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>Port0:EBUS, Port1:MII, 8bit PDI</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>2-3</Range>
+ <Description>CPU clock output</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>Off - PDI[7] available as PDI port</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>PDI[7]=25MHz</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>PDI[7]=20MHz</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>PDI[7]=10MHz</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>4-5</Range>
+ <Description>TX signal shift</Description>
+ <Enum>
+ <item>
+ <value>00</value>
+ <Description>MII TX signals shifted by 0</Description>
+ </item>
+ <item>
+ <value>01</value>
+ <Description>MII TX signals shifted by 90</Description>
+ </item>
+ <item>
+ <value>10</value>
+ <Description>MII TX signals shifted by 180</Description>
+ </item>
+ <item>
+ <value>11</value>
+ <Description>MII TX signals shifted by 270</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>6</Range>
+ <Description>CLK25 Output Enable</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>Disabled</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>Enabled</Description>
+ </item>
+ </Enum>
+ </Detail>
+ <Detail>
+ <Range>7</Range>
+ <Description>Phy address offset</Description>
+ <Enum>
+ <item>
+ <value>0</value>
+ <Description>No offset</Description>
+ </item>
+ <item>
+ <value>1</value>
+ <Description>16 offset</Description>
+ </item>
+ </Enum>
+ </Detail>
+ </Details>
+ </Register>
+ <!--ESC specific I/O-->
+ <Register>
+ <Index>0f00</Index>
+ <Description>Digital Out L</Description>
+ </Register>
+ <Register>
+ <Index>0f02</Index>
+ <Description>Digital Out H</Description>
+ </Register>
+ <Register>
+ <Index>0f10</Index>
+ <Description>GPO LL</Description>
+ </Register>
+ <Register>
+ <Index>0f12</Index>
+ <Description>GPO LH</Description>
+ </Register>
+ <Register>
+ <Index>0f14</Index>
+ <Description>GPO HL</Description>
+ </Register>
+ <Register>
+ <Index>0f16</Index>
+ <Description>GPO HH</Description>
+ </Register>
+ <Register>
+ <Index>0f18</Index>
+ <Description>GPI LL</Description>
+ </Register>
+ <Register>
+ <Index>0f1a</Index>
+ <Description>GPI LH</Description>
+ </Register>
+ <Register>
+ <Index>0f1c</Index>
+ <Description>GPI HL</Description>
+ </Register>
+ <Register>
+ <Index>0f1e</Index>
+ <Description>GPI HH</Description>
+ </Register>
+ <!--User RAM-->
+ <Register>
+ <Index>0f80</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f82</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f84</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f86</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f88</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f8a</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f8c</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f8e</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f90</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f92</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f94</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f96</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f98</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f9a</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f9c</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0f9e</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fa0</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fa2</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fa4</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fa6</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fa8</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0faa</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fac</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fae</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fb0</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fb2</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fb4</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fb6</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fb8</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fba</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fbc</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fbe</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fc0</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fc2</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fc4</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fc6</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fc8</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fca</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fcc</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fce</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fd0</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fd2</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fd4</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fd6</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fd8</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fda</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fdc</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fde</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fe0</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fe2</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fe4</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fe6</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fe8</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fea</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fec</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0fee</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ff0</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ff2</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ff4</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ff6</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ff8</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ffa</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ffc</Index>
+ <Description>User Ram</Description>
+ </Register>
+ <Register>
+ <Index>0ffe</Index>
+ <Description>User Ram</Description>
+ </Register>
+</RegisterInfo>
\ No newline at end of file