author | Florian Pose <fp@igh-essen.com> |
Mon, 01 Mar 2010 18:39:06 +0100 | |
changeset 1832 | fb6a307daf31 |
parent 1826 | ec6223c3b7ec |
child 1869 | 14f634f5b613 |
permissions | -rw-r--r-- |
1142 | 1 |
/***************************************************************************** |
2 |
* |
|
1363
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
3 |
* $Id$ |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
4 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
5 |
* Copyright (C) 2006-2009 Florian Pose, Ingenieurgemeinschaft IgH |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
6 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
7 |
* This file is part of the IgH EtherCAT Master. |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
8 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
9 |
* The IgH EtherCAT Master is free software; you can redistribute it and/or |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
10 |
* modify it under the terms of the GNU General Public License version 2, as |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
11 |
* published by the Free Software Foundation. |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
12 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
13 |
* The IgH EtherCAT Master is distributed in the hope that it will be useful, |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
14 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
15 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
16 |
* Public License for more details. |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
17 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
18 |
* You should have received a copy of the GNU General Public License along |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
19 |
* with the IgH EtherCAT Master; if not, write to the Free Software |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
20 |
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
21 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
22 |
* --- |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
23 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
24 |
* The license mentioned above concerns the source code only. Using the |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
25 |
* EtherCAT technology and brand is only permitted in compliance with the |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1254
diff
changeset
|
26 |
* industrial property and similar rights of Beckhoff Automation GmbH. |
1142 | 27 |
* |
28 |
****************************************************************************/ |
|
29 |
||
30 |
#include <iostream> |
|
31 |
#include <iomanip> |
|
32 |
#include <sstream> |
|
33 |
using namespace std; |
|
34 |
||
35 |
#include "CommandAlias.h" |
|
36 |
#include "sii_crc.h" |
|
1826
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
37 |
#include "MasterDevice.h" |
1142 | 38 |
|
39 |
/*****************************************************************************/ |
|
40 |
||
41 |
CommandAlias::CommandAlias(): |
|
42 |
Command("alias", "Write alias addresses.") |
|
43 |
{ |
|
44 |
} |
|
45 |
||
46 |
/*****************************************************************************/ |
|
47 |
||
48 |
string CommandAlias::helpString() const |
|
49 |
{ |
|
50 |
stringstream str; |
|
51 |
||
52 |
str << getName() << " [OPTIONS] <ALIAS>" << endl |
|
53 |
<< endl |
|
54 |
<< getBriefDescription() << endl |
|
55 |
<< endl |
|
56 |
<< "Arguments:" << endl |
|
1144
7dbfdd61812c
Bugfixes and improvements.
Florian Pose <fp@igh-essen.com>
parents:
1142
diff
changeset
|
57 |
<< " ALIAS must be an unsigned 16 bit number. Zero means" << endl |
7dbfdd61812c
Bugfixes and improvements.
Florian Pose <fp@igh-essen.com>
parents:
1142
diff
changeset
|
58 |
<< " removing an alias address." << endl |
1157
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
59 |
<< endl |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
60 |
<< "If multiple slaves are selected, the --force option" << endl |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
61 |
<< "is required." << endl |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
62 |
<< endl |
1142 | 63 |
<< "Command-specific options:" << endl |
1157
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
64 |
<< " --alias -a <alias>" << endl |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
65 |
<< " --position -p <pos> Slave selection. See the help of" << endl |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
66 |
<< " the 'slaves' command." << endl |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
67 |
<< " --force -f Acknowledge writing aliases of" << endl |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
68 |
<< " multiple slaves." << endl |
1142 | 69 |
<< endl |
70 |
<< numericInfo(); |
|
71 |
||
72 |
return str.str(); |
|
73 |
} |
|
74 |
||
75 |
/*****************************************************************************/ |
|
76 |
||
77 |
/** Writes the Secondary slave address (alias) to the slave's SII. |
|
78 |
*/ |
|
1826
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
79 |
void CommandAlias::execute(const StringVector &args) |
1142 | 80 |
{ |
81 |
uint16_t alias; |
|
82 |
stringstream err, strAlias; |
|
83 |
int number; |
|
1151 | 84 |
SlaveList slaves; |
85 |
SlaveList::const_iterator si; |
|
1142 | 86 |
|
87 |
if (args.size() != 1) { |
|
88 |
err << "'" << getName() << "' takes exactly one argument!"; |
|
89 |
throwInvalidUsageException(err); |
|
90 |
} |
|
91 |
||
92 |
strAlias << args[0]; |
|
93 |
strAlias |
|
94 |
>> resetiosflags(ios::basefield) // guess base from prefix |
|
95 |
>> number; |
|
96 |
if (strAlias.fail() || number < 0x0000 || number > 0xffff) { |
|
97 |
err << "Invalid alias '" << args[0] << "'!"; |
|
98 |
throwInvalidUsageException(err); |
|
99 |
} |
|
100 |
alias = number; |
|
101 |
||
1826
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
102 |
if (getMasterIndices().size() != 1) { |
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
103 |
err << getName() << " requires to select a single master!"; |
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
104 |
throwInvalidUsageException(err); |
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
105 |
} |
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
106 |
MasterDevice m(getMasterIndices().front()); |
1151 | 107 |
m.open(MasterDevice::ReadWrite); |
108 |
slaves = selectedSlaves(m); |
|
109 |
||
1166 | 110 |
if (slaves.size() > 1 && !getForce()) { |
1151 | 111 |
err << "This will write the alias addresses of " |
112 |
<< slaves.size() << " slaves to " << alias |
|
113 |
<< "! Please specify --force to proceed."; |
|
114 |
throwCommandException(err); |
|
115 |
} |
|
1142 | 116 |
|
1157
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
117 |
if (!slaves.size() && getVerbosity() != Quiet) { |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
118 |
cerr << "Warning: Selection matches no slaves!" << endl; |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
119 |
} |
04d1c950cf9d
Added --help for alias and position parameters.
Florian Pose <fp@igh-essen.com>
parents:
1151
diff
changeset
|
120 |
|
1151 | 121 |
for (si = slaves.begin(); si != slaves.end(); si++) { |
122 |
writeSlaveAlias(m, *si, alias); |
|
1142 | 123 |
} |
124 |
} |
|
125 |
||
126 |
/*****************************************************************************/ |
|
127 |
||
128 |
/** Writes the Secondary slave address (alias) to the slave's SII. |
|
129 |
*/ |
|
130 |
void CommandAlias::writeSlaveAlias( |
|
131 |
MasterDevice &m, |
|
1151 | 132 |
const ec_ioctl_slave_t &slave, |
1142 | 133 |
uint16_t alias |
134 |
) |
|
135 |
{ |
|
136 |
ec_ioctl_slave_sii_t data; |
|
137 |
stringstream err; |
|
138 |
uint8_t crc; |
|
139 |
||
140 |
if (slave.sii_nwords < 8) { |
|
141 |
err << "Current SII contents are too small to set an alias " |
|
142 |
<< "(" << slave.sii_nwords << " words)!"; |
|
143 |
throwCommandException(err); |
|
144 |
} |
|
145 |
||
146 |
// read first 8 SII words |
|
1151 | 147 |
data.slave_position = slave.position; |
1142 | 148 |
data.offset = 0; |
149 |
data.nwords = 8; |
|
150 |
data.words = new uint16_t[data.nwords]; |
|
151 |
||
152 |
try { |
|
153 |
m.readSii(&data); |
|
154 |
} catch (MasterDeviceException &e) { |
|
155 |
delete [] data.words; |
|
156 |
err << "Failed to read SII: " << e.what(); |
|
157 |
throwCommandException(err); |
|
158 |
} |
|
159 |
||
160 |
// write new alias address in word 4 |
|
1254
c19d273a9e76
Moved byteorder macros to ecrt.h.
Florian Pose <fp@igh-essen.com>
parents:
1166
diff
changeset
|
161 |
data.words[4] = cpu_to_le16(alias); |
1142 | 162 |
|
163 |
// calculate checksum over words 0 to 6 |
|
164 |
crc = calcSiiCrc((const uint8_t *) data.words, 14); |
|
165 |
||
166 |
// write new checksum into first byte of word 7 |
|
167 |
*(uint8_t *) (data.words + 7) = crc; |
|
168 |
||
169 |
// write first 8 words with new alias and checksum |
|
170 |
try { |
|
171 |
m.writeSii(&data); |
|
172 |
} catch (MasterDeviceException &e) { |
|
173 |
delete [] data.words; |
|
174 |
err << "Failed to read SII: " << e.what(); |
|
175 |
throwCommandException(err); |
|
176 |
} |
|
177 |
||
178 |
delete [] data.words; |
|
179 |
} |
|
180 |
||
181 |
/*****************************************************************************/ |