mirror of
https://github.com/DCC-EX/CommandStation-EX.git
synced 2025-01-11 13:21:01 +01:00
Broadcast stop/estop
Avoids directuion change in reminders
This commit is contained in:
parent
266ef01dbe
commit
fd466a5e62
8
DCC.cpp
8
DCC.cpp
@ -48,7 +48,7 @@ void DCC::begin(MotorDriver * mainDriver, MotorDriver* progDriver, byte timerNum
|
|||||||
}
|
}
|
||||||
|
|
||||||
void DCC::setThrottle( uint16_t cab, uint8_t tSpeed, bool tDirection) {
|
void DCC::setThrottle( uint16_t cab, uint8_t tSpeed, bool tDirection) {
|
||||||
byte speedCode = (tSpeed & 0x7F) + tDirection * 128; //speed codes range from 2-127 (0=stop, 1=emergency stop)
|
byte speedCode = (tSpeed & 0x7F) + tDirection * 128;
|
||||||
setThrottle2(cab, speedCode);
|
setThrottle2(cab, speedCode);
|
||||||
// retain speed for loco reminders
|
// retain speed for loco reminders
|
||||||
updateLocoReminder(cab, speedCode );
|
updateLocoReminder(cab, speedCode );
|
||||||
@ -456,8 +456,10 @@ int DCC::lookupSpeedTable(int locoId) {
|
|||||||
void DCC::updateLocoReminder(int loco, byte speedCode) {
|
void DCC::updateLocoReminder(int loco, byte speedCode) {
|
||||||
|
|
||||||
if (loco==0) {
|
if (loco==0) {
|
||||||
// broadcast message
|
// broadcast stop/estop but dont change direction
|
||||||
for (int reg = 0; reg < MAX_LOCOS; reg++) speedTable[reg].speedCode = speedCode;
|
for (int reg = 0; reg < MAX_LOCOS; reg++) {
|
||||||
|
speedTable[reg].speedCode = (speedTable[reg].speedCode & 0x80) | (speedCode & 0x7f);
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -147,16 +147,20 @@ void DCCEXParser::parse(Print * stream, byte *com, bool blocking) {
|
|||||||
case '\0': return; // filterCallback asked us to ignore
|
case '\0': return; // filterCallback asked us to ignore
|
||||||
case 't': // THROTTLE <t REGISTER CAB SPEED DIRECTION>
|
case 't': // THROTTLE <t REGISTER CAB SPEED DIRECTION>
|
||||||
{
|
{
|
||||||
if (p[1] == 0) break; // ignore requests for throttle address 0 (returns 'X')
|
if (params!=4) break;
|
||||||
|
|
||||||
// Convert JMRI bizarre -1=emergency stop, 0-126 as speeds
|
// Convert JMRI bizarre -1=emergency stop, 0-126 as speeds
|
||||||
// to DCC 0=stop, 1= emergency stop, 2-127 speeds
|
// to DCC 0=stop, 1= emergency stop, 2-127 speeds
|
||||||
int tspeed=p[2];
|
int tspeed=p[2];
|
||||||
if (tspeed>126 || tspeed<-1) break; // invalid JMRI speed code
|
if (tspeed>126 || tspeed<-1) break; // invalid JMRI speed code
|
||||||
if (tspeed<0) tspeed=1; // emergency stop DCC speed
|
if (tspeed<0) tspeed=1; // emergency stop DCC speed
|
||||||
else if (tspeed>0) tspeed++; // map 1-126 -> 2-127
|
else if (tspeed>0) tspeed++; // map 1-126 -> 2-127
|
||||||
|
if (p[1] == 0 && tspeed>1) break; // ignore broadcasts of speed>1
|
||||||
|
|
||||||
|
if (p[3]<0 || p[3]>1) break; // invalid direction code
|
||||||
|
|
||||||
DCC::setThrottle(p[1],tspeed,p[3]);
|
DCC::setThrottle(p[1],tspeed,p[3]);
|
||||||
// report speed 0 after emergency stop
|
StringFormatter::send(stream,F("<T %d %d %d>"), p[0], p[2],p[3]);
|
||||||
StringFormatter::send(stream,F("<T %d %d %d>"), p[0], p[2]<0?0:p[2],p[3]);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
case 'f': // FUNCTION <f CAB BYTE1 [BYTE2]>
|
case 'f': // FUNCTION <f CAB BYTE1 [BYTE2]>
|
||||||
|
Loading…
Reference in New Issue
Block a user