Working on the buffer issues. It looks like the issue is a failure (on
the Raduino side) to check for availability of character in the Serial port, before reading the serial port. Note, need to see if this is a weakness on the Teensy (IOP) side as well.
This commit is contained in:
parent
20e1eda140
commit
f588a89ee7
@ -76,6 +76,8 @@ unsigned int skipTimeCount = 0;
|
|||||||
byte CAT_BUFF[34];
|
byte CAT_BUFF[34];
|
||||||
byte CAT_SNDBUFF[34];
|
byte CAT_SNDBUFF[34];
|
||||||
|
|
||||||
|
byte error_buf[17];
|
||||||
|
|
||||||
void SendCatData(byte sendCount)
|
void SendCatData(byte sendCount)
|
||||||
{
|
{
|
||||||
// KC4UPR--uBITX IOP: Adding an additional byte at the beginning that
|
// KC4UPR--uBITX IOP: Adding an additional byte at the beginning that
|
||||||
@ -811,7 +813,7 @@ byte rxBufferCheckCount = 0;
|
|||||||
//Prevent Stack Overflow
|
//Prevent Stack Overflow
|
||||||
byte isProcessCheck_Cat = 0;
|
byte isProcessCheck_Cat = 0;
|
||||||
|
|
||||||
char iopStatusWindow[4] = " "; // may need to move this if it's not visible to ubitx_lcd_1602
|
//char iopStatusWindow[4] = " "; // may need to move this if it's not visible to ubitx_lcd_1602
|
||||||
char iopMenuDisplay[17] = " ";
|
char iopMenuDisplay[17] = " ";
|
||||||
|
|
||||||
// KC4UPR - these are used to delay the display of the Smeter, if the
|
// KC4UPR - these are used to delay the display of the Smeter, if the
|
||||||
@ -820,7 +822,6 @@ char iopMenuDisplay[17] = " ";
|
|||||||
//#define SMETER_DELAY_TIME 5000
|
//#define SMETER_DELAY_TIME 5000
|
||||||
//bool displaySmeter = true;
|
//bool displaySmeter = true;
|
||||||
//int delaySmeter;
|
//int delaySmeter;
|
||||||
int delayTopLine = 0;
|
|
||||||
int stateTopLine = 0;
|
int stateTopLine = 0;
|
||||||
|
|
||||||
//fromType normal : 0, TX : 1, CW_STRAIGHT : 2, CW_PADDLE : 3, CW_AUTOMODE : 4
|
//fromType normal : 0, TX : 1, CW_STRAIGHT : 2, CW_PADDLE : 3, CW_AUTOMODE : 4
|
||||||
@ -871,7 +872,7 @@ void Check_Cat(byte fromType)
|
|||||||
// Will adjust based on readlength
|
// Will adjust based on readlength
|
||||||
byte first = Serial.read();
|
byte first = Serial.read();
|
||||||
readPrefix = byteToPrefix(first);
|
readPrefix = byteToPrefix(first);
|
||||||
readLength = byteToLength(first);
|
readLength = byteToLength(first);
|
||||||
for (int i = 0; i < readLength; i++) {
|
for (int i = 0; i < readLength; i++) {
|
||||||
CAT_BUFF[i] = Serial.read();
|
CAT_BUFF[i] = Serial.read();
|
||||||
}
|
}
|
||||||
@ -904,17 +905,18 @@ void Check_Cat(byte fromType)
|
|||||||
|
|
||||||
case IOP_MENU_DISPLAY_MSG:
|
case IOP_MENU_DISPLAY_MSG:
|
||||||
for (int i = 0; i < 16; i++) {
|
for (int i = 0; i < 16; i++) {
|
||||||
iopMenuDisplay[i] = msg.data[i+1];
|
iopMenuDisplay[i] = msg.data[i];
|
||||||
}
|
|
||||||
if (int8_t(msg.data[0]) == 0) {
|
|
||||||
stateTopLine = 4;
|
|
||||||
} else if (int8_t(msg.data[0]) < 0) {
|
|
||||||
stateTopLine = 0;
|
|
||||||
} else { // > 0
|
|
||||||
delayTopLine = millis() + (int8_t(msg.data[0]) * 1000);
|
|
||||||
stateTopLine = 2;
|
|
||||||
}
|
}
|
||||||
|
stateTopLine = 2;
|
||||||
|
sprintf(error_buf, "# recv'd: %3d", readLength);
|
||||||
|
sendIOPDebugMessage(error_buf);
|
||||||
|
sendIOPDebugMessage(iopMenuDisplay);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case IOP_MENU_INACTIVE_MSG:
|
||||||
|
stateTopLine = 0;
|
||||||
|
line2DisplayStatus = 0; // trying to force an update
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (readPrefix == CAT_PREFIX) {
|
} else if (readPrefix == CAT_PREFIX) {
|
||||||
@ -1020,5 +1022,6 @@ void Init_Cat(long baud, int portConfig)
|
|||||||
|
|
||||||
// At start, immediately send mode to IOP. Currently, IOP has no way to
|
// At start, immediately send mode to IOP. Currently, IOP has no way to
|
||||||
// request the mode.
|
// request the mode.
|
||||||
iopSendMode(cwMode, isUSB, digiMode, isTest);
|
// Moving this to main setup loop. Here, it may actually occur before the Raduino knows its mode!
|
||||||
|
//iopSendMode(cwMode, isUSB, digiMode, isTest);
|
||||||
}
|
}
|
||||||
|
@ -1453,6 +1453,8 @@ void setup()
|
|||||||
factory_alignment();
|
factory_alignment();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
iopSendMode(cwMode, isUSB, digiMode, isTest);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Auto save Frequency and Mode with Protected eeprom life by KD8CEC
|
//Auto save Frequency and Mode with Protected eeprom life by KD8CEC
|
||||||
|
@ -531,22 +531,12 @@ void updateLine2Buffer(char displayType)
|
|||||||
{
|
{
|
||||||
unsigned long tmpFreq = 0;
|
unsigned long tmpFreq = 0;
|
||||||
|
|
||||||
if ((stateTopLine == 2) || (stateTopLine == 4)) {
|
if (stateTopLine == 2) {
|
||||||
strcpy(line2Buffer, iopMenuDisplay);
|
strncpy(line2Buffer, iopMenuDisplay, 16);
|
||||||
if (stateTopLine == 4) {
|
stateTopLine = 1;
|
||||||
stateTopLine = 3;
|
|
||||||
} else {
|
|
||||||
stateTopLine = 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (stateTopLine == 3) {
|
if (stateTopLine == 1) {
|
||||||
return;
|
return;
|
||||||
} else if (stateTopLine == 1) {
|
|
||||||
if (delayTopLine < millis()) {
|
|
||||||
stateTopLine = 0;
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ritOn)
|
if (ritOn)
|
||||||
|
Loading…
Reference in New Issue
Block a user