For those using v5 of Snooze the reason for the change is that new Teensy's are in the pipeline and updating this fairly extensive library became to difficult because each new processor introduced has its own set of Low Power functionality. Now the library is divided into three classes:
As you can see the Drivers are now separated from the SnoozeBlock Class. Before these drivers where part of the SnoozeBlock which made it difficult to add new functionalities. Each Teensy can now have driver classes designed specifically for them. Users can install their own drivers also if they wish also, see the skeltonClass example. Snooze uses something similar to the Audio library's conventions for adding drivers. As an added benefit, only the drivers that are installed are called, before all drivers where called just not used if not configured, this should add some performance benefits.
Here are some new features and enhancments over Version 5:
- Three teir class structure now means easier and faster debug and development of Snooze.
- All core drivers save and restore all relevent registers and such before/after sleeping. So things like HardwareSerial will just work if using one of its pins as a digital wakeup event.
- Millis is updated when using Timer driver wakeup. Might implement this for other wakeup drivers also.
- Audio library plays nice with Snooze now by using the SnoozeAudio core driver.
- REDUCED_CPU_BLOCK does not mess up the millis anymore.
- Add and subtract drivers from SnoozeBlock(s), now you can get creative with SnoozeBlocks!
- USB Serial works better in low power opteration.
- Audio library works with sleeping.
Here is a basic example of the new api. As you can see we load three of Core Driver Classes - touch, digital, timer.
What are the Core Drivers?
Core Drivers configure wakeup events or configure a module to work while in low power mode. Drivers are further explained later.
- touch - Using the Kinetis touch module to wake your Teensy.
- digital - Wake your Teensy with a RISING or FALLING event on a certian pin.
- timer - Use the Low Power timer in milliseconds to wake your Teensy,
- alarm - Use the RTC clock to wake your Teensy.
- compare - Setup a volatgae crossing to wake your Teensy.
- usbSerial - Does not wake the teensy it makes USB Serial play nice while using Snooze.
- audio - Allows the Audio library to work as normal after waking from sleep, does not wake the Teensy.
Next we see the SnoozeBlock only has the timer and digital drivers installed. Even though the Touch driver is loaded it is not installed so it won't get called. In this example either the timer expires or the digital pin is lifted will wake the Teensy up.
#include <Snooze.h>
// Load drivers
SnoozeTouch touch;
SnoozeDigital digital;
SnoozeTimer timer;
// install drivers to a SnoozeBlock
SnoozeBlock config(timer, digital);
void setup() {
pinMode(LED_BUILTIN, OUTPUT);
/********************************************************
* Set Low Power Timer wake up in milliseconds.
********************************************************/
timer.setTimer(5000);// milliseconds
/********************************************************
* Define digital pins for waking the teensy up. This
* combines pinMode and attachInterrupt in one function.
*
* Teensy 3.x
* Digital pins: 2,4,6,7,9,10,11,13,16,21,22,26,30,33
*
* Teensy LC
* Digital pins: 2,6,7,9,10,11,16,21,22
********************************************************/
digital.pinMode(21, INPUT_PULLUP, RISING);//pin, mode, type
digital.pinMode(22, INPUT_PULLUP, RISING);//pin, mode, type
}
void loop() {
/********************************************************
* feed the sleep function its wakeup parameters. Then go
* to deepSleep.
********************************************************/
int who = Snooze.deepSleep( config );// return module that woke processor
digitalWrite(LED_BUILTIN, HIGH);
delay(100);
digitalWrite(LED_BUILTIN, LOW);
}
Lets break out each part out so we can see what is going on here:
- Include the Snooze library header. This brings in Snooze, SnoozeBlock, Core Driver Classes.
#include <Snooze.h>
- Next we load the drivers classes we want visible to install.
SnoozeTouch touch;
SnoozeDigital digital;
SnoozeTimer timer;
3. Here we install only the Timer and Digital drivers to the SnoozeBlock.
``` SnoozeBlock config(timer, digital); ```
4. Now we configure the Drivers, typically drivers have some way of changing certain parameters.
``` timer.setTimer(5000);// milliseconds digital.pinMode(21, INPUT_PULLUP, RISING);//pin, mode, type digital.pinMode(22, INPUT_PULLUP, RISING);//pin, mode, type ```
5. Lastly we supply the SnoozeBlock to whatever sleep function you want to use from the Snooze class. We still have the same three sleep modes
``` Snooze.sleep( config ); Snooze.deepSleep( config ); Snooze.hibernate( config ); ```
--- Now that was easy enough lets take deeper look at the library structure.
![alt text](https://github.com/duff2013/Snooze/blob/master/images/Snooze_Class_Layout/Slide3.png "Snooze Library Layout")
As you can see Snooze library has only one Snooze Class but can have mulitple SnoozeBlocks which have mulitiple Drivers. Refferring to the first graphic Snooze is 3 Tier Class structure:
- Snooze Class
- SnoozeBlock Class
- Drivers Classes
...TODO Snooze Class code flow diagram.
This class works by connecting the Driver Class to the Snooze Class and can have up to 8 class intstance defined for any one sketch. This class really does all the glue work to call the drivers before and after sleeping. There are three speacial virtual functions that need to be explianed. 1. enableDriver - Driver can override this function, it is called right before sleeping. 2. disableDriver - Driver can override this function, it gets called right after sleeping. 3. clearFlags - Driver can override this function, gets called by interrupts from a driver in 'sleep' mode or directly from deepSleep and hibernate wakeup interrupt. ...![alt text](https://github.com/duff2013/Snooze/blob/master/images/Snooze_Class_Layout/Slide4.png "Snooze Library Layout")
![alt text](https://github.com/duff2013/Snooze/blob/master/images/Snooze_Class_Layout/Slide5.png "Snooze Library Layout")
![alt text](https://github.com/duff2013/Snooze/blob/master/images/Snooze_Class_Layout/Slide6.png "Snooze Library Layout")
![alt text](https://github.com/duff2013/Snooze/blob/master/images/Snooze_Class_Layout/Slide7.png "Snooze Library Layout")