Skip to content
Snippets Groups Projects
Commit 8a629c11 authored by Florian Pose's avatar Florian Pose
Browse files

'ethercat xml' creates <EtherCATInfoList> for more than one slave.

parent 4a91a023
No related branches found
No related tags found
No related merge requests found
...@@ -40,6 +40,8 @@ Changes since 1.4.0: ...@@ -40,6 +40,8 @@ Changes since 1.4.0:
an application transfer SDOs before activating the master. Thanks to Stefan an application transfer SDOs before activating the master. Thanks to Stefan
Weiser. Weiser.
* Changed EC_MAX_SII_SIZE to 4096. * Changed EC_MAX_SII_SIZE to 4096.
* 'ethercat xml' creates valid XML <EtherCATInfoList> for more than one slave
(thanks to E. Burgstaller).
Changes in 1.4.0: Changes in 1.4.0:
......
...@@ -82,8 +82,17 @@ void CommandXml::execute(MasterDevice &m, const StringVector &args) ...@@ -82,8 +82,17 @@ void CommandXml::execute(MasterDevice &m, const StringVector &args)
m.open(MasterDevice::Read); m.open(MasterDevice::Read);
slaves = selectedSlaves(m); slaves = selectedSlaves(m);
cout << "<?xml version=\"1.0\" ?>" << endl;
if (slaves.size() > 1) {
cout << "<EtherCATInfoList>" << endl;
}
for (si = slaves.begin(); si != slaves.end(); si++) { for (si = slaves.begin(); si != slaves.end(); si++) {
generateSlaveXml(m, *si); generateSlaveXml(m, *si, slaves.size() > 1 ? 1 : 0);
}
if (slaves.size() > 1) {
cout << "</EtherCATInfoList>" << endl;
} }
} }
...@@ -91,26 +100,30 @@ void CommandXml::execute(MasterDevice &m, const StringVector &args) ...@@ -91,26 +100,30 @@ void CommandXml::execute(MasterDevice &m, const StringVector &args)
void CommandXml::generateSlaveXml( void CommandXml::generateSlaveXml(
MasterDevice &m, MasterDevice &m,
const ec_ioctl_slave_t &slave const ec_ioctl_slave_t &slave,
unsigned int indent
) )
{ {
ec_ioctl_slave_sync_t sync; ec_ioctl_slave_sync_t sync;
ec_ioctl_slave_sync_pdo_t pdo; ec_ioctl_slave_sync_pdo_t pdo;
string pdoType; string pdoType, in;
ec_ioctl_slave_sync_pdo_entry_t entry; ec_ioctl_slave_sync_pdo_entry_t entry;
unsigned int i, j, k; unsigned int i, j, k;
for (i = 0; i < indent; i++) {
in += " ";
}
cout cout
<< "<?xml version=\"1.0\" ?>" << endl << in << "<EtherCATInfo>" << endl
<< " <EtherCATInfo>" << endl << in << " <!-- Slave " << slave.position << " -->" << endl
<< " <!-- Slave " << slave.position << " -->" << endl << in << " <Vendor>" << endl
<< " <Vendor>" << endl << in << " <Id>" << slave.vendor_id << "</Id>" << endl
<< " <Id>" << slave.vendor_id << "</Id>" << endl << in << " </Vendor>" << endl
<< " </Vendor>" << endl << in << " <Descriptions>" << endl
<< " <Descriptions>" << endl << in << " <Devices>" << endl
<< " <Devices>" << endl << in << " <Device>" << endl
<< " <Device>" << endl << in << " <Type ProductCode=\"#x"
<< " <Type ProductCode=\"#x"
<< hex << setfill('0') << setw(8) << slave.product_code << hex << setfill('0') << setw(8) << slave.product_code
<< "\" RevisionNo=\"#x" << "\" RevisionNo=\"#x"
<< hex << setfill('0') << setw(8) << slave.revision_number << hex << setfill('0') << setw(8) << slave.revision_number
...@@ -118,7 +131,7 @@ void CommandXml::generateSlaveXml( ...@@ -118,7 +131,7 @@ void CommandXml::generateSlaveXml(
if (strlen(slave.name)) { if (strlen(slave.name)) {
cout cout
<< " <Name><![CDATA[" << in << " <Name><![CDATA["
<< slave.name << slave.name
<< "]]></Name>" << endl; << "]]></Name>" << endl;
} }
...@@ -127,7 +140,7 @@ void CommandXml::generateSlaveXml( ...@@ -127,7 +140,7 @@ void CommandXml::generateSlaveXml(
m.getSync(&sync, slave.position, i); m.getSync(&sync, slave.position, i);
cout cout
<< " <Sm Enable=\"" << dec << (unsigned int) sync.enable << in << " <Sm Enable=\"" << dec << (unsigned int) sync.enable
<< "\" StartAddress=\"" << sync.physical_start_address << "\" StartAddress=\"" << sync.physical_start_address
<< "\" ControlByte=\"" << (unsigned int) sync.control_register << "\" ControlByte=\"" << (unsigned int) sync.control_register
<< "\" DefaultSize=\"" << sync.default_size << "\" DefaultSize=\"" << sync.default_size
...@@ -143,37 +156,37 @@ void CommandXml::generateSlaveXml( ...@@ -143,37 +156,37 @@ void CommandXml::generateSlaveXml(
pdoType += "xPdo"; // last 2 letters lowercase in XML! pdoType += "xPdo"; // last 2 letters lowercase in XML!
cout cout
<< " <" << pdoType << in << " <" << pdoType
<< " Sm=\"" << i << "\" Fixed=\"1\" Mandatory=\"1\">" << endl << " Sm=\"" << i << "\" Fixed=\"1\" Mandatory=\"1\">" << endl
<< " <Index>#x" << in << " <Index>#x"
<< hex << setfill('0') << setw(4) << pdo.index << hex << setfill('0') << setw(4) << pdo.index
<< "</Index>" << endl << "</Index>" << endl
<< " <Name>" << pdo.name << "</Name>" << endl; << in << " <Name>" << pdo.name << "</Name>" << endl;
for (k = 0; k < pdo.entry_count; k++) { for (k = 0; k < pdo.entry_count; k++) {
m.getPdoEntry(&entry, slave.position, i, j, k); m.getPdoEntry(&entry, slave.position, i, j, k);
cout cout
<< " <Entry>" << endl << in << " <Entry>" << endl
<< " <Index>#x" << in << " <Index>#x"
<< hex << setfill('0') << setw(4) << entry.index << hex << setfill('0') << setw(4) << entry.index
<< "</Index>" << endl; << "</Index>" << endl;
if (entry.index) if (entry.index)
cout cout
<< " <SubIndex>" << in << " <SubIndex>"
<< dec << (unsigned int) entry.subindex << dec << (unsigned int) entry.subindex
<< "</SubIndex>" << endl; << "</SubIndex>" << endl;
cout cout
<< " <BitLen>" << in << " <BitLen>"
<< dec << (unsigned int) entry.bit_length << dec << (unsigned int) entry.bit_length
<< "</BitLen>" << endl; << "</BitLen>" << endl;
if (entry.index) { if (entry.index) {
cout cout
<< " <Name>" << entry.name << in << " <Name>" << entry.name
<< "</Name>" << endl << "</Name>" << endl
<< " <DataType>"; << in << " <DataType>";
if (entry.bit_length == 1) { if (entry.bit_length == 1) {
cout << "BOOL"; cout << "BOOL";
...@@ -192,18 +205,19 @@ void CommandXml::generateSlaveXml( ...@@ -192,18 +205,19 @@ void CommandXml::generateSlaveXml(
cout << "</DataType>" << endl; cout << "</DataType>" << endl;
} }
cout << " </Entry>" << endl; cout << in << " </Entry>" << endl;
} }
cout cout
<< " </" << pdoType << ">" << endl; << in << " </" << pdoType << ">" << endl;
} }
} }
cout cout
<< " </Device>" << endl << in << " </Device>" << endl
<< " </Devices>" << endl << in << " </Devices>" << endl
<< " </Descriptions>" << endl << in << " </Descriptions>" << endl
<< "</EtherCATInfo>" << endl; << in << "</EtherCATInfo>" << endl;
} }
/*****************************************************************************/ /*****************************************************************************/
...@@ -44,7 +44,8 @@ class CommandXml: ...@@ -44,7 +44,8 @@ class CommandXml:
void execute(MasterDevice &, const StringVector &); void execute(MasterDevice &, const StringVector &);
protected: protected:
void generateSlaveXml(MasterDevice &, const ec_ioctl_slave_t &); void generateSlaveXml(MasterDevice &, const ec_ioctl_slave_t &,
unsigned int);
}; };
/****************************************************************************/ /****************************************************************************/
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment