2020-06-03 04:33:18 -07:00
|
|
|
#include <assert.h>
|
|
|
|
#include "stm32f0xx_hal.h"
|
|
|
|
#include "pcan_timestamp.h"
|
|
|
|
#include "pcan_led.h"
|
2022-01-28 05:45:15 -08:00
|
|
|
#include "pcan_varian.h"
|
2020-06-03 04:33:18 -07:00
|
|
|
|
|
|
|
static struct
|
|
|
|
{
|
|
|
|
uint16_t mode;
|
|
|
|
uint16_t arg;
|
|
|
|
uint16_t delay;
|
|
|
|
uint16_t timestamp;
|
|
|
|
uint8_t state;
|
|
|
|
}
|
|
|
|
led_mode_array[LED_TOTAL] = { 0 };
|
|
|
|
|
|
|
|
void pcan_led_init( void )
|
|
|
|
{
|
2022-01-28 05:45:15 -08:00
|
|
|
#ifdef IOPIN_TX
|
|
|
|
PIN_ENABLE_CLOCK( IOPIN_TX );
|
|
|
|
PIN_INIT( IOPIN_TX );
|
|
|
|
#endif
|
|
|
|
#ifdef IOPIN_RX
|
|
|
|
PIN_ENABLE_CLOCK( IOPIN_RX );
|
|
|
|
PIN_INIT( IOPIN_RX );
|
|
|
|
#endif
|
2020-06-03 04:33:18 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void pcan_led_set_mode( int led, int mode, uint16_t arg )
|
|
|
|
{
|
|
|
|
assert( led < LED_TOTAL );
|
2020-11-11 03:43:03 -08:00
|
|
|
uint16_t ts = pcan_timestamp_millis();
|
2020-06-03 04:33:18 -07:00
|
|
|
|
|
|
|
led_mode_array[led].mode = mode;
|
2020-11-11 03:43:03 -08:00
|
|
|
if( !led_mode_array[led].timestamp )
|
|
|
|
{
|
|
|
|
led_mode_array[led].timestamp = ts|1;
|
|
|
|
}
|
2020-06-03 04:33:18 -07:00
|
|
|
led_mode_array[led].delay = 0;
|
|
|
|
|
|
|
|
/* set guard time */
|
2020-11-11 03:43:03 -08:00
|
|
|
if( mode == LED_MODE_BLINK_FAST || mode == LED_MODE_BLINK_SLOW )
|
2020-06-03 04:33:18 -07:00
|
|
|
{
|
2020-11-11 03:43:03 -08:00
|
|
|
led_mode_array[led].delay = ( mode == LED_MODE_BLINK_FAST ) ? 50: 200;
|
|
|
|
arg = arg?(ts + arg)|1:0;
|
2020-06-03 04:33:18 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
led_mode_array[led].arg = arg;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void pcan_led_update_state( int led, uint8_t state )
|
|
|
|
{
|
|
|
|
switch( led )
|
|
|
|
{
|
2022-01-28 05:45:15 -08:00
|
|
|
#ifdef IOPIN_TX
|
2020-06-03 04:33:18 -07:00
|
|
|
case LED_CH0_TX:
|
2022-01-28 05:45:15 -08:00
|
|
|
state ? (LED_ON( IOPIN_TX )): (LED_OFF( IOPIN_TX ));
|
2020-06-03 04:33:18 -07:00
|
|
|
break;
|
2022-01-28 05:45:15 -08:00
|
|
|
#endif
|
|
|
|
#ifdef IOPIN_RX
|
2020-06-03 04:33:18 -07:00
|
|
|
case LED_CH0_RX:
|
2022-01-28 05:45:15 -08:00
|
|
|
state ? (LED_ON( IOPIN_RX )): (LED_OFF( IOPIN_RX ));
|
2020-06-03 04:33:18 -07:00
|
|
|
break;
|
2022-01-28 05:45:15 -08:00
|
|
|
#endif
|
2020-06-03 04:33:18 -07:00
|
|
|
default:
|
2022-01-28 05:45:15 -08:00
|
|
|
(void)state;
|
2020-06-03 04:33:18 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void pcan_led_poll( void )
|
|
|
|
{
|
|
|
|
uint16_t ts_ms = pcan_timestamp_millis();
|
|
|
|
|
|
|
|
for( int i = 0; i < LED_TOTAL; i++ )
|
|
|
|
{
|
|
|
|
if( !led_mode_array[i].timestamp )
|
|
|
|
continue;
|
|
|
|
if( (uint16_t)( ts_ms - led_mode_array[i].timestamp ) < led_mode_array[i].delay )
|
|
|
|
continue;
|
|
|
|
|
|
|
|
switch( led_mode_array[i].mode )
|
|
|
|
{
|
|
|
|
default:
|
|
|
|
case LED_MODE_NONE:
|
|
|
|
led_mode_array[i].timestamp = 0;
|
|
|
|
break;
|
|
|
|
case LED_MODE_OFF:
|
|
|
|
case LED_MODE_ON:
|
|
|
|
led_mode_array[i].state = ( led_mode_array[i].mode == LED_MODE_ON );
|
|
|
|
led_mode_array[i].timestamp = 0;
|
|
|
|
break;
|
|
|
|
case LED_MODE_BLINK_FAST:
|
|
|
|
case LED_MODE_BLINK_SLOW:
|
|
|
|
led_mode_array[i].state ^= 1;
|
2020-11-11 03:43:03 -08:00
|
|
|
led_mode_array[i].timestamp += led_mode_array[i].delay;
|
|
|
|
led_mode_array[i].timestamp |= 1;
|
2020-06-03 04:33:18 -07:00
|
|
|
if( led_mode_array[i].arg && ( led_mode_array[i].arg <= ts_ms ) )
|
|
|
|
{
|
2020-11-11 03:43:03 -08:00
|
|
|
pcan_led_set_mode( i, LED_MODE_OFF, 0 );
|
2020-06-03 04:33:18 -07:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
pcan_led_update_state( i, led_mode_array[i].state );
|
|
|
|
}
|
|
|
|
}
|