|
|
|
#include "BAHardware.h"
|
|
|
|
#include "BASpiMemory.h"
|
|
|
|
|
|
|
|
using namespace BALibrary;
|
|
|
|
|
|
|
|
constexpr unsigned MIDI_RATE = 31250;
|
|
|
|
constexpr unsigned HIGH_RATE = 230400;
|
|
|
|
constexpr unsigned TEST_TIME = 5; // 5 second test each
|
|
|
|
|
|
|
|
static unsigned baudRate = MIDI_RATE; // start with low speed
|
|
|
|
static uint8_t writeData = 0;
|
|
|
|
static unsigned loopCounter = 0;
|
|
|
|
static unsigned errorCount = 0;
|
|
|
|
static bool testFailed = false;
|
|
|
|
static bool testDone = false;
|
|
|
|
static unsigned testPhase = 0; // 0 for MIDI speed, 1 for high speed.
|
|
|
|
|
|
|
|
bool uartTest(void)
|
|
|
|
{
|
|
|
|
Serial1.begin(baudRate, SERIAL_8N1);
|
|
|
|
delay(100);
|
|
|
|
while(!Serial) {}
|
|
|
|
Serial.println(String("\nRunning MIDI Port speed test at ") + baudRate);
|
|
|
|
|
|
|
|
// write the first data
|
|
|
|
Serial1.write(writeData);
|
|
|
|
|
|
|
|
while(!testFailed && !testDone) {
|
|
|
|
|
|
|
|
if (loopCounter >= (baudRate/4)) { // the divisor determines how long the test runs for
|
|
|
|
// next test
|
|
|
|
switch (testPhase) {
|
|
|
|
case 0 :
|
|
|
|
baudRate = HIGH_RATE;
|
|
|
|
break;
|
|
|
|
case 1 :
|
|
|
|
testDone = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (errorCount == 0) { Serial.println("TEST PASSED!"); }
|
|
|
|
else {
|
|
|
|
Serial.println("MIDI PORT TEST FAILED!");
|
|
|
|
}
|
|
|
|
errorCount = 0;
|
|
|
|
testPhase++;
|
|
|
|
loopCounter = 0;
|
|
|
|
|
|
|
|
if (!testDone) {
|
|
|
|
Serial.println(String("\nRunning MIDI Port speed test at ") + baudRate);
|
|
|
|
Serial1.begin(baudRate, SERIAL_8N1);
|
|
|
|
while (!Serial1) {} // wait for serial to be ready
|
|
|
|
} else {
|
|
|
|
Serial.println("MIDI PORT TEST DONE!\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Wait for read data
|
|
|
|
if (Serial1.available()) {
|
|
|
|
uint8_t readData= Serial1.read();
|
|
|
|
if (readData != writeData) {
|
|
|
|
Serial.println(String("MIDI ERROR: readData = ") + readData + String(" writeData = ") + writeData);
|
|
|
|
errorCount++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((loopCounter % (baudRate/64)) == 0) { // the divisor determines how often the period is printed
|
|
|
|
Serial.print("."); Serial.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (errorCount > 16) {
|
|
|
|
Serial.println("Halting test");
|
|
|
|
testFailed = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
loopCounter++;
|
|
|
|
writeData++;
|
|
|
|
Serial1.write(writeData);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return testFailed;
|
|
|
|
}
|