Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: libmDot mbed-rtos mbed
Diff: main.cpp
- Revision:
- 3:23fae3efa1c0
- Parent:
- 2:5318600ca0fe
- Child:
- 4:0fb159501a04
diff -r 5318600ca0fe -r 23fae3efa1c0 main.cpp
--- a/main.cpp Mon May 16 20:16:37 2016 +0000
+++ b/main.cpp Thu May 19 07:42:49 2016 +0000
@@ -1,4 +1,5 @@
#include "mbed.h"
+#include "rtos.h"
#include "mDot.h"
#include "MTSLog.h"
#include "MTSText.h"
@@ -8,40 +9,37 @@
#define MIN(a,b) (((a)<(b))?(a):(b))
#define MAX(a,b) (((a)>(b))?(a):(b))
-#define REED_PORT PA_3
+// http://www.multitech.net/developer/forums/topic/mdot-pinout-associate-and-onsleep/
+// Keep in mind that if you want to put the device in deepsleep mode
+// and wake up with an interrupt, pin D3/XBEE_CTS/XBEE_DIO7/PA_0 is
+// the only pin that can be used.
+
+#define REED_PORT PA_0
#define MINIMAL_SECONDS_BETEEN_CONTACT 10
#define MAXIMAL_SECONDS_BETEEN_CONTACT 60
-//Serial pc(USBTX,USBRX);
-RawSerial pc(USBTX,USBRX);
+// https://developer.mbed.org/users/mbed_official/code/mbed/docs/252557024ec3/classmbed_1_1RawSerial.html
+RawSerial pc(PA_2,NC);
+//RawSerial pc(USBTX,USBRX);
DigitalIn reed_gpio(REED_PORT);
-int reed_lock_write = 0;
-int reed_lock_read = 0;
-int reed_has_changed = 0;
+
+volatile int reed_has_changed = 0;
int reed_value_to_send = 0;
int reed_value_last_sent = 0;
int reed_gpio_value = 0;
void isr_reed_sensor_change(void) {
-
- while(reed_lock_read) {}
- reed_lock_write = 1;
- reed_has_changed = 1;
- reed_lock_write = 0;
+ reed_has_changed++;
}
int has_reed_changed(void) {
int change;
- while(reed_lock_write) {}
- reed_lock_read = 1;
change = reed_has_changed;
reed_has_changed = 0;
- reed_lock_read = 0;
-
reed_gpio_value = reed_gpio.read();
return(change);
@@ -52,7 +50,6 @@
int change;
has_reed_changed();
- reed_gpio_value = reed_gpio.read();
change = reed_gpio_value != reed_value_last_sent;
@@ -63,7 +60,7 @@
void send_reed(void) {
- reed_value_last_sent = reed_gpio_value;
+ reed_value_last_sent = reed_gpio.read();
pc.printf("%d: Sending REED = %d\r\n",time(NULL),reed_value_last_sent);
@@ -86,14 +83,32 @@
pc.printf( "* Build: " __DATE__ ", " __TIME__" *\r\n");
pc.printf( "********************************\r\n\r\n");
+ reed_gpio.mode(PullUp);
+
+ for(int i=0;i<10;i++) {
+ pc.printf("before mdot: %d (%d)\r\n",reed_gpio.read(),reed_has_changed);
+ Thread::wait(1000);
+ }
+
dot = mDot::getInstance();
dot->setLogLevel(MTSLog::TRACE_LEVEL);
+ for(int i=0;i<10;i++) {
+ pc.printf("after mdot %d (%d)\r\n",reed_gpio.read(),reed_has_changed);
+ Thread::wait(1000);
+ }
+
InterruptIn *reed_sensor_change;
reed_sensor_change = new InterruptIn(REED_PORT);
reed_sensor_change->fall(&isr_reed_sensor_change);
reed_sensor_change->rise(&isr_reed_sensor_change);
+ reed_sensor_change->mode(PullUp);
+ for(int i=0;i<10;i++) {
+ pc.printf("after int %d (%d)\r\n",reed_gpio.read(),reed_has_changed);
+ Thread::wait(1000);
+ }
+
while (true) {
int wakeup_time = last_sent + MAXIMAL_SECONDS_BETEEN_CONTACT;
@@ -149,7 +164,7 @@
Thread::wait(10);
- dot->sleep(sleep_time, mDot::RTC_ALARM_OR_INTERRUPT, false);
+ dot->sleep(sleep_time, mDot::RTC_ALARM_OR_INTERRUPT, true);
pc.printf("%d: Woke up\r\n",time(NULL));
}