<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Aptos;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
font-size:11.0pt;
font-family:"Aptos",sans-serif;
mso-ligatures:standardcontextual;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
{mso-style-priority:34;
margin-top:0in;
margin-right:0in;
margin-bottom:0in;
margin-left:.5in;
font-size:11.0pt;
font-family:"Aptos",sans-serif;
mso-ligatures:standardcontextual;}
span.EmailStyle17
{mso-style-type:personal-compose;
font-family:"Aptos",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:11.0pt;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
/* List Definitions */
@list l0
{mso-list-id:1219631474;
mso-list-type:hybrid;
mso-list-template-ids:-463860830 67698705 67698713 67698715 67698703 67698713 67698715 67698703 67698713 67698715;}
@list l0:level1
{mso-level-text:"%1\)";
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;}
@list l0:level2
{mso-level-number-format:alpha-lower;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;}
@list l0:level3
{mso-level-number-format:roman-lower;
mso-level-tab-stop:none;
mso-level-number-position:right;
text-indent:-9.0pt;}
@list l0:level4
{mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;}
@list l0:level5
{mso-level-number-format:alpha-lower;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;}
@list l0:level6
{mso-level-number-format:roman-lower;
mso-level-tab-stop:none;
mso-level-number-position:right;
text-indent:-9.0pt;}
@list l0:level7
{mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;}
@list l0:level8
{mso-level-number-format:alpha-lower;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;}
@list l0:level9
{mso-level-number-format:roman-lower;
mso-level-tab-stop:none;
mso-level-number-position:right;
text-indent:-9.0pt;}
ol
{margin-bottom:0in;}
ul
{margin-bottom:0in;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#467886" vlink="#96607D" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoNormal">All,<o:p></o:p></p>
<p class="MsoNormal"> Trying to track down an issue with setting up “Flexible PDOs” on the Kollmorgan AKD2Gs. I have tried various methods to get these to be configured reliably, but nothing yet.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">The baseline code calls ecrt_domain_reg_pdo_entry_list(mDomain,domain1_regs), and that works around 90% of the time. However, it fails ~10% of the time. This problem makes life “fun” when you have 6 motor controllers with each one
randomly not configuring properly.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">In looking at the logs on the master with dmesg, we get a timeout on waiting for SDO responses. Also, looking at the SDO logs inside the AKD2G (but still working that angle), it also appears that either SDOs are not being received from
the master (or the AKD2G is ignoring them??).<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I have even written scripts that does the SDOs setup by hand (ie ethercat -p0 --type uint8 download 0x1C12 0 0), and I also get random results of getting the configuration setup correctly.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">The CStruct is as follows:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">ec_pdo_entry_info_t akd2g_pdo_entries_current[] = {<o:p></o:p></p>
<p class="MsoNormal"> /* RxPdo 0x1600 */<o:p></o:p></p>
<p class="MsoNormal"> { 0x5003, 0x05, 32 }, /* current */<o:p></o:p></p>
<p class="MsoNormal"> { 0x6040, 0x00, 16 }, /* DS402 command word */<o:p></o:p></p>
<p class="MsoNormal">};<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">ec_pdo_entry_info_t akd2g_pdo_entries_received[] = {<o:p></o:p></p>
<p class="MsoNormal"> /* TxPDO 0x1a00 */<o:p></o:p></p>
<p class="MsoNormal"> { 0x6063, 0x00, 32 }, /* position */<o:p></o:p></p>
<p class="MsoNormal"> { 0x6041, 0x00, 16 }, /* DS402 Status Word*/<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"> /* TxPDO 0x1a01 */<o:p></o:p></p>
<p class="MsoNormal"> { 0x606c, 0x00, 32 }, /* actual velocity, in milli rpm */<o:p></o:p></p>
<p class="MsoNormal"> { 0x500A, 0x01, 32 }, /* actual current */<o:p></o:p></p>
<p class="MsoNormal"> { 0x60E4, 0x01, 32 }, /* Feedback 1 Position */<o:p></o:p></p>
<p class="MsoNormal">};<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">ec_pdo_info_t akd2g_pdos_current[] = {<o:p></o:p></p>
<p class="MsoNormal"> { 0x1600, 2, akd2g_pdo_entries_current + 0 },<o:p></o:p></p>
<p class="MsoNormal"> { 0x1a00, 2, akd2g_pdo_entries_received + 0 },<o:p></o:p></p>
<p class="MsoNormal"> { 0x1a01, 3, akd2g_pdo_entries_received + 2 },<o:p></o:p></p>
<p class="MsoNormal">};<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">ec_sync_info_t akd2g_syncs_current[] = {<o:p></o:p></p>
<p class="MsoNormal"> { 0, EC_DIR_OUTPUT, 0, NULL, EC_WD_DISABLE },<o:p></o:p></p>
<p class="MsoNormal"> { 1, EC_DIR_INPUT, 0, NULL, EC_WD_DISABLE },<o:p></o:p></p>
<p class="MsoNormal"> { 2, EC_DIR_OUTPUT, 1, akd2g_pdos_current + 0, EC_WD_DISABLE },<o:p></o:p></p>
<p class="MsoNormal"> { 3, EC_DIR_INPUT, 2, akd2g_pdos_current + 1, EC_WD_DISABLE },<o:p></o:p></p>
<p class="MsoNormal"> { 0xFF }<o:p></o:p></p>
<p class="MsoNormal">};<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Still working to get a Wireshark dump (on a headless system), so working through this to see if it tells me anything.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Questions: <o:p></o:p></p>
<ol style="margin-top:0in" start="1" type="1">
<li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level1 lfo1">Has anybody experienced similar issues and how they where able to resolve this?<o:p></o:p></li><li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level1 lfo1">I have tried things that where mentioned in other posts like increasing EC_WAIT_SDO_DICT from 3 to 30 seconds. Any other settings I should be looking at?<o:p></o:p></li><li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level1 lfo1">I am currently using version 1.5.x. I looked at the release notes for 1.6 and didn’t see anything that looked obvious. Anything in the update that may help?<o:p></o:p></li><li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level1 lfo1">It seems (as a stop gap) that if I attempt to configure all 6 motor controllers, eventually it will work. The method right now is to:<o:p></o:p></li><ol style="margin-top:0in" start="1" type="a">
<li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level2 lfo1">Ecrt_release_master(mMaster)<o:p></o:p></li><li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level2 lfo1">Run a script that will restart ethercat (ie. /usr/local/etc/init.d/ethercat restart)<o:p></o:p></li><li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level2 lfo1">But when I attempt to get the master (ecrt_master_activate(mMaster)), domain (ie. ecrt_domain_data(mDomain)) all is good<o:p></o:p></li><li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level2 lfo1">BUT FAILS on ecrt_domain_reg_pdo_entry_list(mDomain, domain_regs)<o:p></o:p></li><li class="MsoListParagraph" style="margin-left:0in;mso-list:l0 level2 lfo1">Anybody have some actual or sudo code that would allow for me to try again…either fall all motor controllers or the specific motor controller that didn’t setup the PDOs correctly?<o:p></o:p></li></ol>
</ol>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Thanks in advance for anything you can provide,<o:p></o:p></p>
<p class="MsoNormal">Mike W<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</body>
</html>