Hello all,

i try to read some SDOs from a slave, the PDOs are limited and that values need 
not to be updated with high frequency.

My first trial was using the function "ecrt_master_sdo_upload" in a non 
realtime task.
Problem here besides of the blocking behaviour is, that it needs the slave 
position and not its alias,
which i think is a problem in case of dynamically connected/disconnected slaves.

So i tried using the methods "ecrt_slave_config_create_sdo_request, 
ecrt_sdo_request_timeout ,ecrt_sdo_request_read, ecrt_sdo_request_state, 
ecrt_sdo_request_data"
in the realtime task.
That works, but with this i see a process "EtherCAT-OP" in the task list with a 
cpu load of more than 20%, while my test application consumes about 1%.
This is for reading only one SDO. Without reading the SDO "EtherCAT-OP" is also 
at about 1% load.

So my question, does reading one SDO really cause this high cpu load? Is there 
something wrong? Or am i on a totally wrong way to read some SDOs?

My test application is mainly derived from the "user" example, of course i can 
share the source if of interest.
It uses a cycle time of 5ms, so it should be not too fast.
It runs on a plc (Cortex A8) with Preempt_rt patch, etherCAT version is 1.6.1.
There are 4 slaves connected, 3 Beckhoff and one NORD inverter, from which I 
need to read the SDOs.

I really appreciate receiving some tips!

Best regards
Franz
-- 
Etherlab-users mailing list
Etherlab-users@etherlab.org
https://lists.etherlab.org/mailman/listinfo/etherlab-users

Reply via email to