<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=iso-8859-1">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><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:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:"Segoe UI";
panose-1:2 11 5 2 4 2 4 2 2 3;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0cm;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:purple;
text-decoration:underline;}
p.msonormal0, li.msonormal0, div.msonormal0
{mso-style-name:msonormal;
margin:0cm;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
span.EmailStyle20
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:10.0pt;}
@page WordSection1
{size:612.0pt 792.0pt;
margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.WordSection1
{page:WordSection1;}
--></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-NZ" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">Most libraries claiming “thread safety” actually mean “uses mutexes”. And you absolutely never ever ever want to hit a mutex on your realtime thread. (Etherlab does have a few internal ones, but
they’re rarely contended, by design, so it’s usually ok.)<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">You also never want to call out into “outside” code, especially not GUI code, on your realtime thread. It needs to be doing EtherCAT things and only EtherCAT things. You need to be very careful
that any interaction with other threads is limited to flag passing or wakeups, not event signals in the Qt sense.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">You can have realtime and non-realtime threads within the same process if you’re careful, but as Wilhelm suggested, it’s better to have them on separate processes, even separate computers if you
can manage it. Most user-interaction libraries are not designed with realtime performance in mind and they can do things that cause severe latency problems.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">Note that EoE is specifically for when you have a standard Ethernet gateway slave (eg. Beckhoff EL6601) on your EtherCAT network. If you’re just talking to EtherCAT devices, you’re not using EoE
and you should disable it to improve performance.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<P
style="FONT-SIZE: 100%; FONT-FAMILY: Calibri, Candara, Segoe, Optima, Arial, sans-serif; COLOR: rgb(89,89,89)"><STRONG>Gavin Lambert<BR></STRONG>Senior Software Developer<BR></P>
<P style="FONT-SIZE: 10pt; FONT-FAMILY: Arial">
<TABLE>
<TBODY
style="FONT-SIZE: 75%; FONT-FAMILY: Calibri, Candara, Segoe, Optima, Arial, sans-serif; COLOR: rgb(89,89,89)"> </TBODY></TABLE></P>
<P style="FONT-SIZE: 10pt; FONT-FAMILY: Arial"><IMG border=0
src="cid:logo_compac_5dcf97ef-52f5-498c-8b9b-728410ddffaf.png"><BR><A
href="http://www.compacsort.com"><IMG border=0 alt=TOMRA
src="cid:compacicon_82e8a8c7-154a-4a32-9720-a5badb6258e0.png" width=33
height=37></A> <A href="https://www.facebook.com/Compacsort"><IMG border=0
alt=Facebook src="cid:facebook_fa85b924-53b9-45cc-8162-0564f64ec3a3.png" width=35
height=37></A> <A
href="https://www.linkedin.com/company/compac-sorting-equipment/"><IMG border=0
alt=Linkedin src="cid:linkedin_4ec016ad-84fa-443c-85a3-b9615a4ccef8.png" width=35
height=37></A> <A href="https://vimeo.com/compacsort"><IMG border=0 alt=Youtube
src="cid:youtube_32142163-fc27-4aed-b14d-e8a377f98a6d.png" width=37 height=37></A>
<A href="https://twitter.com/compacsort"><IMG border=0 alt=twitter
src="cid:twitter_d89338d8-98c8-4b65-9a9e-7b1333160b0d.png" width=33 height=37></A>
</P>
<P
style="FONT-SIZE: 75%; FONT-FAMILY: Calibri, Candara, Segoe, Optima, Arial, sans-serif; COLOR: rgb(89,89,89)"><B>COMPAC
SORTING EQUIPMENT LTD</B> | 4 Henderson Pl | Onehunga | Auckland 1061 | New
Zealand<BR>Switchboard: +64 96 34 00 88 | <A
href="http://www.tomra.com">tomra.com</A> </P>
<TABLE
style="BORDER-TOP-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-COLLAPSE: collapse; BORDER-BOTTOM-STYLE: none; BORDER-RIGHT-STYLE: none"
cellSpacing=0 cellPadding=0 border=1>
<TBODY>
<TR>
<TD
style="BORDER-LEFT-STYLE: none; BORDER-TOP: #595959 1pt solid; BORDER-BOTTOM: #595959 1pt solid; BORDER-RIGHT-STYLE: none"
vAlign=top>
<P
style="FONT-SIZE: 75%; FONT-FAMILY: Calibri, Candara, Segoe, Optima, Arial, sans-serif; COLOR: rgb(89,89,89)">The
information contained in this communication and any attachment is
confidential and may be legally privileged. It should only be read by the
person(s) to whom it is addressed. If you have received this communication
in error, please notify the sender and delete the communication.
</P></TD></TR></TBODY></TABLE>
<P
style="FONT-SIZE: 75%; FONT-FAMILY: Calibri, Candara, Segoe, Optima, Arial, sans-serif; COLOR: rgb(89,89,89)"></P><div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="EN-US">From:</span></b><span lang="EN-US"> Simone Comari<br>
<b>Sent:</b> Tuesday, 4 June 2019 06:14<br>
<b>To:</b> Dr.-Ing. Wilhelm Hagemeister <hm@igh.de>; etherlab-users@etherlab.org<br>
<b>Subject:</b> [etherlab-users] R: R: System randomly freezes in multi-thread Qt application with a RT process<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">Hi all,<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">@Roberto, we were already building a new program with a progressively increasing complexity and it looks like the fault arises as soon as many Qt signals come into play. I didn't even have to create
a GUI, but just few slots simulating the receivers of such signals already blocked the system.<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">So I really believe that the "thread-safe" feature claimed by Qt is only true when using their own QThread or anyway the problem is related to how we make the two processes comunicate to each other.<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">Following Wilhelm's suggestion, I had a look at their libraries. The premises seem promising, meaning that it looks like it is exactly what we need. Only issue is that I really had some troubles
understanding how I can integrate it into my program. <br>
As far as I understood, we should split our application into two separate programs, being one the server, running our ethercat-capable real time process, and the other the client, running our GUI. Then these processes should be started separately and would
communicate through some (internal?) network protocol. Is it somewhat correct?<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">I will definitely have to look deeper into it, but a first question already comes to my mind: how do I enhance a real time task on the server side with pdserv? I'm using
<a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2FUNIBO-GRABLab%2Fgrab_common%2Ftree%2Fmaster%2Flibgrabrt&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574030109&sdata=pQw93PQf55J1APYLblK64KShVZqQb377S7PyW7dlWMY%3D&reserved=0" title="https://github.com/UNIBO-GRABLab/grab_common/tree/master/libgrabrt">
this</a> library (our own) to start our real-time thread at the moment.<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">Lastly, I beg your pardon for the next foolish question, I'm not very familiar with communication protocols.. Which alternative would we have to replace EoE when our only physical device is an
ethernet cable connecting our workstation (PC) to a series of Elmo's motor drives (open daisy chain config), also linked by ethernet cables to each other? <o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">Thank you all for the great support!<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">Best regards,<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-size:12.0pt;color:black">Simone<o:p></o:p></span></p>
</div>
<div id="Signature">
<div id="divtagdefaultwrapper">
<p><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121">____________________________________________________</span><span style="font-size:12.0pt;font-family:"Segoe UI",sans-serif;color:#212121"><br>
<br>
</span><b><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121">SIMONE COMARI</span></b><span style="font-size:12.0pt;color:black"><o:p></o:p></span></p>
<p><i><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:black">Research Fellow</span></i><i><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121"><br>
</span></i><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121">DIN – Dept. of Industrial Engineering</span><span style="font-family:"Segoe UI",sans-serif;color:#212121"><br>
</span><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121">Alma Mater Studiorum – University of Bologna</span><span style="font-family:"Segoe UI",sans-serif;color:#212121"><br>
</span><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121">Via Umberto Terracini, 24, 40131 Bologna (BO), Italy </span><span style="color:black"><o:p></o:p></span></p>
<p><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121">E-mail:
</span><span style="font-size:12.0pt;font-family:"Segoe UI",sans-serif;color:#212121"><a href="mailto:simone.comari2@unibo.it"><span style="font-size:10.0pt">simone.comari2@unibo.it</span></a><br>
</span><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif;color:#212121">Websites:</span><span style="font-size:12.0pt;font-family:"Segoe UI",sans-serif;color:#212121"><br>
</span><span style="font-size:12.0pt;color:black"><a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.unibo.it%2Fsitoweb%2Fsimone.comari2&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574039942&sdata=nRv2AsOx%2FFUJlR19ukc1sMBt2P6NMBCeVZbQHa54Mjk%3D&reserved=0"><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif">https://www.unibo.it/sitoweb/simone.comari2</span></a></span><span style="font-size:12.0pt;font-family:"Segoe UI",sans-serif;color:#212121"><br>
</span><span style="font-size:12.0pt;color:black"><a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fgrab.diem.unibo.it%2F&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574039942&sdata=9egoU0kDuE1gBo90r%2BDokxFGmqt28lNQmo8lOpkBIgg%3D&reserved=0" target="_blank"><span style="font-size:10.0pt;font-family:"Segoe UI",sans-serif">http://grab.diem.unibo.it</span></a><o:p></o:p></span></p>
</div>
</div>
<div class="MsoNormal" align="center" style="text-align:center">
<hr size="2" width="98%" align="center">
</div>
<div id="divRplyFwdMsg">
<p class="MsoNormal"><b><span style="color:black">Da:</span></b><span style="color:black"> Dr.-Ing. Wilhelm Hagemeister <<a href="mailto:hm@igh.de">hm@igh.de</a>><br>
<b>Inviato:</b> venerdì 31 maggio 2019 11:00<br>
<b>A:</b> <a href="mailto:etherlab-users@etherlab.org">etherlab-users@etherlab.org</a><br>
<b>Cc:</b> Simone Comari; <a href="mailto:roberto.viola@systemceramics.com">roberto.viola@systemceramics.com</a><br>
<b>Oggetto:</b> Re: [etherlab-users] R: System randomly freezes in multi-thread Qt application with a RT process</span>
<o:p></o:p></p>
<div>
<p class="MsoNormal"> <o:p></o:p></p>
</div>
</div>
<div>
<div>
<p class="MsoNormal">Hi Simone,<br>
<br>
in addition to Robertos post...<br>
<br>
We strictly separate GUI from real time program and communicate between<br>
a realtime process as the data producer and clients like GUI as <br>
consumers by a network protocol. This protocol separates parameters from<br>
channels and is bidirectional and multi client capable. It also allows <br>
to run realtime process and GUI on separate machines; which mostly the <br>
case. Also it makes debugging a lot easier due to reduced complexity.<br>
<br>
"pdcom" and "pdserv" are the well tested communication libraries and<br>
"qtpdwidgets" is the library with process data aware widgets for QT(4 <br>
and 5).<br>
With this "qtpdwidgets" comes an example.<br>
<br>
Read the README with comes with the libraries.<br>
<br>
By using "pdserv" as the communication interface to the realtime process <br>
you also are able to use tools like "Testmanager" or "dlsd".<br>
<br>
There is no good example for "pdserv" right now. But triggered by your <br>
post I asked my colleague to add an example to the "pdserv" library to <br>
make the start a bit easier.<br>
<br>
look here for latest versions and precompiled rpm's (sorry, no debian<br>
packages yet, we are working on it...):<br>
<br>
<a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fbuild.opensuse.org%2Fproject%2Fshow%2Fscience%3AEtherLab&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574049934&sdata=nMLkFI5mReyM%2BBxCXwaZCpWGWp2kKfrs49Huc7vg1Vw%3D&reserved=0">https://build.opensuse.org/project/show/science:EtherLab</a><br>
<br>
Don't reinvent the wheel... if you can avoid it.<br>
<br>
Regards Wilhelm.<br>
<br>
P.S. EoE has some issues. Try without it.<br>
<br>
Am 31.05.19 um 09:30 schrieb Viola Roberto:<br>
> Hi Simone,<br>
> <br>
> first of all the guc firmware aren’t a issue, so go on J<br>
> <br>
> In order to understand the issue i think you should try to split your <br>
> application in small pieces: in this way we can try to delimit the <br>
> perimeter of the issue.<br>
> <br>
> You could try to run a simple application (using the ethercat example <br>
> that you can find on the repository) that only read or write some <br>
> objects from your slaves and step after step you can add pieces of code <br>
> in order to identify when and where the issue happens. I don’t know how <br>
> much is big your app, but from my point of view it’s the only way to <br>
> achieve some results.<br>
> <br>
> Other note: in your first log i saw that the crash happened in EoE <br>
> context, did you use it? Could you try to disable it and test it again?<br>
> <br>
> Have a nice weekend<br>
> <br>
> Roberto<br>
> <br>
> *Da:*Simone Comari [<a href="mailto:simone.comari2@unibo.it">mailto:simone.comari2@unibo.it</a>]<br>
> *Inviato:* mercoledì 29 maggio 2019 15:50<br>
> *A:* Viola Roberto <<a href="mailto:roberto.viola@systemceramics.com">roberto.viola@systemceramics.com</a>>;
<br>
> <a href="mailto:etherlab-users@etherlab.org">etherlab-users@etherlab.org</a><br>
> *Cc:* Edoardo Ida <<a href="mailto:edoardo.ida2@unibo.it">edoardo.ida2@unibo.it</a>><br>
> *Oggetto:* R: System randomly freezes in multi-thread Qt application <br>
> with a RT process<br>
> <br>
> Hi Roberto,<br>
> <br>
> Thanks for following up, much appreciated.<br>
> <br>
> We tried the same setup on a laptop (Dell Inspiron-5567, Intel® Core™ <br>
> i7-7500U CPU @ 2.70GHz × 4), dual booted Windows 10/Ubuntu 16.04.6 but <br>
> the behavior remains the same.<br>
> <br>
> I noticed nevertheless that both workstations have the same driver for <br>
> the video card (i.e. /i915/). I also noticed that at the end of RT <br>
> kernel build (I think when making /modules_install/) there was a warning <br>
> about a couple of missing firmwares for this device:<br>
> <br>
> possible missing firmware /lib/firmware/i915/kbl_guc_ver9_14.bin for <br>
> module i915<br>
> <br>
> possible missing firmware /lib/firmware/i915/bxt_guc_ver8_7.bin for <br>
> module i915<br>
> <br>
> <br>
> <br>
> So I copied the missing files (taken from here <br>
> <<a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgit.kernel.org%2Fpub%2Fscm%2Flinux%2Fkernel%2Fgit%2Ffirmware%2Flinux-firmware.git%2Ftree%2Fi915&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574049934&sdata=IKyZpeZTM1ziDKwNLOG49dIHncpKdfEXpFqhqazh8JE%3D&reserved=0">https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/tree/i915</a>>)
<br>
> into //lib/firmware/i915/ and updated with following command:<br>
> <br>
> |sudo update-initramfs -u|<br>
> <br>
> I then recompiled both the RT kernel and etherlab libs, but except for <br>
> the disappeared warnings, nothing changed.<br>
> <br>
> The video card I'm mounting is the following:<br>
> <br>
> $ lshw -C video<br>
> <br>
> *-display<br>
> <br>
> description: VGA compatible controller<br>
> <br>
> product: HD Graphics 620<br>
> <br>
> vendor: Intel Corporation<br>
> <br>
> physical id: 2<br>
> <br>
> bus info: <a href="mailto:pci@0000:00:02.0">pci@0000:00:02.0</a> <<a href="mailto:pci@0000:00:02.0">mailto:pci@0000:00:02.0</a>><br>
> <br>
> version: 02<br>
> <br>
> width: 64 bits<br>
> <br>
> clock: 33MHz<br>
> <br>
> capabilities: pciexpress msi pm vga_controller bus_master <br>
> cap_list rom<br>
> <br>
> configuration: driver=i915 latency=0<br>
> <br>
> resources: irq:280 memory:de000000-deffffff <br>
> memory:b0000000-bfffffff ioport:f000(size=64) memory:c0000-dffff<br>
> <br>
> I've tried to stress both CPU<br>
> <br>
> $ stress --cpu `nproc` --vm `nproc` --vm-bytes 1GB --io `nproc` --hdd <br>
> `nproc` --hdd-bytes 1GB --timeout 60s<br>
> <br>
> stress: info: [6624] dispatching hogs: 4 cpu, 4 io, 4 vm, 4 hdd<br>
> <br>
> stress: info: [6624] successful run completed in 60s<br>
> <br>
> and video card<br>
> <br>
> $ glmark2<br>
> <br>
> =======================================================<br>
> <br>
> glmark2 2014.03+git20150611.fa71af2d<br>
> <br>
> =======================================================<br>
> <br>
> OpenGL Information<br>
> <br>
> GL_VENDOR: Intel Open Source Technology Center<br>
> <br>
> GL_RENDERER: Mesa DRI Intel(R) HD Graphics 620 (Kaby Lake GT2)<br>
> <br>
> GL_VERSION: 3.0 Mesa 18.0.5<br>
> <br>
> =======================================================<br>
> <br>
> [build] use-vbo=false: FPS: 1392 FrameTime: 0.718 ms<br>
> <br>
> [build] use-vbo=true: FPS: 1494 FrameTime: 0.669 ms<br>
> <br>
> [texture] texture-filter=nearest: FPS: 1220 FrameTime: 0.820 ms<br>
> <br>
> [texture] texture-filter=linear: FPS: 1370 FrameTime: 0.730 ms<br>
> <br>
> [texture] texture-filter=mipmap: FPS: 1379 FrameTime: 0.725 ms<br>
> <br>
> [shading] shading=gouraud: FPS: 1352 FrameTime: 0.740 ms<br>
> <br>
> [shading] shading=blinn-phong-inf: FPS: 1356 FrameTime: 0.737 ms<br>
> <br>
> [shading] shading=phong: FPS: 1334 FrameTime: 0.750 ms<br>
> <br>
> [shading] shading=cel: FPS: 1365 FrameTime: 0.733 ms<br>
> <br>
> [bump] bump-render=high-poly: FPS: 1004 FrameTime: 0.996 ms<br>
> <br>
> [bump] bump-render=normals: FPS: 1474 FrameTime: 0.678 ms<br>
> <br>
> [bump] bump-render=height: FPS: 1496 FrameTime: 0.668 ms<br>
> <br>
> [effect2d] kernel=0,1,0;1,-4,1;0,1,0;: FPS: 1141 FrameTime: 0.876 ms<br>
> <br>
> [effect2d] kernel=1,1,1,1,1;1,1,1,1,1;1,1,1,1,1;: FPS: 847 FrameTime: <br>
> 1.181 ms<br>
> <br>
> [pulsar] light=false:quads=5:texture=false: FPS: 1543 FrameTime: 0.648 ms<br>
> <br>
> [desktop] blur-radius=5:effect=blur:passes=1:separable=true:windows=4: <br>
> FPS: 670 FrameTime: 1.493 ms<br>
> <br>
> [desktop] effect=shadow:windows=4: FPS: 891 FrameTime: 1.122 ms<br>
> <br>
> [buffer] <br>
> columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=map:
<br>
> FPS: 638 FrameTime: 1.567 ms<br>
> <br>
> [buffer] <br>
> columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=subdata:
<br>
> FPS: 493 FrameTime: 2.028 ms<br>
> <br>
> [buffer] <br>
> columns=200:interleave=true:update-dispersion=0.9:update-fraction=0.5:update-method=map:
<br>
> FPS: 690 FrameTime: 1.449 ms<br>
> <br>
> [ideas] speed=duration: FPS: 1265 FrameTime: 0.791 ms<br>
> <br>
> [jellyfish] <default>: FPS: 1258 FrameTime: 0.795 ms<br>
> <br>
> [terrain] <default>: FPS: 189 FrameTime: 5.291 ms<br>
> <br>
> [shadow] <default>: FPS: 982 FrameTime: 1.018 ms<br>
> <br>
> [refract] <default>: FPS: 360 FrameTime: 2.778 ms<br>
> <br>
> [conditionals] fragment-steps=0:vertex-steps=0: FPS: 1339 FrameTime: <br>
> 0.747 ms<br>
> <br>
> [conditionals] fragment-steps=5:vertex-steps=0: FPS: 1337 FrameTime: <br>
> 0.748 ms<br>
> <br>
> [conditionals] fragment-steps=0:vertex-steps=5: FPS: 1329 FrameTime: <br>
> 0.752 ms<br>
> <br>
> [function] fragment-complexity=low:fragment-steps=5: FPS: 1343 <br>
> FrameTime: 0.745 ms<br>
> <br>
> [function] fragment-complexity=medium:fragment-steps=5: FPS: 1343 <br>
> FrameTime: 0.745 ms<br>
> <br>
> [loop] fragment-loop=false:fragment-steps=5:vertex-steps=5: FPS: 1315 <br>
> FrameTime: 0.760 ms<br>
> <br>
> [loop] fragment-steps=5:fragment-uniform=false:vertex-steps=5: FPS: 1221 <br>
> FrameTime: 0.819 ms<br>
> <br>
> [loop] fragment-steps=5:fragment-uniform=true:vertex-steps=5: FPS: 1275 <br>
> FrameTime: 0.784 ms<br>
> <br>
> =======================================================<br>
> <br>
> glmark2 Score: 1142<br>
> <br>
> =======================================================<br>
> <br>
> and no apparent issues arised.<br>
> <br>
> I'm attaching two log sessions from my latest laptop trials. Inside you <br>
> can find a brief description of the operations carried out for each session.<br>
> <br>
> I noticed that in one of them it looks like one source of the freezing <br>
> is related to /rt_mutex/, which I'm not really confident with but I have <br>
> the feeling is the actual source of our problem (probably in the way we <br>
> implemented the ethercat communication in our code).<br>
> <br>
> Please let me know if you have any suggestions or need any other <br>
> information.<br>
> <br>
> Thanks again,<br>
> <br>
> Simone<br>
> <br>
> Roberto Viola<br>
> Technical Dept<br>
> +39 0536836680<br>
> <br>
> *SYSTEM CERAMICS S.p.A.*<br>
> Via Ghiarola Vecchia, 73<br>
> 41042 Fiorano (Mo) ITALY<br>
> +39 0536 836111<br>
> <a href="mailto:info@system-electronics.it">info@system-electronics.it</a> <<a href="mailto:info@system-electronics.it">mailto:info@system-electronics.it</a>><br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.system-electronics.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574059929&sdata=O2zd%2FJ9b9knzTyCSUwyr3xMKsutwnl74VbrJ9EBM9MI%3D&reserved=0">
www.system-electronics.it</a> <<a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.system-electronics.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574059929&sdata=O2zd%2FJ9b9knzTyCSUwyr3xMKsutwnl74VbrJ9EBM9MI%3D&reserved=0">http://www.system-electronics.it</a>><br>
> <br>
> ------------------------------------------------------------------------<br>
> <br>
> Le informazioni contenute in questa email, inclusi i suoi allegati, sono <br>
> riservate e ad uso esclusivo del destinatario. Qualora le fosse <br>
> pervenuta per errore, lei non è autorizzato a copiare, inoltrare e/o <br>
> rendere nota questa email e i suoi allegati, totalmente o parzialmente, <br>
> e pertanto la preghiamo di cancellarla immediatamente senza visionarne <br>
> il contenuto e gli allegati.<br>
> <br>
> Avvertenza: la presente casella e-mail ed i messaggi da essa derivanti, <br>
> sono di esclusivo utilizzo aziendale /lavorativo e mai personale.<br>
> <br>
> Risposte al presente messaggio: si avvisa il destinatario che eventuali <br>
> sue risposte, potranno essere lette dall’intera azienda /ufficio <br>
> /reparto di appartenenza del mittente.<br>
> <br>
> The information contained in this e-mail, including attachments, is <br>
> confidential and exclusively for the use of the intended recipient. If <br>
> you received this communication by mistake you are not authorized to <br>
> copy, send and/or publish this message and its attachments, in whole or <br>
> in part and therefore please delete this message.<br>
> <br>
> ____________________________________________________<br>
> <br>
> *SIMONE COMARI*<br>
> <br>
> /Research Fellow//<br>
> /DIN – Dept. of Industrial Engineering<br>
> Alma Mater Studiorum – University of Bologna<br>
> Via Umberto Terracini, 24, 40131 Bologna (BO), Italy<br>
> <br>
> E-mail: <a href="mailto:simone.comari2@unibo.it">simone.comari2@unibo.it</a> <<a href="mailto:simone.comari2@unibo.it">mailto:simone.comari2@unibo.it</a>><br>
> Websites:<br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.unibo.it%2Fsitoweb%2Fsimone.comari2&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574069923&sdata=Z0yu4FFHAyJZxZIA5hlGuF3araDCWufybpfo6Ticx3A%3D&reserved=0">
https://www.unibo.it/sitoweb/simone.comari2</a><br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fgrab.diem.unibo.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574069923&sdata=T6X00Ch4GzjceleUoEBRqPEyCsU0OSYajmJb9duIMcI%3D&reserved=0">
http://grab.diem.unibo.it</a> <<a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fgrab.diem.unibo.it%2F&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574069923&sdata=ZNtGorCOR1ljrangotBRlZmhdqFQ7QMsaiE6daojqfQ%3D&reserved=0">http://grab.diem.unibo.it/</a>><br>
> <br>
> ------------------------------------------------------------------------<br>
> <br>
> *Da:*Viola Roberto <<a href="mailto:roberto.viola@systemceramics.com%20%0b">roberto.viola@systemceramics.com
<br>
</a>> <<a href="mailto:roberto.viola@systemceramics.com">mailto:roberto.viola@systemceramics.com</a>>><br>
> *Inviato:* lunedì 27 maggio 2019 10:57<br>
> *A:* Simone Comari; <a href="mailto:etherlab-users@etherlab.org">etherlab-users@etherlab.org</a>
<br>
> <<a href="mailto:etherlab-users@etherlab.org">mailto:etherlab-users@etherlab.org</a>><br>
> *Oggetto:* R: System randomly freezes in multi-thread Qt application <br>
> with a RT process<br>
> <br>
> Hi Simone,<br>
> <br>
> from the logs it seems a issue releated to your i915 (video card, i <br>
> guess inside your CPU).<br>
> <br>
> You should try to understand the cause of issue: i suggest to try <br>
> without the ethercat and stressing the cpu and the video card in some <br>
> other way. I guess it’s not related to ethercat.<br>
> <br>
> BTW what videocard do you have?<br>
> <br>
> Did you try to catch the logs on other systems (laptop for example)?<br>
> <br>
> R.<br>
> <br>
> *Da:*Simone Comari [<a href="mailto:simone.comari2@unibo.it">mailto:simone.comari2@unibo.it</a>]<br>
> *Inviato:* giovedì 23 maggio 2019 12:51<br>
> *A:* Viola Roberto <<a href="mailto:roberto.viola@systemceramics.com%20%0b">roberto.viola@systemceramics.com
<br>
</a>> <<a href="mailto:roberto.viola@systemceramics.com">mailto:roberto.viola@systemceramics.com</a>>>;
<a href="mailto:etherlab-users@etherlab.org">etherlab-users@etherlab.org</a> <br>
> <<a href="mailto:etherlab-users@etherlab.org">mailto:etherlab-users@etherlab.org</a>><br>
> *Oggetto:* R: System randomly freezes in multi-thread Qt application <br>
> with a RT process<br>
> <br>
> Hi Roberto,<br>
> <br>
> First of all, thank you for your quick response.<br>
> <br>
> Attached you can find the /kernel.log/ and /system.log/ of a single <br>
> session, that is:<br>
> <br>
> 1. Boot up<br>
> 2. Application launch (successful ethercat network setup) through Qt IDE<br>
> 3. Successful enabling of a single motor (i.e. one of the ethercat<br>
> slaves) through our GUI<br>
> 4. Simple operation (e.g. manual velocity control) until problem occurs<br>
> (it took a couple of minutes this time)<br>
> 5. Hard shut-down of the "frozen" system<br>
> <br>
> I hope these are the logs you were talking about, please let me know <br>
> otherwise.<br>
> <br>
> Maybe it's worth mentioning we followed these <br>
> <<a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2FUNIBO-GRABLab%2Fcable_robot%2Fwiki%2FInstallation&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574079919&sdata=ZQk37PyK%2BYFAx9OyHmD%2F1rcmfCKaxLKmdI1E2F%2BtkeU%3D&reserved=0">https://github.com/UNIBO-GRABLab/cable_robot/wiki/Installation</a>>
<br>
> instructions to install both the RT kernel and ethercat libs, just in <br>
> case we misused patches or configurations.<br>
> <br>
> Thanks again.<br>
> <br>
> Best regards,<br>
> <br>
> Simone<br>
> <br>
> Roberto Viola<br>
> <br>
> Technical Dept<br>
> <br>
> +39 0536836680<br>
> <br>
> *SYSTEM CERAMICS S.p.A.*<br>
> <br>
> Via Ghiarola Vecchia, 73<br>
> <br>
> 41042 Fiorano (Mo) ITALY<br>
> <br>
> +39 0536 836111<br>
> <br>
> <a href="mailto:info@system-electronics.it">info@system-electronics.it</a> <<a href="mailto:info@system-electronics.it">mailto:info@system-electronics.it</a>><br>
> <br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.system-electronics.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574079919&sdata=YUVN%2Bi5bDjw11h%2FzTPZNT6DxUDrOJMp0vThOhrGpp%2Fs%3D&reserved=0">
www.system-electronics.it</a> <<a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.system-electronics.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574089903&sdata=YrGQH8WoOpdrS8B09FeoJiCnRH4meaIlBRzxlbhB7uI%3D&reserved=0">http://www.system-electronics.it</a>><br>
> <br>
> ------------------------------------------------------------------------<br>
> <br>
> Le informazioni contenute in questa email, inclusi i suoi allegati, sono <br>
> riservate e ad uso esclusivo del destinatario. Qualora le fosse <br>
> pervenuta per errore, lei non è autorizzato a copiare, inoltrare e/o <br>
> rendere nota questa email e i suoi allegati, totalmente o parzialmente, <br>
> e pertanto la preghiamo di cancellarla immediatamente senza visionarne <br>
> il contenuto e gli allegati.<br>
> <br>
> Avvertenza: la presente casella e-mail ed i messaggi da essa derivanti, <br>
> sono di esclusivo utilizzo aziendale /lavorativo e mai personale.<br>
> <br>
> Risposte al presente messaggio: si avvisa il destinatario che eventuali <br>
> sue risposte, potranno essere lette dall’intera azienda /ufficio <br>
> /reparto di appartenenza del mittente.<br>
> <br>
> The information contained in this e-mail, including attachments, is <br>
> confidential and exclusively for the use of the intended recipient. If <br>
> you received this communication by mistake you are not authorized to <br>
> copy, send and/or publish this message and its attachments, in whole or <br>
> in part and therefore please delete this message.<br>
> <br>
> ____________________________________________________<br>
> <br>
> *SIMONE COMARI*<br>
> <br>
> /Research Fellow//<br>
> /DIN – Dept. of Industrial Engineering<br>
> Alma Mater Studiorum – University of Bologna<br>
> Via Umberto Terracini, 24, 40131 Bologna (BO), Italy<br>
> <br>
> E-mail: <a href="mailto:simone.comari2@unibo.it">simone.comari2@unibo.it</a> <<a href="mailto:simone.comari2@unibo.it">mailto:simone.comari2@unibo.it</a>><br>
> Websites:<br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.unibo.it%2Fsitoweb%2Fsimone.comari2&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574089903&sdata=EUqfPpv6cuRqCy7YAGhuFk9YohqTE2icad2ZPHxva6w%3D&reserved=0">
https://www.unibo.it/sitoweb/simone.comari2</a><br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fgrab.diem.unibo.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574099898&sdata=Y4TpM0ljCRmgKoSBG9ArHh7UxLDnPuI99HFaax63d0Q%3D&reserved=0">
http://grab.diem.unibo.it</a> <<a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fgrab.diem.unibo.it%2F&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574099898&sdata=A8t%2FHvkdsjukEDASCmEKKow36jiAwxStyZHQ4rFsfZA%3D&reserved=0">http://grab.diem.unibo.it/</a>><br>
> <br>
> ------------------------------------------------------------------------<br>
> <br>
> *Da:*Viola Roberto <<a href="mailto:roberto.viola@systemceramics.com%20%0b">roberto.viola@systemceramics.com
<br>
</a>> <<a href="mailto:roberto.viola@systemceramics.com">mailto:roberto.viola@systemceramics.com</a>>><br>
> *Inviato:* giovedì 23 maggio 2019 08:00<br>
> *A:* Simone Comari; <a href="mailto:etherlab-users@etherlab.org">etherlab-users@etherlab.org</a>
<br>
> <<a href="mailto:etherlab-users@etherlab.org">mailto:etherlab-users@etherlab.org</a>><br>
> *Oggetto:* R: System randomly freezes in multi-thread Qt application <br>
> with a RT process<br>
> <br>
> Hi Simone, just a quick hint in order to understand the freeze: try to <br>
> run the setup inside a VM (kvm or virtualbox) in order to catch the <br>
> serial log from the kernel or, if you have a UART avaiable on your <br>
> system, directly from it.<br>
> <br>
> In this way we should try to understand the issue better.<br>
> <br>
> R.<br>
> <br>
> *Da:*etherlab-users [<a href="mailto:etherlab-users-bounces@etherlab.org">mailto:etherlab-users-bounces@etherlab.org</a>] *Per
<br>
> conto di *Simone Comari<br>
> *Inviato:* mercoledì 22 maggio 2019 18:52<br>
> *A:* <a href="mailto:etherlab-users@etherlab.org">etherlab-users@etherlab.org</a> <<a href="mailto:etherlab-users@etherlab.org">mailto:etherlab-users@etherlab.org</a>><br>
> *Oggetto:* [etherlab-users] System randomly freezes in multi-thread Qt <br>
> application with a RT process<br>
> <br>
> Hi all,<br>
> <br>
> I am a young research fellow at the university of Bologna and I just <br>
> started working with EtherCAT technology and RT systems yet, so please <br>
> forgive me if I misuse words or I'm not precise enough.<br>
> <br>
> <br>
> First, I'll try to describe my setup:<br>
> <br>
> * Ubuntu 16.04.6 with patched fully preemptible RT kernel 4.13.13-rt5<br>
> * Qt 5.12.2<br>
> * PCI driver e1000e<br>
> * Ethercat master running on this Linux RT<br>
> * Elmo GOLD SOLO WHISTLE Drives (ethercat slaves) <br>
> <br>
> Secondly, a brief outline of my software architecture:<br>
> <br>
> * POSIX threads<br>
> * Qt-based GUI running on a non-RT thread<br>
> * Ethercat network setup (ethercat master and slaves init) done in the<br>
> same non-RT thread<br>
> * If initialization is successful, start a new RT-thread in charge of<br>
> handling all ethercat-related functionalities (read/write/status-check).<br>
> * Shared resources between RT and non-RT ones handled with<br>
> pthread_mutex (even if I'm not 100% sure I'm using it correctly)<br>
> * Implementation of our generic ethercat master can be found here<br>
> <<a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2FUNIBO-GRABLab%2Fgrab_common%2Fblob%2Fe5278b6fe611654bfa84c951d8b77e56ebbc8fa9%2Flibgrabec%2Fsrc%2Fethercatmaster.cpp&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574099898&sdata=nLzX%2FT5amL34j0oL%2FHnnDmgMC4SfVd5h5jpEo%2FdMhKs%3D&reserved=0">https://github.com/UNIBO-GRABLab/grab_common/blob/e5278b6fe611654bfa84c951d8b77e56ebbc8fa9/libgrabec/src/ethercatmaster.cpp</a>><br>
> <br>
> <br>
> Problem description:<br>
> <br>
> * Once the ethercat network is setup and the RT thread is started,<br>
> quite randomly the system freezes without errors of any sorts.<br>
> Sometimes it happens when motors are enabled and operational,<br>
> sometimes when they are enabled and idle, sometimes even if they are<br>
> disabled. It is not reproducible and I couldn't link it to any<br>
> particular step in my application. Sometimes it happens even if I<br>
> simply start it, but always after successful initialization.<br>
> * Even when I manage to close the application, next time I try to run<br>
> it it tells me that master is busy and ec_e1000e is in use. Only<br>
> solution is to manually hard-shut-down the PC.<br>
> * Other thing I noticed is that even if the main thread (the GUI one,<br>
> so non-RT) is closed, the child RT-thread stays running with<br>
> status D (uninterruptible sleep) blocking a great deal of CPU (that<br>
> is why probably the whole system freezes).<br>
> * We tried with different computers (both laptop and desktop) to<br>
> exclude a platform's dependency, but the issue remains.<br>
> <br>
> Please let me know if there is any missing important information that <br>
> can help understanding the problem.<br>
> <br>
> Thank you a lot for the support.<br>
> <br>
> Best regards,<br>
> <br>
> Simone<br>
> <br>
> Roberto Viola<br>
> <br>
> Technical Dept<br>
> <br>
> +39 0536836680<br>
> <br>
> *SYSTEM CERAMICS S.p.A.*<br>
> <br>
> Via Ghiarola Vecchia, 73<br>
> <br>
> 41042 Fiorano (Mo) ITALY<br>
> <br>
> +39 0536 836111<br>
> <br>
> <a href="mailto:info@system-electronics.it">info@system-electronics.it</a> <<a href="mailto:info@system-electronics.it">mailto:info@system-electronics.it</a>><br>
> <br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.system-electronics.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574109901&sdata=lymkycpa4CF1VQmrLTiFHVv6ugLTyyTEjrDK3WTcWng%3D&reserved=0">
www.system-electronics.it</a> <<a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.system-electronics.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574109901&sdata=lymkycpa4CF1VQmrLTiFHVv6ugLTyyTEjrDK3WTcWng%3D&reserved=0">http://www.system-electronics.it</a>><br>
> <br>
> ------------------------------------------------------------------------<br>
> <br>
> Le informazioni contenute in questa email, inclusi i suoi allegati, sono <br>
> riservate e ad uso esclusivo del destinatario. Qualora le fosse <br>
> pervenuta per errore, lei non è autorizzato a copiare, inoltrare e/o <br>
> rendere nota questa email e i suoi allegati, totalmente o parzialmente, <br>
> e pertanto la preghiamo di cancellarla immediatamente senza visionarne <br>
> il contenuto e gli allegati.<br>
> <br>
> Avvertenza: la presente casella e-mail ed i messaggi da essa derivanti, <br>
> sono di esclusivo utilizzo aziendale /lavorativo e mai personale.<br>
> <br>
> Risposte al presente messaggio: si avvisa il destinatario che eventuali <br>
> sue risposte, potranno essere lette dall’intera azienda /ufficio <br>
> /reparto di appartenenza del mittente.<br>
> <br>
> The information contained in this e-mail, including attachments, is <br>
> confidential and exclusively for the use of the intended recipient. If <br>
> you received this communication by mistake you are not authorized to <br>
> copy, send and/or publish this message and its attachments, in whole or <br>
> in part and therefore please delete this message.<br>
> <br>
> ____________________________________________________<br>
> <br>
> *SIMONE COMARI*<br>
> <br>
> /Research Fellow//<br>
> /DIN – Dept. of Industrial Engineering<br>
> Alma Mater Studiorum – University of Bologna<br>
> Via Umberto Terracini, 24, 40131 Bologna (BO), Italy<br>
> <br>
> E-mail: <a href="mailto:simone.comari2@unibo.it">simone.comari2@unibo.it</a> <<a href="mailto:simone.comari2@unibo.it">mailto:simone.comari2@unibo.it</a>><br>
> Websites:<br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.unibo.it%2Fsitoweb%2Fsimone.comari2&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574119895&sdata=3nqladKWFUFYASWPxSYwXI7HG%2F29hgRhpqVugdaTX5g%3D&reserved=0">
https://www.unibo.it/sitoweb/simone.comari2</a><br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fgrab.diem.unibo.it&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574119895&sdata=ShGD3zm4rfhvdcJ9MGtqPW0qX6iCWUF9gN60H10vg%2Fg%3D&reserved=0">
http://grab.diem.unibo.it</a> <<a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Fgrab.diem.unibo.it%2F&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574129890&sdata=35ziaS8cTncPOXqZhaAA51XJVjBIPAnBoBMC1rcji5c%3D&reserved=0">http://grab.diem.unibo.it/</a>><br>
> <br>
> <br>
> _______________________________________________<br>
> etherlab-users mailing list<br>
> <a href="mailto:etherlab-users@etherlab.org">etherlab-users@etherlab.org</a><br>
> <a href="https://eur02.safelinks.protection.outlook.com/?url=http%3A%2F%2Flists.etherlab.org%2Fmailman%2Flistinfo%2Fetherlab-users&data=02%7C01%7Cgavin.lambert%40tomra.com%7C6d22d3fa7f454d4d7a8108d6e84f490e%7C4308d118edd143008a37cfeba8ad5898%7C0%7C1%7C636951824574129890&sdata=i5MfGGtwtAD%2F9SCCxbB1wOLXkUWJ4EWA%2BQeU5hpTZ9c%3D&reserved=0">
http://lists.etherlab.org/mailman/listinfo/etherlab-users</a><br>
> <o:p></o:p></p>
</div>
</div>
</div>
</body>
</html>