should change all pinouts to match v1.1 PCB (keypad pinout possibly wrong)

This commit is contained in:
Brendan Haines 2016-11-29 20:45:52 -07:00
parent 815f392e9e
commit eb947bff8c

View File

@ -6,31 +6,21 @@
////////// PARAMETERS ////////// ////////// PARAMETERS //////////
//////////////////////////////// ////////////////////////////////
// Arduino will wake from sleep when WAKE_PIN is pulled low. Connect any waking buttons to WAKE_PIN #define LED_BAT_LOW 3
#define WAKE_PIN 2 #define LED_NO_SERVICE 2
#define BUT_ANS A3 #define BUT_ANS A3
#define BUT_END A4 #define BUT_END A4
// RX/TX are in reference to the Arduino, not SIM800
#define GSM_RX 3
#define GSM_TX 11
#define GSM_RST A2 #define GSM_RST A2
#define GSM_RING A5 #define GSM_RING A5
// TIMEOUT_SLEEP is the time to stay awake from last activity until sleep (milliseconds)
#define TIMEOUT_SLEEP 6000
// Charging voltage thresholds. Will turn on charging at CHG_VLO and turn off charging at CHG_VHI (millivolts) // Charging voltage thresholds. Will turn on charging at CHG_VLO and turn off charging at CHG_VHI (millivolts)
#define CHG_VLO 3900 #define CHG_VLO 3900
#define CHG_VHI 4100 #define CHG_VHI 4100
#define CHG_PIN A0 #define CHG_PIN A0
// Comment the following line to use HW serial for Fona and disable debugging information #define MAG_SENSE A1
#define USB_DEBUG
// Comment the following line to disable sleeping the Arduino
//#define SLEEP
// Keypad pinout // Keypad pinout
byte rowPins[4] = {9, 4, 5, 7}; byte rowPins[4] = {9, 4, 5, 7};
@ -54,13 +44,7 @@ unsigned long lastActiveTime;
bool dialtoneActive = false; bool dialtoneActive = false;
bool startDialtone = false; bool startDialtone = false;
#ifdef USB_DEBUG
#include "SoftwareSerial.h"
SoftwareSerial fonaSS = SoftwareSerial(GSM_RX, GSM_TX);
SoftwareSerial *fonaSerial = &fonaSS;
#else
HardwareSerial *fonaSerial = &Serial; HardwareSerial *fonaSerial = &Serial;
#endif
Adafruit_FONA fona = Adafruit_FONA(GSM_RST); Adafruit_FONA fona = Adafruit_FONA(GSM_RST);
Keypad keypad = Keypad( makeKeymap(keys), rowPins, colPins, 4, 3 ); Keypad keypad = Keypad( makeKeymap(keys), rowPins, colPins, 4, 3 );
@ -70,28 +54,6 @@ Keypad keypad = Keypad( makeKeymap(keys), rowPins, colPins, 4, 3 );
////////// FUNCTIONS ////////// ////////// FUNCTIONS //////////
/////////////////////////////// ///////////////////////////////
void wakeFromSleep() {
sleep_disable();
detachInterrupt(WAKE_PIN);
#ifdef USB_DEBUG
Serial.println("Woke up");
#endif
startDialtone = true;
}
void goToSleep() {
#ifdef USB_DEBUG
Serial.println("Going to sleep");
#endif
sleep_enable();
attachInterrupt(WAKE_PIN, wakeFromSleep, LOW);
set_sleep_mode(SLEEP_MODE_PWR_DOWN);
cli();
sleep_bod_disable();
sei();
sleep_cpu();
}
void inCall() { void inCall() {
while (1) { while (1) {
if ( !digitalRead(BUT_END) || fona.getCallStatus() < 3 ) { // End button pressed if ( !digitalRead(BUT_END) || fona.getCallStatus() < 3 ) { // End button pressed
@ -112,20 +74,11 @@ void inCall() {
} }
void beginCall() { void beginCall() {
#ifdef USB_DEBUG
Serial.println("Starting Call");
#endif
fona.sendCheckReply( F("AT+STTONE=0"), F("OK") ); // End dialtone fona.sendCheckReply( F("AT+STTONE=0"), F("OK") ); // End dialtone
dialtoneActive = false; dialtoneActive = false;
if ( fona.callPhone( phoneNumber ) ) { if ( fona.callPhone( phoneNumber ) ) {
#ifdef USB_DEBUG
Serial.println("Call Started");
#endif
inCall(); inCall();
} }
#ifdef USB_DEBUG
Serial.println("Call ended");
#endif
} }
void resumeDialtone() { void resumeDialtone() {
@ -138,36 +91,33 @@ void resumeDialtone() {
////////////////////////////////// //////////////////////////////////
void setup() { void setup() {
#ifdef USB_DEBUG
Serial.begin(9600);
Serial.println("Booted. Setting up");
#endif
pinMode( WAKE_PIN, INPUT_PULLUP );
pinMode( BUT_ANS, INPUT_PULLUP ); pinMode( BUT_ANS, INPUT_PULLUP );
pinMode( BUT_END, INPUT_PULLUP ); pinMode( BUT_END, INPUT_PULLUP );
pinMode( GSM_RST, OUTPUT ); pinMode( GSM_RST, OUTPUT );
pinMode( GSM_RING, INPUT_PULLUP ); pinMode( GSM_RING, INPUT_PULLUP );
pinMode( CHG_PIN, OUTPUT ); pinMode( CHG_PIN, OUTPUT );
pinMode( LED_BAT_LOW, OUTPUT);
pinMode( LED_NO_SERVICE, OUTPUT);
digitalWrite( LED_BAT_LOW, HIGH );
digitalWrite( LED_NO_SERVICE, HIGH );
digitalWrite( GSM_RST, HIGH ); digitalWrite( GSM_RST, HIGH );
digitalWrite( CHG_PIN, HIGH ); digitalWrite( CHG_PIN, HIGH );
fonaSerial->begin(4800); digitalWrite( LED_NO_SERVICE, LOW );
fonaSerial->begin(115200);
if (! fona.begin(*fonaSerial)) { if (! fona.begin(*fonaSerial)) {
#ifdef USB_DEBUG
Serial.println("Fona failed to respond");
#endif
while (1); //fona didn't start while (1); //fona didn't start
} }
while ( !fona.setAudio(FONA_EXTAUDIO) ) {} //while ( !fona.setAudio(FONA_EXTAUDIO) ) {}
#ifdef USB_DEBUG
Serial.println("Setup Complete");
#endif
startDialtone = true; startDialtone = true;
lastActiveTime = millis(); lastActiveTime = millis();
digitalWrite( LED_BAT_LOW, LOW );
fona.sendCheckReply( F("AT+CLVL=20"), F("OK") ); // set dialtone volume fona.sendCheckReply( F("AT+CLVL=20"), F("OK") ); // set dialtone volume
} }
void loop() { void loop() {
@ -199,14 +149,6 @@ void loop() {
fona.playDTMF( key ); // Play DTMF tone fona.playDTMF( key ); // Play DTMF tone
lastActiveTime = millis(); lastActiveTime = millis();
#ifdef USB_DEBUG
int i;
for (i = 0; i < 15; i = i + 1) {
Serial.print(phoneNumber[i]);
Serial.print(", ");
}
Serial.println(phoneNumberLength);
#endif
// Check for complete phone number (including +1 country code) // Check for complete phone number (including +1 country code)
if ( ( phoneNumberLength == 10 & phoneNumber[0] != '1' ) || phoneNumberLength > 10 ) { if ( ( phoneNumberLength == 10 & phoneNumber[0] != '1' ) || phoneNumberLength > 10 ) {
beginCall(); beginCall();
@ -220,12 +162,10 @@ void loop() {
phoneNumber[j] = 0; phoneNumber[j] = 0;
} }
phoneNumberLength = 0; phoneNumberLength = 0;
#ifdef USB_DEBUG
Serial.println( phoneNumberLength );
#endif
resumeDialtone(); resumeDialtone();
} }
// Battery Management
uint16_t vbat; uint16_t vbat;
fona.getBattVoltage(&vbat); fona.getBattVoltage(&vbat);
if ( vbat < CHG_VLO ) { if ( vbat < CHG_VLO ) {
@ -234,13 +174,6 @@ void loop() {
digitalWrite( CHG_PIN, LOW ); digitalWrite( CHG_PIN, LOW );
} }
#ifdef SLEEP
// Autoshutdown if inactive for extended period
// Typecast to long avoids "rollover" issues
if ( (long)(millis() - lastActiveTime) > TIMEOUT_SLEEP ) {
goToSleep();
}
#endif
} }