How do .comp files work?
- AgentWD40
- Topic Author
- Offline
- Platinum Member
Less
More
- Posts: 334
- Thank you received: 92
29 May 2019 18:38 #135313
by AgentWD40
Okay, that was a poor analogy.
loadrt loads the component into realtime, addf selects to which thread to add it's FUNCTION(_){}.
What is the scope of functions (besides the main FUNCTION(_) {} ) defined in a .comp file?
Replied by AgentWD40 on topic How do .comp files work?
Okay, so looking at the basic hal tutorial: You use loadrt to load the component, like importing a library in c like #import <>. Then you call addf to initialize it however many times you need it, kind of like a c++ object. Right? But in the case of the plasmac it's a "singleton" so it can only be intialized once.
Okay, that was a poor analogy.
loadrt loads the component into realtime, addf selects to which thread to add it's FUNCTION(_){}.
What is the scope of functions (besides the main FUNCTION(_) {} ) defined in a .comp file?
Please Log in or Create an account to join the conversation.
- andypugh
- Offline
- Moderator
Less
More
- Posts: 23178
- Thank you received: 4864
30 May 2019 01:06 #135337
by andypugh
Replied by andypugh on topic How do .comp files work?
It might help to look at a component that is written in C rather than comp, and that exports multiple functions.
github.com/LinuxCNC/linuxcnc/blob/master...onents/mux_generic.c
This does much the same a the mux.comp files, but was written directly in C because it needs a hint more introspection, and also because I wanted it to export more than one function.
(look for the calls to "hal_export_funct"). This comp either exports "write_fp" or "write_nofp" depending on the configuration.
So the HAL codewill periodically call a different function in the code depending on the mux config. (the point being that if all data types are non-floating-point then the component is allowed to run in the base thread)
github.com/LinuxCNC/linuxcnc/blob/master...onents/mux_generic.c
This does much the same a the mux.comp files, but was written directly in C because it needs a hint more introspection, and also because I wanted it to export more than one function.
(look for the calls to "hal_export_funct"). This comp either exports "write_fp" or "write_nofp" depending on the configuration.
So the HAL code
addf mux_generic.0 servo-thread
The following user(s) said Thank You: AgentWD40
Please Log in or Create an account to join the conversation.
- rodw
- Away
- Platinum Member
Less
More
- Posts: 10833
- Thank you received: 3575
30 May 2019 01:44 - 30 May 2019 01:46 #135340
by rodw
Replied by rodw on topic How do .comp files work?
What is the scope of functions (besides the main FUNCTION(_) {} ) defined in a .comp file?
I think there are two parts to the answer. There are functions that can be defined as being part of the comp. The pid component is an example you'll probably find in your hal file already.pid.N.do−pid−calcs (uses floating-point) Does the PID calculations for control loop N.
My halloadrt pid names=pid.y,pid.y1,pid.x,pid.z addf pid.y.do-pid-calcs servo-thread addf pid.y1.do-pid-calcs servo-thread addf pid.x.do-pid-calcs servo-thread addf pid.z.do-pid-calcs servo-thread
But there is nothing wrong in using functions within a component to make the file more readable in which case they would be private to the component.
By now you've probably realised that halcompile processes a .comp C file into a format understood by the compiler (gcc I guess), compiles it and with --install, copies the object file to the correct directory where it can be found when your hal file loads it.
Last edit: 30 May 2019 01:46 by rodw.
The following user(s) said Thank You: AgentWD40
Please Log in or Create an account to join the conversation.
Time to create page: 0.084 seconds