rusefi/firmware/controllers/system/efi_output.h

117 lines
2.8 KiB
C
Raw Normal View History

2022-09-07 16:36:16 -07:00
/*
* @file efi_output.h
*
*/
#pragma once
2022-09-07 16:36:16 -07:00
#include "io_pins.h"
#include "smart_gpio.h"
// This class acts as a boolean, but has a switch counter inside
class SwitchedState {
public:
SwitchedState(int8_t *state) {
2023-08-20 14:08:33 -07:00
this->state = state;
}
// returns true if the state has been changed
bool update(bool newState);
uint16_t getCounter();
operator bool() const {
return (bool)*state;
}
private:
int8_t *state;
uint16_t counter = 0;
2023-08-20 14:08:33 -07:00
};
2022-09-07 16:36:16 -07:00
// Used if you want a function to be virtual only for unit testing purposes
#if EFI_UNIT_TEST
#define TEST_VIRTUAL virtual
#else
#define TEST_VIRTUAL
#endif
/**
* @brief Single output pin reference and state
*/
class OutputPin {
public:
2023-02-25 00:31:12 -08:00
// initializes pin & registers it in pin repository
void initPin(const char *msg, brain_pin_e brainPin, pin_output_mode_e outputMode, bool forceInitWithFatalError = false);
// same as above, with OM_DEFAULT mode
2022-09-07 16:36:16 -07:00
void initPin(const char *msg, brain_pin_e brainPin);
2023-02-25 00:31:12 -08:00
// dissociates pin from this output and un-registers it in pin repository
2022-09-07 16:36:16 -07:00
void deInit();
bool isInitialized();
bool getAndSet(int logicValue);
void setValue(const char *msg, int logicValue);
2022-09-07 16:36:16 -07:00
TEST_VIRTUAL void setValue(int logicValue);
void toggle();
bool getLogicValue() const;
brain_pin_diag_e getDiag() const;
#if EFI_GPIO_HARDWARE
ioportid_t port = 0;
uint8_t pin = 0;
#endif /* EFI_GPIO_HARDWARE */
#if EFI_UNIT_TEST
int unitTestTurnedOnCounter = 0;
#endif
brain_pin_e brainPin = Gpio::Unassigned;
#if (EFI_GPIO_HARDWARE && (BOARD_EXT_GPIOCHIPS > 0))
/* used for external pins */
bool ext = false;
#endif /* EFI_GPIO_HARDWARE */
int8_t currentLogicValue = INITIAL_PIN_STATE;
/**
* we track current pin status so that we do not touch the actual hardware if we want to write new pin bit
* which is same as current pin value. This maybe helps in case of status leds, but maybe it's a total over-engineering
*/
private:
// todo: inline this method?
2023-02-25 00:31:12 -08:00
void setDefaultPinState(pin_output_mode_e mode);
2022-09-07 16:36:16 -07:00
void setOnchipValue(int electricalValue);
// 4 byte pointer is a bit of a memory waste here
2023-02-25 00:31:12 -08:00
pin_output_mode_e mode = OM_DEFAULT;
2022-09-07 16:36:16 -07:00
};
/**
* OutputPin which is reported on Engine Sniffer
*/
class NamedOutputPin : public virtual OutputPin {
public:
NamedOutputPin();
explicit NamedOutputPin(const char *name);
virtual void setHigh(const char *msg);
virtual void setLow(const char *msg);
2022-09-07 16:36:16 -07:00
virtual void setHigh();
virtual void setLow();
const char *getName() const;
const char *getShortName() const;
/**
* @return true if pin was stopped
*/
bool stop();
// todo: char pointer is a bit of a memory waste here, we can reduce RAM usage by software-based getName() method
const char *name = nullptr;
/**
* rusEfi Engine Sniffer protocol uses these short names to reduce bytes usage
*/
const char *shortName = nullptr;
};