[avr] couple the LED heartbeat to activity on the SPI bus
This commit is contained in:
parent
9c47f71514
commit
0af40cf27d
2 changed files with 23 additions and 14 deletions
|
@ -1,14 +1,20 @@
|
||||||
#if DBG > 0
|
#if DBG > 0
|
||||||
/* set LED pin high/low at the start/end of an ISR */
|
/* set LED pin high/low at the start/end of an ISR */
|
||||||
#define DBG_ISR_BEGIN PORTB |= (1<<PB0);
|
#define DBG_ISR_BEGIN() PORTB |= (1<<PB0)
|
||||||
#define DBG_ISR_END PORTB &= ~(1<<PB0);
|
#define DBG_ISR_END() PORTB &= ~(1<<PB0)
|
||||||
|
|
||||||
/* Set PB1=OC1A as output pin and toggle this pin on TIMER1 compare match */
|
/* Set PB1=OC1A as output pin and toggle this pin on TIMER1 compare match */
|
||||||
#define DBG_OC1A_TOGGLE DDRB |= (1<<DDB1); \
|
#define DBG_OC1A_TOGGLE() DDRB |= (1<<DDB1); \
|
||||||
TCCR1A |= 1<<COM1A0;
|
TCCR1A |= 1<<COM1A0
|
||||||
#else
|
|
||||||
#define DBG_ISR_BEGIN /* nothing */
|
|
||||||
#define DBG_ISR_END /* nothing */
|
|
||||||
#define DBG_OC1A_TOGGLE /* nothing */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
#define DBG_LED_ON() /* nothing */
|
||||||
|
#define DBG_LED_OFF() /* nothing */
|
||||||
|
#else
|
||||||
|
#define DBG_ISR_BEGIN() /* nothing */
|
||||||
|
#define DBG_ISR_END() /* nothing */
|
||||||
|
#define DBG_OC1A_TOGGLE() /* nothing */
|
||||||
|
|
||||||
|
/* LED behaviour in non-debugging mode */
|
||||||
|
#define DBG_LED_ON() PORTB &= ~(1<<PB0)
|
||||||
|
#define DBG_LED_OFF() PORTB |= (1<<PB0)
|
||||||
|
#endif
|
||||||
|
|
|
@ -63,11 +63,12 @@ ISR(SPI_STC_vect)
|
||||||
uint8_t spi_rx, rx, tx;
|
uint8_t spi_rx, rx, tx;
|
||||||
uint16_t spi_tx;
|
uint16_t spi_tx;
|
||||||
|
|
||||||
DBG_ISR_BEGIN
|
DBG_ISR_BEGIN();
|
||||||
|
|
||||||
// the SPI is double-buffered, requiring two NO_OPs when switching from Tx to Rx
|
// the SPI is double-buffered, requiring two NO_OPs when switching from Tx to Rx
|
||||||
if (spi_status & (SPI_NO_OP_1 | SPI_NO_OP_2)) {
|
if (spi_status & (SPI_NO_OP_1 | SPI_NO_OP_2)) {
|
||||||
spi_status--;
|
spi_status--;
|
||||||
|
DBG_LED_ON();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,9 +128,11 @@ ISR(SPI_STC_vect)
|
||||||
break;
|
break;
|
||||||
case SPI_FORWARD_TO_UART_PORT:
|
case SPI_FORWARD_TO_UART_PORT:
|
||||||
spi_status |= SPI_TO_FROM_UART;
|
spi_status |= SPI_TO_FROM_UART;
|
||||||
|
DBG_LED_OFF();
|
||||||
break;
|
break;
|
||||||
case SPI_FORWARD_TO_CTRL_PORT:
|
case SPI_FORWARD_TO_CTRL_PORT:
|
||||||
spi_status &= ~SPI_TO_FROM_UART;
|
spi_status &= ~SPI_TO_FROM_UART;
|
||||||
|
DBG_LED_OFF();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (spi_status & SPI_HIGH_HEX) {
|
if (spi_status & SPI_HIGH_HEX) {
|
||||||
|
@ -150,7 +153,7 @@ ISR(SPI_STC_vect)
|
||||||
spi_status ^= SPI_HIGH_HEX;
|
spi_status ^= SPI_HIGH_HEX;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBG_ISR_END
|
DBG_ISR_END();
|
||||||
}
|
}
|
||||||
|
|
||||||
ISR(INT0_vect)
|
ISR(INT0_vect)
|
||||||
|
@ -178,7 +181,7 @@ ISR(TIMER1_COMPA_vect)
|
||||||
{
|
{
|
||||||
uint8_t muxn_l = phy_to_log[muxn];
|
uint8_t muxn_l = phy_to_log[muxn];
|
||||||
|
|
||||||
DBG_ISR_BEGIN
|
DBG_ISR_BEGIN();
|
||||||
|
|
||||||
MacU16X16to32(state[muxn_l].nano, sensor[muxn_l].meterconst, ADC);
|
MacU16X16to32(state[muxn_l].nano, sensor[muxn_l].meterconst, ADC);
|
||||||
|
|
||||||
|
@ -212,7 +215,7 @@ ISR(TIMER1_COMPA_vect)
|
||||||
/* Start a new ADC conversion. */
|
/* Start a new ADC conversion. */
|
||||||
ADCSRA |= (1<<ADSC);
|
ADCSRA |= (1<<ADSC);
|
||||||
|
|
||||||
DBG_ISR_END
|
DBG_ISR_END();
|
||||||
}
|
}
|
||||||
|
|
||||||
ISR(ANALOG_COMP_vect)
|
ISR(ANALOG_COMP_vect)
|
||||||
|
@ -287,7 +290,7 @@ void setup_timer1(void)
|
||||||
// Enable output compare match interrupt for timer1 (DS p.136)
|
// Enable output compare match interrupt for timer1 (DS p.136)
|
||||||
TIMSK1 |= (1<<OCIE1A);
|
TIMSK1 |= (1<<OCIE1A);
|
||||||
|
|
||||||
DBG_OC1A_TOGGLE
|
DBG_OC1A_TOGGLE();
|
||||||
}
|
}
|
||||||
|
|
||||||
void setup_analog_comparator(void)
|
void setup_analog_comparator(void)
|
||||||
|
|
Loading…
Reference in a new issue