Fix random cutter stops (evaluateSwitch)
- use evaluatedSwitch class for position switch instead of reading gpio directly because it triggered incorrectly too often - cutter_stop() only switch to CANCELED when not in IDLE already
This commit is contained in:
parent
9600932ae8
commit
fab75661c2
@ -19,6 +19,8 @@ cutter_state_t cutter_state = cutter_state_t::IDLE;
|
|||||||
uint32_t timestamp_turnedOn;
|
uint32_t timestamp_turnedOn;
|
||||||
uint32_t msTimeout = 3000;
|
uint32_t msTimeout = 3000;
|
||||||
static const char *TAG = "cutter"; //tag for logging
|
static const char *TAG = "cutter"; //tag for logging
|
||||||
|
gpio_evaluatedSwitch POSITION_SW(GPIO_CUTTER_POS_SW, true, false); //pullup true, not inverted (switch to GND, internal pullup used)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -37,7 +39,9 @@ void cutter_start(){
|
|||||||
//========= stop =========
|
//========= stop =========
|
||||||
//========================
|
//========================
|
||||||
void cutter_stop(){
|
void cutter_stop(){
|
||||||
setState(cutter_state_t::CANCELED);
|
if(cutter_state =! cutter_state_t::IDLE){
|
||||||
|
setState(cutter_state_t::CANCELED);
|
||||||
|
}
|
||||||
//starts motor on state change
|
//starts motor on state change
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,6 +114,12 @@ bool checkTimeout(){
|
|||||||
//========================
|
//========================
|
||||||
//function that handles the cutter logic -> has to be run repeatedly
|
//function that handles the cutter logic -> has to be run repeatedly
|
||||||
void cutter_handle(){
|
void cutter_handle(){
|
||||||
|
//handle evaluated switch (position switch)
|
||||||
|
POSITION_SW.handle();
|
||||||
|
//TODO add custom thresholds once at initialization?
|
||||||
|
//POSITION_SW.minOnMs = 10;
|
||||||
|
//POSITION_SW.minOffMs = 10;
|
||||||
|
|
||||||
|
|
||||||
switch(cutter_state){
|
switch(cutter_state){
|
||||||
case cutter_state_t::IDLE:
|
case cutter_state_t::IDLE:
|
||||||
@ -120,8 +130,8 @@ void cutter_handle(){
|
|||||||
|
|
||||||
case cutter_state_t::START:
|
case cutter_state_t::START:
|
||||||
//--- moved away from idle position ---
|
//--- moved away from idle position ---
|
||||||
if (gpio_get_level(GPIO_CUTTER_POS_SW) == 0){ //switch closed
|
//if (gpio_get_level(GPIO_CUTTER_POS_SW) == 0){ //contact closed
|
||||||
//FIXME: initialize gpio as input with PULLUP somewhere
|
if (POSITION_SW.state == true) { //contact closed -> not at idle pos
|
||||||
setState(cutter_state_t::CUTTING);
|
setState(cutter_state_t::CUTTING);
|
||||||
}
|
}
|
||||||
//--- timeout ---
|
//--- timeout ---
|
||||||
@ -133,7 +143,9 @@ void cutter_handle(){
|
|||||||
|
|
||||||
case cutter_state_t::CUTTING:
|
case cutter_state_t::CUTTING:
|
||||||
//--- idle position reached ---
|
//--- idle position reached ---
|
||||||
if (gpio_get_level(GPIO_CUTTER_POS_SW) == 1){ //switch not closed
|
//if (gpio_get_level(GPIO_CUTTER_POS_SW) == 1){ //contact not closed
|
||||||
|
//TODO: add min on duration
|
||||||
|
if (POSITION_SW.state == false) { //contact open -> at idle pos
|
||||||
setState(cutter_state_t::IDLE);
|
setState(cutter_state_t::IDLE);
|
||||||
}
|
}
|
||||||
//--- timeout ---
|
//--- timeout ---
|
||||||
|
@ -6,6 +6,7 @@ extern "C"
|
|||||||
|
|
||||||
#include "buzzer.hpp"
|
#include "buzzer.hpp"
|
||||||
#include "display.hpp"
|
#include "display.hpp"
|
||||||
|
#include "gpio_evaluateSwitch.hpp"
|
||||||
|
|
||||||
|
|
||||||
//--- variables ---
|
//--- variables ---
|
||||||
|
@ -44,11 +44,11 @@ void init_gpios(){
|
|||||||
//initialize and configure ADC
|
//initialize and configure ADC
|
||||||
adc1_config_width(ADC_WIDTH_BIT_12); //=> max resolution 4096
|
adc1_config_width(ADC_WIDTH_BIT_12); //=> max resolution 4096
|
||||||
adc1_config_channel_atten(ADC_CHANNEL_POTI, ADC_ATTEN_DB_11); //max voltage
|
adc1_config_channel_atten(ADC_CHANNEL_POTI, ADC_ATTEN_DB_11); //max voltage
|
||||||
//initialize input for cutter position switch with pullup
|
////initialize input for cutter position switch with pullup (now done via evaluatedSwitch construcor)
|
||||||
gpio_pad_select_gpio(GPIO_CUTTER_POS_SW);
|
//gpio_pad_select_gpio(GPIO_CUTTER_POS_SW);
|
||||||
gpio_set_direction(GPIO_CUTTER_POS_SW, GPIO_MODE_INPUT);
|
//gpio_set_direction(GPIO_CUTTER_POS_SW, GPIO_MODE_INPUT);
|
||||||
gpio_pad_select_gpio(GPIO_CUTTER_POS_SW);
|
//gpio_pad_select_gpio(GPIO_CUTTER_POS_SW);
|
||||||
gpio_set_pull_mode(GPIO_CUTTER_POS_SW, GPIO_PULLUP_ONLY);
|
//gpio_set_pull_mode(GPIO_CUTTER_POS_SW, GPIO_PULLUP_ONLY);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user