trouble accessing hal variables from custom M code

More
24 Jan 2022 21:30 #233015 by gerrg
So I've been trying to change the duty cycle of a PWM signal that I setup from a custom M code... but something's not working right. This is my first time messing with custom M codes, so i'm sure there's something small that i'm missing, I'm just not sure what that is. Here's my current setup.

In my main INI file i have this to set the location of my custom M code files:
[RS274NGC]
USER_M_PATH = /home/gerrg/linuxcnc/configs/PrintNC/m_codes/

Then I setup my PWM in a hal file. The file is being pointed to in the INI file by the way
#setup PWM generator
loadrt pwmgen ouput_type=0
addf pwmgen.update servo-thread 
addf pwmgen.make-pulses servo-thread

### ---mist signals start---

#configure PWM signals

#set to a scale from 0 to 100, and over a 2 second period
setp pwmgen.0.enable 1
setp pwmgen.0.scale 100
setp pwmgen.0.pwm-freq .5
setp pwmgen.0.value 55


#mist coolant stuff
loadrt and2 count=2
addf or2.1   servo-thread
addf and2.0 servo-thread

#setup our three inputs (physical button, M7 command, and pwm signal)
net mistOnButton <= hm2_7i76e.0.7i76.0.0.input-31 
net mistOnCmd <= iocontrol.0.coolant-mist
net mistOnPWM <= pwmgen.0.pwm

#make M7 command act on PWM signal
net mistOnCmd => and2.0.in0
net mistOnPWM => and2.0.in1

#make output signal based off PWM signal or button
net mistOnButton => or2.1.in0
net and2.0.out => or2.1.in1

net mistOutOn <= or2.1.out
net mistOutOn => hm2_7i76e.0.7i76.0.0.output-09

### ---mist signals end---

and finally, I have my M100 file (no file type, the entire file name is "M100"), and it's in the "m_codes" folder specified above
#!/bin/bash
#Intended to be run as a remapped M100 command. Used to set the pmw value for the mist system

pwmValue=$1
halcmd setp pwmgen.0.value $pwmValue

exit 0

I've tried looking at the hal meter to make sure the pwm value changes or not, and it's not changing. I can change the default value in the hal file, and restart linuxCNC and then value changes then... but so far it's not changing with the M code. Any thoughts of where i'm messing up? Thanks a bunch!

Please Log in or Create an account to join the conversation.

More
25 Jan 2022 11:12 #233051 by andypugh
I think that the word "remapped" in the M-code comment is wrong, as this is a conventional user M-code rather than a remap. (Not important, unless you have a REMAP line in the INI )

Have you set the M100 file to be executable?

If you run the M100 file from the command-line does it work? (it should, but LinuxCNC will need to be running at the same time)

Start LinuxCNC itself from the command-line in order to see error logging that might help.
linuxcnc &
(The "&" returns you to the command line after starting LinuxCNC so that you can carry on entering commands.)

Please Log in or Create an account to join the conversation.

More
25 Jan 2022 20:16 #233101 by gerrg
good point about the comment. I'll change that now. I do not have it remapped in the ini file (i'm happy to share my ini and hal files if that helps at all by the way)

If I right click on the M100 file and go to permissions, it has "Allow this file to run as a program" checked... so I think that's right.

When i run linuxcnc through the terminal with the &, I home my machine and then send a "M100 P66" command, and it says command not found. I'm glad you told me about the 'linuxcnc &" terminal command. That's very helpful for debugging!

it sounds like it's not seeing the M100 file, or least not as a command, so that's a step in the right direction towards figuring things out! Thoughts on what to check next?
Attachments:

Please Log in or Create an account to join the conversation.

More
25 Jan 2022 21:50 - 25 Jan 2022 21:51 #233111 by Todd Zuercher
When running an M1xx code from the command line, it must be executed as a bash script. So you would type "bash M100 66". (Note that you do not use the P.) And you must be in the dir the file is located.

Some other things to check because they were tripping me up just now when I was trying to test this. If you place the Mxx code files in your nc_files dir you don't have to put the custom M-code path in your INI file. Also make sure that the ini file you are editing and saving your M-code path in is actually the one that you are exicuting (this one got me), and Linuxcnc must be restarted before changes made to the config files (hal or ini) will be used. If you edit the config while Linuxcnc is running the changes will not take effect.
Last edit: 25 Jan 2022 21:51 by Todd Zuercher.

Please Log in or Create an account to join the conversation.

More
25 Jan 2022 23:14 #233115 by gerrg
Okay, so I went back out and went to my m_codes folder in the terminal again. started up linuxCNC and did "bash M100 66" and it did infact change the value (I also had it echo out the value, and that worked too. So that's good at least. I had some blank lines which were giving a problem at first, but i just deleted those and it worked fine from the terminal after that

then i went to the linuxCNC program and the MDI tab and entered "M100 P72", but the value didn't change at all. I also put a copy of the M100 file in the NC folder and tried it from there (both with and without the m-code path in the ini file), but couldn't get it to work from either place, or any combination of path in the ini file (or the entire m code path line commented out entirly). the terminal command always worked, but never worked from the MDI tab.

I don't think it's a problem, but i kept getting a message in the terminal ":numeric argument required". it would still run the bash command from the terminal though and would change the value, so it's all a step in the right direction i think.

Also, I did save all my M100 and ini files and such and restart before testing out something different. And I did double check it was the right config... but I also only have a single linuxCNC config on that machine, so that helps. Next try?
Attachments:

Please Log in or Create an account to join the conversation.

More
25 Jan 2022 23:33 #233118 by andypugh

When running an M1xx code from the command line, it must be executed as a bash script. So you would type "bash M100 66". 

The #! at the beginning should do that automatically.  A test script that I just created (to echo hello) worked that way. 

I just tried a test setup with an M100 and it all seemed to work as expected with LinuxCNC. 

Can you attach the INI file and the M100 file? 



 

Please Log in or Create an account to join the conversation.

More
26 Jan 2022 02:58 #233141 by gerrg
for sure, here they both are. I had to zip it up, because it didn't like the M100 file not having an extension
Attachments:

Please Log in or Create an account to join the conversation.

More
26 Jan 2022 09:33 #233161 by andypugh
I don't see anything obviously wrong with the files.

1) The M-code really should run as an executable, but Linux requires a dummy path in front of random executable files.
So try uncommenting the echo telltale, moving to the mcode directory and issuing the command ./M100. That should work, without the bash command.

2) It is just about possible that /bin/bash isn't the path to bash on your machine. You could try #!/bin/sh instead.

First get the script working as a standalone executable (./M100 or from hour home folder ./linuxcnc/configs/Gerrgs_PNC/m_codes/M100

Please Log in or Create an account to join the conversation.

More
26 Jan 2022 15:56 #233184 by gerrg
okay, so everything seems to work now except for the user_M_path directory. Here's what i've done to get it to work.

when using the ./M100 from the directory, it was giving me a "/bin/bash^M: bad interpreter" which looked like there was a hidden character in there. I tried editing the file from nano (just deleting that line and re-writing it) but that didn't seem to work. So then I just deleted the whole file and re-wrote it in vi  (just "sudo vi M100"), and that seemed to make it work correctly from the terminal without adding bash infront of it.

Tested it out first with the callout "USER_M_PATH = /home/gerrg/linuxcnc/configs/Gerrgs_PNC/m_codes/" in my INI file, but no sending the MDI command still didn't change anything. After commenting that line out so it points to the nc_files folder, I restarted everything (and moved new M100 file to the nc_files folder), and it worked! I might fiddle with stuff a bit more to try to get the M codes into a folder (either in the config file or the NC_files folder), but for now it works, so that's the biggest problem solved.

I typicaly use notepad++ on my windows PC to edit any text files on my linuxCNC PC, so i'm guessing that's where the extra hidden characters popped up. I'll try to find an easier work around than using vi since it's a bit funky to me, but I can at least make it work, so that's good. If anyone has any other advice, I'd be glad to hear it, but thanks everyone for helping me get this fixed!
 

Please Log in or Create an account to join the conversation.

More
26 Jan 2022 16:32 #233194 by andypugh
I use Notepad++ a fair bit, you can set it to show all characters to be sure what is going in, and choose the line end style by double clicking where it (should) say Unix (LF) on the bottom right of the window.
Maybe the file was being saved in a bizarre encoding?

Please Log in or Create an account to join the conversation.

Time to create page: 0.111 seconds
Powered by Kunena Forum