feat: removed event with no changed value
This commit is contained in:
@@ -1 +1 @@
|
|||||||
2.2.0
|
2.3.0
|
||||||
@@ -321,6 +321,7 @@ static void IRAM_ATTR _zh_encoder_isr_processing_task(void *pvParameter)
|
|||||||
{
|
{
|
||||||
zh_encoder_handle_t *encoder_handle = (zh_encoder_handle_t *)pvParameter;
|
zh_encoder_handle_t *encoder_handle = (zh_encoder_handle_t *)pvParameter;
|
||||||
int pcnt_count = {0};
|
int pcnt_count = {0};
|
||||||
|
bool is_value_changed = false;
|
||||||
while (xQueueReceive(_queue_handle, &pcnt_count, portMAX_DELAY) == pdTRUE)
|
while (xQueueReceive(_queue_handle, &pcnt_count, portMAX_DELAY) == pdTRUE)
|
||||||
{
|
{
|
||||||
switch (pcnt_count)
|
switch (pcnt_count)
|
||||||
@@ -333,6 +334,7 @@ static void IRAM_ATTR _zh_encoder_isr_processing_task(void *pvParameter)
|
|||||||
{
|
{
|
||||||
encoder_handle->encoder_position = encoder_handle->encoder_max_value;
|
encoder_handle->encoder_position = encoder_handle->encoder_max_value;
|
||||||
}
|
}
|
||||||
|
is_value_changed = true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ZH_ENCODER_DIRECTION_CCW:
|
case ZH_ENCODER_DIRECTION_CCW:
|
||||||
@@ -343,11 +345,15 @@ static void IRAM_ATTR _zh_encoder_isr_processing_task(void *pvParameter)
|
|||||||
{
|
{
|
||||||
encoder_handle->encoder_position = encoder_handle->encoder_min_value;
|
encoder_handle->encoder_position = encoder_handle->encoder_min_value;
|
||||||
}
|
}
|
||||||
|
is_value_changed = true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (is_value_changed == true)
|
||||||
|
{
|
||||||
|
is_value_changed = false;
|
||||||
zh_encoder_event_on_isr_t encoder_data = {0};
|
zh_encoder_event_on_isr_t encoder_data = {0};
|
||||||
encoder_data.encoder_number = encoder_handle->encoder_number;
|
encoder_data.encoder_number = encoder_handle->encoder_number;
|
||||||
encoder_data.encoder_position = encoder_handle->encoder_position;
|
encoder_data.encoder_position = encoder_handle->encoder_position;
|
||||||
@@ -357,6 +363,7 @@ static void IRAM_ATTR _zh_encoder_isr_processing_task(void *pvParameter)
|
|||||||
++_stats.event_post_error;
|
++_stats.event_post_error;
|
||||||
ZH_LOGE("Encoder isr processing failed. Failed to post interrupt event.", err);
|
ZH_LOGE("Encoder isr processing failed. Failed to post interrupt event.", err);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
_stats.min_stack_size = (uint32_t)uxTaskGetStackHighWaterMark(NULL);
|
_stats.min_stack_size = (uint32_t)uxTaskGetStackHighWaterMark(NULL);
|
||||||
}
|
}
|
||||||
vTaskDelete(NULL);
|
vTaskDelete(NULL);
|
||||||
|
|||||||
Reference in New Issue
Block a user