This commit is contained in:
J. Nick Koston 2023-06-09 18:30:52 -05:00
parent e3eca8b028
commit df01b002cf
No known key found for this signature in database
2 changed files with 17 additions and 38 deletions

View File

@ -23,6 +23,7 @@ namespace ratgdo {
static const char* const TAG = "ratgdo"; static const char* const TAG = "ratgdo";
static const int STARTUP_DELAY = 2000; // delay before enabling interrupts static const int STARTUP_DELAY = 2000; // delay before enabling interrupts
static const uint64_t REMOTE_ID = 0x539; static const uint64_t REMOTE_ID = 0x539;
static const uint16_t STATUS_CMD = 0x81;
void IRAM_ATTR HOT RATGDOStore::isrObstruction(RATGDOStore* arg) void IRAM_ATTR HOT RATGDOStore::isrObstruction(RATGDOStore* arg)
{ {
@ -74,7 +75,7 @@ namespace ratgdo {
ESP_LOGCONFIG(TAG, " Rolling Code Counter: %d", this->rollingCodeCounter); ESP_LOGCONFIG(TAG, " Rolling Code Counter: %d", this->rollingCodeCounter);
} }
void RATGDOComponent::readRollingCode(bool& isStatus, uint8_t& door, uint8_t& light, uint8_t& lock, uint8_t& motion, uint8_t& obstruction, uint8_t& motor, uint16_t& openings, uint8_t& button) uint16_t RATGDOComponent::readRollingCode() {
{ {
uint32_t rolling = 0; uint32_t rolling = 0;
uint64_t fixed = 0; uint64_t fixed = 0;
@ -93,36 +94,35 @@ namespace ratgdo {
byte1 = (data >> 16) & 0xff; byte1 = (data >> 16) & 0xff;
byte2 = (data >> 24) & 0xff; byte2 = (data >> 24) & 0xff;
if (cmd == 0x81) { if (cmd == STATUS_CMD) {
this->doorState = nibble;
door = nibble; this->lightState = (byte2 >> 1) & 1;
light = (byte2 >> 1) & 1; this->lockState = byte2 & 1;
lock = byte2 & 1; this->motionState = MotionState::MOTION_STATE_CLEAR; // when the status message is read, reset motion state to 0|clear
motion = MotionState::MOTION_STATE_CLEAR; // when the status message is read, reset motion state to 0|clear this->motorState = MotorState::MOTOR_STATE_OFF; // when the status message is read, reset motor state to 0|off
motor = MotorState::MOTOR_STATE_OFF; // when the status message is read, reset motor state to 0|off
// obstruction = (byte1 >> 6) & 1; // unreliable due to the time it takes to register an obstruction // obstruction = (byte1 >> 6) & 1; // unreliable due to the time it takes to register an obstruction
ESP_LOGD(TAG, "Door: %d Light: %d Lock: %d Motion: %d Obstruction: %d", door, light, lock, motion, obstruction); ESP_LOGD(TAG, "Door: %d Light: %d Lock: %d Motion: %d Obstruction: %d", door, light, lock, motion, obstruction);
isStatus = true;
} else if (cmd == 0x281) { } else if (cmd == 0x281) {
light ^= 1; // toggle bit this->lightState ^= 1; // toggle bit
ESP_LOGD(TAG, "Light: %d (toggle)", light); ESP_LOGD(TAG, "Light: %d (toggle)", this->lightState);
} else if (cmd == 0x84) { } else if (cmd == 0x84) {
ESP_LOGD(TAG, "Unknown 0x84"); ESP_LOGD(TAG, "Unknown 0x84");
} else if (cmd == 0x284) { } else if (cmd == 0x284) {
motor = MotorState::MOTOR_STATE_ON; this->motorState = MotorState::MOTOR_STATE_ON;
} else if (cmd == 0x280) { } else if (cmd == 0x280) {
button = byte1 == 1 ? ButtonState::BUTTON_STATE_PRESSED : ButtonState::BUTTON_STATE_RELEASED; this->buttonState = byte1 == 1 ? ButtonState::BUTTON_STATE_PRESSED : ButtonState::BUTTON_STATE_RELEASED;
ESP_LOGD(TAG, "Pressed: %s", byte1 == 1 ? "pressed" : "released"); ESP_LOGD(TAG, "Pressed: %s", byte1 == 1 ? "pressed" : "released");
} else if (cmd == 0x48c) { } else if (cmd == 0x48c) {
openings = (byte1 << 8) | byte2; this->openings = (byte1 << 8) | byte2;
ESP_LOGD(TAG, "Openings: %d", (byte1 << 8) | byte2); ESP_LOGD(TAG, "Openings: %d", (byte1 << 8) | byte2);
} else if (cmd == 0x285) { } else if (cmd == 0x285) {
motion = MotionState::MOTION_STATE_DETECTED; // toggle bit this->motionState = MotionState::MOTION_STATE_DETECTED; // toggle bit
ESP_LOGD(TAG, "Motion: %d (toggle)", motion); ESP_LOGD(TAG, "Motion: %d (toggle)", motion);
} else { } else {
ESP_LOGD(TAG, "Unknown command: %04x", cmd); ESP_LOGD(TAG, "Unknown command: %04x", cmd);
} }
return cmd;
} }
void RATGDOComponent::getRollingCode(cmd command) void RATGDOComponent::getRollingCode(cmd command)
@ -261,19 +261,7 @@ namespace ratgdo {
reading = false; reading = false;
msgStart = 0; msgStart = 0;
byteCount = 0; byteCount = 0;
isStatus = false; if (readRollingCode() == STATUS_CMD && this->forceUpdate_) {
readRollingCode(
isStatus,
this->doorState,
this->lightState,
this->lockState,
this->motionState,
this->obstructionState,
this->motorState,
this->openings,
this->buttonState);
if (isStatus && this->forceUpdate_) {
this->forceUpdate_ = false; this->forceUpdate_ = false;
this->previousDoorState = DoorState::DOOR_STATE_UNKNOWN; this->previousDoorState = DoorState::DOOR_STATE_UNKNOWN;
this->previousLightState = LightState::LIGHT_STATE_UNKNOWN; this->previousLightState = LightState::LIGHT_STATE_UNKNOWN;

View File

@ -134,16 +134,7 @@ namespace ratgdo {
void printRollingCode(); void printRollingCode();
void getRollingCode(cmd command); void getRollingCode(cmd command);
void readRollingCode( uint16_t readRollingCode();
bool& isStatus,
uint8_t& door,
uint8_t& light,
uint8_t& lock,
uint8_t& motion,
uint8_t& obstruction,
uint8_t& motor,
uint16_t& openings,
uint8_t& button);
void incrementRollingCodeCounter(); void incrementRollingCodeCounter();
void sendRollingCodeChanged(); void sendRollingCodeChanged();
void setRollingCodeCounter(uint32_t counter); void setRollingCodeCounter(uint32_t counter);