Open rmpel opened 3 years ago
Yes I have also seen it a couple of times - https://raspi.tv/2013/rpi-gpio-basics-3-how-to-exit-gpio-programs-cleanly-avoid-warnings-and-protect-your-pi
There should be no need to use that command as far as I can understand - only when ending the program
If I don't use the cleanup() method it is not possible to switch between modes in test button functionality. Causes error: - A different mode has already been set! I removed it where it is not needed so maybe try newest version? Looking at your log it is all over the place, can you rewire it to GPIO24 and 3.3V?
To switch back to your plugin should not be hard, and I'm willing to do that and test it out, but, rewiring to 3.3v is kind-of a pain as the Pi is in a housing that exposes only Pin 24 and ground next to it. Is switching to 3,3v instead of ground required? or should it work fine with ground as well?
No it is not required, I was wondering if it makes any difference.
The new version does not change anything for me.
I tested my switch, now using python, with
`#!/usr/bin/env python
import RPi.GPIO as GPIO
GPIO.setmode(GPIO.BCM) INPUT_PIN = 24
GPIO.setup(INPUT_PIN, GPIO.IN, pull_up_down=GPIO.PUD_UP)
if (GPIO.input(INPUT_PIN) == GPIO.HIGH): print('HIGH') elif (GPIO.input(INPUT_PIN) == GPIO.LOW): print('LOW') else: print('undetermined')`
When filament is present, I get "LOW", when filament is out, I get "HIGH".
So, looking in the plugin code, PUD_UP is set when power=0, which is "connected to ground" in the interface, so that seems to be in order
Board Mode:GPIO/BCM Pin: 24 Sensor connected to: ground Switchtype: ...
def no_filament(self): return (GPIO.input(self.pin) + self.power + self.triggered) % 2 is not 0
so, in my case; with filament present, GPIO.input() is 0, self.power is 0 no-filament condition is when 0 + 0 + self.triggered is odd. therefore, "have filament" condition should result in 0 value, therefore "triggered" variable should be 0, which is "triggered when open"
re-evaluate; "triggered when open" == self.triggered = 0 filament present: LOW -> 0 + 0 + 0 = 0, 0 % 2 = 0 -> no_filament(self) is false, ergo filament present. NO filament present: HIGH -> 1 + 0 + 0 = 1, 1 % 2 = 1 -> no_filament(self) is true, ergo NO filament present.
The set-up is correct.
Push button "test sensor" with filament present; "Sensor detected filament" Push button "test sensor" without filament present; "Sensor triggered"
repeated 5 times, all working perfectly.
Start print;
OctoPrint did not crash, so that is one issue less, but, got popup message
"No filament detected, print cancelled"
Restarted octoprint and tried again, again, 5 times, all the same.
I have the same problem, when resume from pause after sensor triggered, octprint crashed.
2021-02-25 08:48:27,342 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:27,605 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:27,868 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:28,133 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:28,400 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:28,666 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:28,933 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:29,201 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:29,466 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:29,731 - octoprint.plugins.filamentsensorsimplified - INFO - Sensor was triggered
2021-02-25 08:48:49,959 - octoprint.util.comm - INFO - Pausing/resuming job on behalf of user disttrack
2021-02-25 08:48:49,960 - octoprint.util.comm - INFO - Changing monitoring state from "Paused" to "Resuming"
2021-02-25 08:48:49,991 - octoprint.printer.standard.job - INFO - Print job resumed - origin: local, path: Untitled.gcode, owner: disttrack, user: disttrack
2021-02-25 08:48:49,996 - octoprint.plugins.filamentsensorsimplified - INFO - PrintResumed: Enabling filament sensor.
2021-02-25 08:48:50,003 - octoprint.plugins.filamentsensorsimplified - INFO - PrintResumed: Disabling filament sensor.
2021-02-25 08:48:50,168 - octoprint.util.comm - INFO - Changing monitoring state from "Resuming" to "Printing"
2021-02-25 08:48:22,597 - octoprint.startup - INFO - ******************************************************************************
2021-02-25 08:48:22,600 - octoprint.startup - INFO - Starting OctoPrint 1.5.3
2021-02-25 08:48:22,601 - octoprint.startup - INFO - ******************************************************************************
Hi I am writing in this issue because I think my problem is related(or the same). After I started using Filament Sensor Simplified I started having Octoprint crashes after the print finishes. It happens most of the time but not every time. If I login through SSH and restart Octoprint from the command line everything is ok. I have had this problem with other filament sensor plugins and after searching I found this as the probable reason: https://github.com/kontakt/Octoprint-Filament-Reloaded/issues/54 however pretty much every other filament sensor plugin is abandoned and there is no fix in them... Is it possible that this is the reason for this issue?
I'm having the same problem, all the wiring looks ok, using the test button reports filament detected or triggered as I'd expect it to. Try to start a print and it stops with a filament out error, telling it to resume crashes octoprint.
I also notice that even if filament is present I get a triggered message after a reboot, testing again will say filament found correctly.
I'm also using gpio 24 and the gnd pin next to it.
The Pi is running octoprint and has a pi camera installed. nothing else.
@LuckyX182 is this not fixed in the latest version?
body, table, td, a { font-family: 'Open Sans', 'Trebuchet MS', Trebuchet, sans-serif !important; font-size: 12px; } table.footer tr td { vertical-align: bottom; white-space: nowrap; } table.footer tr td, table.footer tr td a { color: #0365dd; font-weight: 500; font-size: 18px; text-decoration: none; } table.footer tr td a a { line-height: 30px; }
Geachte lezer,
In verband met vakantie ben ik niet in de gelegenheid uw email te beantwoorden. Voor dringende zaken verzoek ik u contact op te nemen met mijn collega's via @.*** of 030-2640605. Vanaf 6 September ben ik weer aanwezig. Met vriendelijke groet, Remon Pel
www.clearsite.nl | 030 264 06 05 | bekijk ons werk
Last update was in Jan, I reported it 22 days ago, so no, it happens in the latest release.
@TheRobotFactory and you are running a clean octopi image or is it a custom install?
I'm running a clean octopi image (actually two of them, one each on two different printers) same issue on both printers.
Other plugins installed are...
Arc-Welder BLTouch Cura Thumbnails DisplayLayerProgress FileManager Marlin EEPROM Editor Preheat Button Pushover
Disabling all other plugins during testing of the filament sensor made no difference to the results.
Strange I running it the same way although on a different pin.
Does it crash on print start or when you remove filament. Try and give me and step by step guide on how to recreate and also the OctoPrint log file.
What pins are you using? I'll move mine and see if it makes a difference, the other people with the same problem are all using the same pins as me.
I'll try your pins and document step by step with my pins over the weekend.
I'm using gpio/pcm mode and pin 18 and ground on the one next to it
@TheRobotFactory any news?
Yes, sorry for not getting back sooner, I tested this last weekend. I took photos as I went. Here's my filament sensor Wired to my Raspberry Pi. My Octoprint settings
This is what happens when I test with filament Pull the filament
Seems perfect click the print button then
Have to reboot the pi to get it back. Moved the pins to here, updated the settings and tried again same thing happened again.
I looped around this a few times not really knowing what to do to get it working right, then gave up and wired the runout sensors to the printer mainboards directly (which included new cables with three wires not two) and built new versions of marlin with runout detection enabled.
There was one issue doing that, the two wires were plugged into the runout sensor where +V and GND should be, not GND and S so I had to change the wiring at the sensor end to get it working when I added the +v wire.
I don't know if that could be the problem with the setup of this, I don't see how, there was no voltage present using only the two wires, and a continuity tester reads open circuit/closed circuit when the switch is triggered.
Maybe you can test by moving the outside wire on your filament sensor to the other side of the plug and see if it starts crashing the pi?
Whatever. I now have two printers with two working runout sensors so I'm happy and octoprint is not involved at all so I wont be using this plugin going forward.
I can't recreate it but if you could I would really like to see the octorprint log (octoprint.log)
https://community.octoprint.org/t/where-can-i-find-octoprints-and-octopis-log-files/299
I would if I could but I switched over on the 22nd and Octoprint only keeps logs for a week so I can only go back to the 25th.
On Aug 31, 2021, at 13:58, LazeMSS @.***> wrote:
I can't recreate it but if you could I would really like to see the octorprint log (octoprint.log)
https://community.octoprint.org/t/where-can-i-find-octoprints-and-octopis-log-files/299 https://community.octoprint.org/t/where-can-i-find-octoprints-and-octopis-log-files/299 — You are receiving this because you were mentioned. Reply to this email directly, view it on GitHub https://github.com/LuckyX182/Filament_sensor_simplified/issues/23#issuecomment-909516014, or unsubscribe https://github.com/notifications/unsubscribe-auth/AAADDULR7GBYZI74RFAFOGLT7UQ5TANCNFSM4VMOWFLQ.
@TheRobotFactory if you rewire it :)
During set-up I see the "filament detected" and "triggered" correctly when using the test button, but as soon as I start a print -- with filament detected, of course -- a message "printer ran out of filament" is shown and octoprint crashes.
My switch is connected to pins 18 and 20 (GPIO 24 and Ground)
during start and tests, this shows up in the log;
2020-12-28 21:40:12,900 - py.warnings - WARNING - /home/pi/oprint/local/lib/python2.7/site-packages/octoprint_filamentsensorsimplified/__init__.py:125: RuntimeWarning: No channels have been set up yet - nothing to clean up! Try cleaning up at the end of your program instead! GPIO.cleanup()
when starting a print, this happens;
octoprint is now completely frozen, RasPi needs a reboot and the printer (Stock Melzi board) needs a reset, otherwise serial connection handshake fails.
please advise...
thank you!
Remon.
Additional:
when I read the pin with
gpio -g read 24
I correctly get1
when filament is present, and0
when filament is out. same withgpio -1 read 18
so I know the port definitely is 18 (board) 24 (BCM).