[avr] fix interrupt tracing and remove unneeded volatiles
This commit is contained in:
parent
b224ffdf23
commit
8813c816ff
3 changed files with 34 additions and 30 deletions
|
@ -37,16 +37,16 @@ static char ctrlTxData[CTRL_TX_BUFFER_SIZE];
|
||||||
extern uint16_t EEMEM EEPROM_version;
|
extern uint16_t EEMEM EEPROM_version;
|
||||||
extern uint16_t version;
|
extern uint16_t version;
|
||||||
|
|
||||||
extern volatile struct event_struct EEMEM EEPROM_event;
|
extern struct event_struct EEMEM EEPROM_event;
|
||||||
extern volatile struct event_struct event;
|
extern struct event_struct event;
|
||||||
|
|
||||||
extern uint8_t EEMEM EEPROM_phy_to_log[MAX_SENSORS];
|
extern uint8_t EEMEM EEPROM_phy_to_log[MAX_SENSORS];
|
||||||
extern uint8_t phy_to_log[MAX_SENSORS];
|
extern uint8_t phy_to_log[MAX_SENSORS];
|
||||||
|
|
||||||
extern volatile struct sensor_struct EEMEM EEPROM_sensor[MAX_SENSORS];
|
extern struct sensor_struct EEMEM EEPROM_sensor[MAX_SENSORS];
|
||||||
extern volatile struct sensor_struct sensor[MAX_SENSORS];
|
extern struct sensor_struct sensor[MAX_SENSORS];
|
||||||
|
|
||||||
extern volatile struct state_struct state[MAX_SENSORS];
|
extern struct state_struct state[MAX_SENSORS];
|
||||||
|
|
||||||
void ctrlInit(void)
|
void ctrlInit(void)
|
||||||
{
|
{
|
||||||
|
@ -253,7 +253,7 @@ void ctrlDecode(void)
|
||||||
|
|
||||||
void ctrlCmdGet(uint8_t cmd)
|
void ctrlCmdGet(uint8_t cmd)
|
||||||
{
|
{
|
||||||
uint8_t i;
|
uint8_t i = 0;
|
||||||
uint32_t tmp32, tmp32_bis;
|
uint32_t tmp32, tmp32_bis;
|
||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
|
@ -315,9 +315,9 @@ void ctrlCmdGet(uint8_t cmd)
|
||||||
|
|
||||||
void ctrlCmdSet(uint8_t cmd)
|
void ctrlCmdSet(uint8_t cmd)
|
||||||
{
|
{
|
||||||
uint8_t i, tmp8;
|
uint8_t i = 0, tmp8 = 0;
|
||||||
uint16_t tmp16;
|
uint16_t tmp16 = 0;
|
||||||
uint32_t tmp32;
|
uint32_t tmp32 = 0;
|
||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case 'v':
|
case 'v':
|
||||||
|
|
|
@ -35,28 +35,29 @@
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
#include "encode.h"
|
#include "encode.h"
|
||||||
|
|
||||||
volatile uint8_t spi_status, spi_high_hex;
|
register uint8_t spi_status asm("r7");
|
||||||
|
uint8_t spi_high_hex;
|
||||||
|
|
||||||
uint8_t EEMEM first_EEPROM_byte_not_used_to_protect_from_brownout_corruption = 0xbe;
|
uint8_t EEMEM first_EEPROM_byte_not_used_to_protect_from_brownout_corruption = 0xbe;
|
||||||
|
|
||||||
uint8_t EEMEM EEPROM_version[2] = {2, 1};
|
uint8_t EEMEM EEPROM_version[2] = {2, 1};
|
||||||
uint8_t version[2];
|
uint8_t version[2];
|
||||||
|
|
||||||
volatile struct event_struct EEMEM EEPROM_event = {0, 0};
|
struct event_struct EEMEM EEPROM_event = {0, 0};
|
||||||
volatile struct event_struct event;
|
struct event_struct event;
|
||||||
|
|
||||||
uint8_t EEMEM EEPROM_phy_to_log[MAX_SENSORS] = {0, 1, 2, 3, 4, 5};
|
uint8_t EEMEM EEPROM_phy_to_log[MAX_SENSORS] = {0, 1, 2, 3, 4, 5};
|
||||||
uint8_t phy_to_log[MAX_SENSORS];
|
uint8_t phy_to_log[MAX_SENSORS];
|
||||||
|
|
||||||
volatile struct sensor_struct EEMEM EEPROM_sensor[MAX_SENSORS];
|
struct sensor_struct EEMEM EEPROM_sensor[MAX_SENSORS];
|
||||||
volatile struct sensor_struct sensor[MAX_SENSORS];
|
struct sensor_struct sensor[MAX_SENSORS];
|
||||||
|
|
||||||
volatile struct state_struct state[MAX_SENSORS];
|
struct state_struct state[MAX_SENSORS];
|
||||||
|
|
||||||
volatile uint8_t muxn = 0;
|
uint8_t muxn = 0;
|
||||||
volatile uint16_t timer = 0;
|
uint16_t timer = 0;
|
||||||
|
|
||||||
volatile struct time_struct time = {0, 0};
|
struct time_struct time = {0, 0};
|
||||||
|
|
||||||
ISR(SPI_STC_vect)
|
ISR(SPI_STC_vect)
|
||||||
{
|
{
|
||||||
|
@ -68,14 +69,14 @@ ISR(SPI_STC_vect)
|
||||||
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();
|
DBG_LED_ON();
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
// do we have to transmit the first byte?
|
// do we have to transmit the first byte?
|
||||||
if (spi_status & SPI_START_TX) {
|
if (spi_status & SPI_START_TX) {
|
||||||
received_from_spi(SPI_FORWARD_TO_CTRL_PORT);
|
received_from_spi(SPI_FORWARD_TO_CTRL_PORT);
|
||||||
spi_status &= ~SPI_START_TX;
|
spi_status &= ~SPI_START_TX;
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
// are we in Tx mode?
|
// are we in Tx mode?
|
||||||
|
@ -83,7 +84,7 @@ ISR(SPI_STC_vect)
|
||||||
if (spi_status & SPI_HIGH_HEX) {
|
if (spi_status & SPI_HIGH_HEX) {
|
||||||
received_from_spi(spi_high_hex); /* actually low hex ! */
|
received_from_spi(spi_high_hex); /* actually low hex ! */
|
||||||
spi_status &= ~SPI_HIGH_HEX;
|
spi_status &= ~SPI_HIGH_HEX;
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (spi_status & SPI_TO_FROM_UART) {
|
if (spi_status & SPI_TO_FROM_UART) {
|
||||||
|
@ -91,25 +92,25 @@ ISR(SPI_STC_vect)
|
||||||
received_from_spi(SPI_END_OF_TX);
|
received_from_spi(SPI_END_OF_TX);
|
||||||
spi_status &= ~SPI_TRANSMIT;
|
spi_status &= ~SPI_TRANSMIT;
|
||||||
spi_status |= SPI_NO_OP_2;
|
spi_status |= SPI_NO_OP_2;
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (ctrlGetFromTxBuffer(&tx)) {
|
if (ctrlGetFromTxBuffer(&tx)) {
|
||||||
received_from_spi(tx);
|
received_from_spi(tx);
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
received_from_spi(SPI_FORWARD_TO_UART_PORT);
|
received_from_spi(SPI_FORWARD_TO_UART_PORT);
|
||||||
spi_status |= SPI_TO_FROM_UART;
|
spi_status |= SPI_TO_FROM_UART;
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
btoh(tx, &spi_tx, (uint8_t *)&spi_high_hex); /* actually low hex ! */
|
btoh(tx, &spi_tx, (uint8_t *)&spi_high_hex); /* actually low hex ! */
|
||||||
spi_status |= SPI_HIGH_HEX;
|
spi_status |= SPI_HIGH_HEX;
|
||||||
received_from_spi(spi_tx);
|
received_from_spi(spi_tx);
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
// we're in Rx mode
|
// we're in Rx mode
|
||||||
|
@ -143,7 +144,7 @@ ISR(SPI_STC_vect)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ctrlAddToRxBuffer(spi_rx);
|
ctrlAddToRxBuffer(spi_rx);
|
||||||
return;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -151,6 +152,7 @@ ISR(SPI_STC_vect)
|
||||||
spi_status ^= SPI_HIGH_HEX;
|
spi_status ^= SPI_HIGH_HEX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
finish:
|
||||||
DBG_ISR_END();
|
DBG_ISR_END();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -179,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);
|
||||||
|
|
||||||
|
@ -213,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)
|
||||||
|
@ -366,7 +368,6 @@ int main(void)
|
||||||
|
|
||||||
for(;;) {
|
for(;;) {
|
||||||
if (spi_status & SPI_NEW_CTRL_MSG) {
|
if (spi_status & SPI_NEW_CTRL_MSG) {
|
||||||
//ctrlRxToTxLoop();
|
|
||||||
ctrlDecode();
|
ctrlDecode();
|
||||||
spi_status &= ~SPI_NEW_CTRL_MSG;
|
spi_status &= ~SPI_NEW_CTRL_MSG;
|
||||||
}
|
}
|
||||||
|
|
|
@ -122,6 +122,9 @@ CDEFS += -D DBG=$(DBG)
|
||||||
# Warn when a function marked for inlining could not be substituted
|
# Warn when a function marked for inlining could not be substituted
|
||||||
CDEFS += -Winline
|
CDEFS += -Winline
|
||||||
|
|
||||||
|
# Inline all 'simple-enough' functions (seems to be done by default in -Os)
|
||||||
|
CDEFS += -finline-functions
|
||||||
|
|
||||||
# uncomment and adapt these line if you want different UART library buffer size
|
# uncomment and adapt these line if you want different UART library buffer size
|
||||||
CDEFS += -DUART_RX_BUFFER_SIZE=64
|
CDEFS += -DUART_RX_BUFFER_SIZE=64
|
||||||
CDEFS += -DUART_TX_BUFFER_SIZE=64
|
CDEFS += -DUART_TX_BUFFER_SIZE=64
|
||||||
|
|
Loading…
Reference in a new issue