This repository has been archived on 2020-09-09. You can view files and clone it, but cannot push or open issues or pull requests.
arduino_universal_serial_ad.../Universal_Serial_Adapter/Config.cpp

253 lines
4.7 KiB
C++
Raw Normal View History

/*
Serial Adapter Project: Dynamic serial TTY passthroughs
by: Mike Crosson
Nusku Networks
date: 2013/03/09
license: CC-BY SA 3.0 - Creative commons share-alike 3.0
use this code however you'd like, just keep this license and
attribute.
*/
2013-04-09 21:40:12 +00:00
#include "Arduino.h"
#include "Project.h"
#include "Config.h"
#include "UI.h"
Config::Config() {
if (DEBUG) {
Serial.println("Config::Config()");
}
currentMode = none;
currentLineSpeed = zero;
currentVoltage = negOne;
2013-04-07 04:49:23 +00:00
currentTimeout = never;
pinMode(voltagePinOnePointEight, OUTPUT);
pinMode(voltagePinThreePointThree, OUTPUT);
pinMode(voltagePinFivePointZero, OUTPUT);
if (DEBUG) {
Serial.begin(115200);
}
}
2013-04-07 05:32:42 +00:00
bool Config::isUIEnabled() {
if (DEBUG) {
Serial.println("Config::isUIEnabled()");
}
2013-04-07 05:32:42 +00:00
return uiEnabled;
}
void Config::enableUI() {
if (DEBUG) {
Serial.println("Config::enableUI()");
}
2013-04-07 05:32:42 +00:00
uiEnabled = true;
}
void Config::disableUI() {
if (DEBUG) {
Serial.println("Config::disableUI()");
}
2013-04-07 05:32:42 +00:00
uiEnabled = false;
}
serialmode Config::getSerialMode() {
if (DEBUG) {
Serial.println("Config::getSerialMode()");
}
return currentMode;
}
linespeed Config::getLineSpeed() {
if (DEBUG) {
Serial.println("Config::getLineSpeed()");
}
return currentLineSpeed;
}
float Config::getLineSpeedBaud() {
if (DEBUG) {
Serial.println("Config::getLineSpeedBaud()");
}
2013-04-09 22:05:22 +00:00
switch (currentLineSpeed) {
case 0: // twentyFourHundredBaud
2013-04-09 22:05:22 +00:00
return 2400;
break;
case 1: // ninetySixHundredBaud
2013-04-09 22:05:22 +00:00
return 9600;
break;
case 2: // nineteenTwoK
2013-04-09 22:05:22 +00:00
return 19200;
break;
case 3: // thirtyeightFourK
2013-04-09 22:05:22 +00:00
return 38400;
break;
case 4: // fiftysevenFiveK
2013-04-09 22:05:22 +00:00
return 57600;
break;
case 5: // oneNineteenTwoK
return 115200;
2013-04-09 22:05:22 +00:00
break;
}
}
ttlvoltage Config::getVoltage() {
if (DEBUG) {
Serial.println("Config::getVoltage()");
}
return currentVoltage;
}
2013-04-07 04:49:23 +00:00
timeout Config::getTimeout() {
if (DEBUG) {
Serial.println("Config::getTimeout()");
}
2013-04-07 04:49:23 +00:00
return currentTimeout;
}
2013-04-09 21:18:43 +00:00
int Config::getTimeoutMilis() {
if (DEBUG) {
Serial.println("Config::getTimeoutMilis()");
}
2013-04-07 05:32:42 +00:00
switch (currentTimeout) {
case 0: // tenseconds
return 10000;
case 1: // thirtyseconds
return 30000;
case 2: // oneminute
return 60000;
case 3: // fiveminutes
return 300000;
}
return -1;
}
void Config::setMode(serialmode mode) {
if (DEBUG) {
Serial.println("Config::setMode()");
Serial.print(" Setting ttl line speed to:");
float baudrate = this->getLineSpeedBaud();
Serial.println(baudrate);
}
2013-04-09 22:05:22 +00:00
switch (currentMode) {
case 1: // ttl
Serial3.end();
2013-04-09 22:05:22 +00:00
break;
case 2: // db9_null
Serial2.end();
break;
case 3: // cisco
Serial1.end();
2013-04-09 22:05:22 +00:00
break;
}
switch (mode) {
case 0: // ttl
Serial3.begin(getLineSpeedBaud());
2013-04-09 22:05:22 +00:00
break;
case 1: // db9_null
2013-04-09 22:05:22 +00:00
Serial2.begin(getLineSpeedBaud());
break;
case 2: // cisco
Serial1.begin(getLineSpeedBaud());
2013-04-09 22:05:22 +00:00
break;
}
currentMode = mode;
}
void Config::setLineSpeed(linespeed aLineSpeed) {
if (DEBUG) {
Serial.println("Config::setLineSpeed()");
}
currentLineSpeed = aLineSpeed;
Serial.end();
Serial.begin(getLineSpeedBaud());
setMode(currentMode);
}
void Config::setVoltage(ttlvoltage voltage) {
if (DEBUG) {
Serial.println("Config::setVoltage()");
}
currentVoltage = voltage;
digitalWrite(voltagePinOnePointEight, LOW);
digitalWrite(voltagePinThreePointThree, LOW);
digitalWrite(voltagePinFivePointZero, LOW);
2013-04-09 21:40:12 +00:00
switch (voltage) {
case 0: // onePointEight
digitalWrite(voltagePinOnePointEight, HIGH);
2013-04-09 21:40:12 +00:00
break;
case 1: // threePointThree
digitalWrite(voltagePinThreePointThree, HIGH);
2013-04-09 21:40:12 +00:00
break;
case 2: // five
digitalWrite(voltagePinFivePointZero, HIGH);
2013-04-09 21:40:12 +00:00
break;
}
}
void Config::setLCDTimeout(timeout aTimeout) {
if (DEBUG) {
Serial.println("Config::setTimeout()");
}
2013-04-07 04:49:23 +00:00
currentTimeout = aTimeout;
ui->setLCDTimeout();
2013-04-07 04:49:23 +00:00
}
void Config::setDefaults() {
if (DEBUG) {
Serial.println("Config::setDefaults()");
}
setVoltage(onePointEight);
setLineSpeed(oneFifteenTwoK);
2013-04-09 22:05:22 +00:00
setMode(ttl);
setLCDTimeout(thirtyseconds);
2013-04-07 05:32:42 +00:00
}
2013-04-09 22:11:08 +00:00
void Config::processSerialData() {
//if (DEBUG) {
// Serial.println("Config::processSerialData()");
//}
2013-04-09 22:11:08 +00:00
switch (currentMode) {
case 0: // ttl
if (Serial3.available()) {
int inByte = Serial3.read();
2013-04-09 22:11:08 +00:00
Serial.write(inByte);
}
if (Serial.available()) {
int inByte = Serial.read();
Serial3.write(inByte);
2013-04-09 22:11:08 +00:00
}
break;
case 1: // db9_null
2013-04-09 22:11:08 +00:00
if (Serial2.available()) {
int inByte = Serial2.read();
Serial.write(inByte);
}
if (Serial.available()) {
int inByte = Serial.read();
Serial2.write(inByte);
}
break;
case 2: // cisco
if (Serial1.available()) {
int inByte = Serial1.read();
2013-04-09 22:11:08 +00:00
Serial.write(inByte);
}
if (Serial.available()) {
int inByte = Serial.read();
Serial1.write(inByte);
2013-04-09 22:11:08 +00:00
}
break;
}
}