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/Universal_Serial_Adapter.ino

104 lines
2.7 KiB
Arduino
Raw Permalink Normal View History

2013-03-10 18:26:41 +00:00
/*
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-03-10 18:26:41 +00:00
#include <Wire.h>
2013-03-10 18:26:41 +00:00
#include "Project.h"
#include "Config.h"
#include "UIButton.h"
#include "UIJoystickPSP.h"
#include "UILCD.h"
2013-04-07 05:32:42 +00:00
#include "UI.h"
2013-04-06 22:44:34 +00:00
#include <Adafruit_GFX.h>
#include <Adafruit_ST7735.h>
#include <SPI.h>
#include <SerialPort.h>
#include <SdFile.h>
#include <SdFat.h>
2013-04-06 22:44:34 +00:00
#include <TimerThree.h>
#include <Metro.h>
#include "RTClib.h"
// Globals used by main classes
2013-04-07 05:32:42 +00:00
UI* ui;
Config* config;
RTC_DS1307 rtc;
SdFile dataFile;
SdFat sd;
#if ARD_DUE
SerialPort<0, 4096, 4096> serialPort0;
SerialPort<1, 4096, 4096> serialPort1;
SerialPort<2, 4096, 4096> serialPort2;
SerialPort<3, 4096, 4096> serialPort3;
#else
SerialPort<0, 512, 512> serialPort0;
SerialPort<1, 512, 512> serialPort1;
SerialPort<2, 512, 512> serialPort2;
SerialPort<3, 512, 512> serialPort3;
#endif
2013-04-06 22:44:34 +00:00
// helper for interrupt method call
void processSerial() {
config->processSerialData();
}
2013-03-10 18:26:41 +00:00
void setup() {
// Setup various IO busses
serialPort0.begin(115200);
Wire.begin();
// Start the SD Card -- This should come very early
// Not in config to guarantee it comes online very very early
serialPort0.println("Starting SD card");
if (!sd.begin(SD_CS, SPI_PROJECT_SPEED )) {
serialPort0.println("SD.begin(SD_CS, SPI_SPEED ) -- failed!");
sd.initErrorHalt();
}
// Ensure RTC is set to run on battery
// clear /EOSC bit
// Sometimes necessary to ensure that the clock
// keeps running on just battery power. Once set,
// it shouldn't need to be reset but it's a good
// idea to make sure.
Wire.beginTransmission(0x68); // address DS3231
Wire.write(0x0E); // select register
Wire.write(0b00011100); // write register bitmap, bit 7 is /EOSC
Wire.endTransmission();
// Start real time clock
rtc.begin();
// Stuff used for serial and UI
config = new Config();
config->setDefaults();
ui = new UI();
// Open data log file -- FIXME: This needs to be controlled via config some
//dataFile.open("datalog.txt", O_WRITE | O_CREAT | O_AT_END);
// Setup serial IO on an interrupt timer
// ***THIS MUST BE DONE AFTER new Config()***
// ***THIS MUST BE DONE AFTER SD INIT***
Timer3.initialize(100); // initialize timer3, value in micro seconds
Timer3.pwm(timerThreePin, 512); // setup pwm on appropriate pin, 50% duty cycle
Timer3.attachInterrupt(processSerial); // attaches method as a timer overflow interrupt
2013-03-10 18:26:41 +00:00
}
void loop() {
// Serial data is processed via an interrupt so isn't needed in the main loop
2013-04-07 05:32:42 +00:00
ui->processInputEvents();
ui->processTimeoutEvents();
2013-03-10 18:26:41 +00:00
}
2013-04-06 22:44:34 +00:00