mirror of
https://github.com/DCC-EX/CommandStation-EX.git
synced 2025-04-21 20:41:19 +02:00
Compare commits
No commits in common. "830de850a97745c3f493865ca15b5e14bb25615e" and "0476b9c1d8dca011029ba39f269a85e21adb6ea1" have entirely different histories.
830de850a9
...
0476b9c1d8
6
DCCRMT.h
6
DCCRMT.h
@ -44,12 +44,6 @@ class RMTChannel {
|
|||||||
return true;
|
return true;
|
||||||
return dataReady;
|
return dataReady;
|
||||||
};
|
};
|
||||||
inline void waitForDataCopy() {
|
|
||||||
while(1) { // do nothing and wait for interrupt clearing dataReady to happen
|
|
||||||
if (dataReady == false)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
inline uint32_t packetCount() { return packetCounter; };
|
inline uint32_t packetCount() { return packetCounter; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -278,11 +278,7 @@ void DCCWaveform::begin() {
|
|||||||
|
|
||||||
void DCCWaveform::schedulePacket(const byte buffer[], byte byteCount, byte repeats) {
|
void DCCWaveform::schedulePacket(const byte buffer[], byte byteCount, byte repeats) {
|
||||||
if (byteCount > MAX_PACKET_SIZE) return; // allow for chksum
|
if (byteCount > MAX_PACKET_SIZE) return; // allow for chksum
|
||||||
RMTChannel *rmtchannel = (isMainTrack ? rmtMainChannel : rmtProgChannel);
|
|
||||||
if (rmtchannel == NULL)
|
|
||||||
return; // no idea to prepare packet if we can not send it anyway
|
|
||||||
|
|
||||||
rmtchannel->waitForDataCopy(); // blocking wait so we can write into buffer
|
|
||||||
byte checksum = 0;
|
byte checksum = 0;
|
||||||
for (byte b = 0; b < byteCount; b++) {
|
for (byte b = 0; b < byteCount; b++) {
|
||||||
checksum ^= buffer[b];
|
checksum ^= buffer[b];
|
||||||
@ -300,7 +296,13 @@ void DCCWaveform::schedulePacket(const byte buffer[], byte byteCount, byte repea
|
|||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
do {
|
do {
|
||||||
ret = rmtchannel->RMTfillData(pendingPacket, pendingLength, pendingRepeats);
|
if(isMainTrack) {
|
||||||
|
if (rmtMainChannel != NULL)
|
||||||
|
ret = rmtMainChannel->RMTfillData(pendingPacket, pendingLength, pendingRepeats);
|
||||||
|
} else {
|
||||||
|
if (rmtProgChannel != NULL)
|
||||||
|
ret = rmtProgChannel->RMTfillData(pendingPacket, pendingLength, pendingRepeats);
|
||||||
|
}
|
||||||
} while(ret > 0);
|
} while(ret > 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,8 +3,7 @@
|
|||||||
|
|
||||||
#include "StringFormatter.h"
|
#include "StringFormatter.h"
|
||||||
|
|
||||||
#define VERSION "5.4.1"
|
#define VERSION "5.4.0"
|
||||||
// 5.4.1 - ESP32 bugfix packet buffer race
|
|
||||||
// 5.4.0 - New version on master
|
// 5.4.0 - New version on master
|
||||||
// 5.2.96 - EXRAIL additions XFWD() and XREV()
|
// 5.2.96 - EXRAIL additions XFWD() and XREV()
|
||||||
// 5.2.95 - Release candidate for 5.4
|
// 5.2.95 - Release candidate for 5.4
|
||||||
|
Loading…
x
Reference in New Issue
Block a user