First Test env
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
// Arduino Libraries
|
||||
#include <Arduino.h>
|
||||
#include <DebugLog.h>
|
||||
#include "utils.h"
|
||||
|
||||
// ISR
|
||||
#include "isr.h"
|
||||
@@ -14,15 +15,27 @@
|
||||
static bool rt_task_running = true;
|
||||
const auto spark_timeout_max = 1; // convert to microsecond timer
|
||||
|
||||
// RT task parameters
|
||||
struct rtTaskParams {
|
||||
bool rt_running;
|
||||
Devices *dev;
|
||||
};
|
||||
|
||||
void ignitionA_task(void *pvParameters) {
|
||||
|
||||
if (!pvParameters) {
|
||||
LOG_ERROR("Null device parameters");
|
||||
LOG_ERROR("Null task parameters");
|
||||
vTaskDelete(NULL);
|
||||
}
|
||||
|
||||
Devices* dev = (Devices*) pvParameters;
|
||||
ADS1256* adc = dev->adc;
|
||||
// Task Parameters and Devices
|
||||
rtTaskParams* params = (rtTaskParams*) pvParameters;
|
||||
Devices* dev = (Devices*) params->dev;
|
||||
ADS1256* adc = dev->adc_a;
|
||||
|
||||
// Global task variables
|
||||
uint32_t pickup_flag = 0;
|
||||
uint32_t spark_flag = 0;
|
||||
|
||||
// Ignition A Interrupts
|
||||
attachInterrupt(TRIG_A12P, trig_isr_a, RISING);
|
||||
@@ -32,24 +45,37 @@ void ignitionA_task(void *pvParameters) {
|
||||
attachInterrupt(SPARK_A12, spark_a, RISING);
|
||||
attachInterrupt(SPARK_A34, spark_a, RISING);
|
||||
|
||||
uint32_t pickup_flag;
|
||||
uint32_t spark_flag;
|
||||
|
||||
while (rt_task_running) {
|
||||
// WAIT FOR PICKUP SIGNAL
|
||||
xTaskNotifyWait(
|
||||
0x00, // non pulire all'ingresso
|
||||
0x000000FF, // pulisci i primi 8 bit
|
||||
ULONG_MAX, // non pulire all'ingresso
|
||||
ULONG_MAX, // pulisci i primi 8 bit
|
||||
&pickup_flag, // valore ricevuto
|
||||
portMAX_DELAY
|
||||
);
|
||||
LOG_ERROR("Pickup Interrupt Status", printBits(pickup_flag).c_str());
|
||||
if (!names.contains(pickup_flag)) {
|
||||
continue;
|
||||
} else {
|
||||
LOG_INFO("Pickup Trigger: ", names.at(pickup_flag));
|
||||
}
|
||||
// WAIT FOR SPARK TO HAPPEN
|
||||
auto spark_timeout = xTaskNotifyWait(
|
||||
0x00, // non pulire all'ingresso
|
||||
0x0000FF00, // pulisci gli 8 bit successivi
|
||||
ULONG_MAX, // non pulire all'ingresso
|
||||
ULONG_MAX, // pulisci gli 8 bit successivi
|
||||
&spark_flag, // valore ricevuto
|
||||
spark_timeout_max
|
||||
);
|
||||
if (spark_timeout == pdPASS){ //otherwise timeout
|
||||
LOG_ERROR("Spark Interrupt Status", printBits(spark_flag).c_str());
|
||||
if (!names.contains(spark_flag)) {
|
||||
continue;
|
||||
} else {
|
||||
LOG_INFO("Spark Trigger:", names.at(spark_flag));
|
||||
}
|
||||
} else {
|
||||
LOG_INFO("Spark Timeout");
|
||||
}
|
||||
|
||||
// A trigger from pickup 12 is followed by a spark event on 34 or vice versa pickup 34 triggers spark on 12
|
||||
if ((pickup_flag == TRIG_FLAG_A12P || pickup_flag == TRIG_FLAG_A12N) && spark_flag != SPARK_A12) {
|
||||
@@ -79,11 +105,13 @@ void ignitionA_task(void *pvParameters) {
|
||||
case TRIG_FLAG_A12P:
|
||||
case TRIG_FLAG_A34P:
|
||||
{
|
||||
LOG_INFO("Trigger Pickup POSITIVE");
|
||||
// Timeout not occourred, expected POSITIVE edge spark OCCOURRED
|
||||
if (spark_timeout == pdPASS) {
|
||||
c->spark_delay = c->spark_time - c->trig_time;
|
||||
c->soft_start_status = softStartStatus::NORMAL; // because spark on positive edge
|
||||
c->spark_status = sparkStatus::SPARK_POS_OK; // do not wait for spark on negative edge
|
||||
LOG_INFO("Trigger Spark POSITIVE");
|
||||
}
|
||||
// Timeout occourred, expected POSITIVE edge spark NOT OCCOURRED
|
||||
else if (spark_timeout == pdFAIL) {
|
||||
@@ -98,11 +126,13 @@ void ignitionA_task(void *pvParameters) {
|
||||
case TRIG_FLAG_A34N:
|
||||
{
|
||||
const bool expected_negative12 = c->spark_status == sparkStatus::SPARK_NEG_WAIT;
|
||||
LOG_INFO("Trigger Pickup NEGATIVE");
|
||||
// Timeout not occourred, expected NEGATIVE edge spark OCCOURRED
|
||||
if (spark_timeout == pdPASS && expected_negative12) {
|
||||
c->spark_delay = c->spark_time - c->trig_time;
|
||||
c->soft_start_status = softStartStatus::SOFT_START;
|
||||
c->spark_status == sparkStatus::SPARK_NEG_OK;
|
||||
LOG_INFO("Trigger Spark NEGATIVE");
|
||||
}
|
||||
// Timeout occourred, expected POSITIVE edge spark NOT OCCOURRED
|
||||
else if (spark_timeout == pdFAIL && expected_negative12) {
|
||||
@@ -125,18 +155,27 @@ void ignitionA_task(void *pvParameters) {
|
||||
if (new_data) {
|
||||
vTaskDelay(pdMS_TO_TICKS(1)); // delay 1ms to allow peak detectors to charge for negative cycle
|
||||
// read adc channels: pickup12, out12 [ pos + neg ]
|
||||
ignA_status.coils12.pickup_volts = adcReadChannel(adc, IN_A12_P);
|
||||
ignA_status.coils12.output_volts = adcReadChannel(adc, PICKUP_OUT_A12);
|
||||
ignA_status.coils34.pickup_volts = adcReadChannel(adc, PICKUP_IN_A34);
|
||||
ignA_status.coils34.output_volts = adcReadChannel(adc, PICKUP_OUT_A34);
|
||||
// reset peak detectors -> gli output sono sull'expander
|
||||
|
||||
//digitalWrite(RST_A12P, HIGH);
|
||||
//digitalWrite(RST_A12N, HIGH);
|
||||
//vTaskDelay(pdMS_TO_TICKS(1));
|
||||
//digitalWrite(RST_A12P, HIGH);
|
||||
//digitalWrite(RST_A12N, HIGH);
|
||||
|
||||
if (adc) // read only if adc initialized
|
||||
{
|
||||
ignA_status.coils12.pickup_volts = adcReadChannel(adc, ADC_A_DRDY, IN_A12_P);
|
||||
ignA_status.coils12.output_volts = adcReadChannel(adc, ADC_A_DRDY, IN_A12_N);
|
||||
ignA_status.coils34.pickup_volts = adcReadChannel(adc, ADC_A_DRDY, IN_A34_P);
|
||||
ignA_status.coils34.output_volts = adcReadChannel(adc, ADC_A_DRDY, IN_A34_N);
|
||||
} else {
|
||||
LOG_WARN("ADC not initialized, skipping conversion");
|
||||
}
|
||||
// reset peak detectors -> gli output sono sull'expander, temporaneo uso il PC del pot non collegato
|
||||
digitalWrite(POT_A_CS, HIGH);
|
||||
// digitalWrite(RST_A12P, HIGH);
|
||||
// digitalWrite(RST_A12N, HIGH);
|
||||
// digitalWrite(RST_A34P, HIGH);
|
||||
// digitalWrite(RST_A34N, HIGH);
|
||||
vTaskDelay(1);
|
||||
digitalWrite(POT_A_CS, HIGH);
|
||||
// digitalWrite(RST_A12P, LOW);
|
||||
// digitalWrite(RST_A12N, LOW);
|
||||
// digitalWrite(RST_A34P, LOW);
|
||||
// digitalWrite(RST_A34N, LOW);
|
||||
// save on circluar buffer 12
|
||||
}
|
||||
|
||||
@@ -153,6 +192,7 @@ void ignitionA_task(void *pvParameters) {
|
||||
vTaskDelete(NULL);
|
||||
}
|
||||
|
||||
#ifndef TEST
|
||||
void ignitionB_task(void *pvParameters) {
|
||||
uint32_t notifiedValue;
|
||||
// Ignition B Interrupts
|
||||
@@ -184,4 +224,5 @@ void ignitionB_task(void *pvParameters) {
|
||||
LOG_ERROR("Invalid B Interrupt: ", notifiedValue);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user