Sensor Watch 0.0.2
A board replacement for the classic Casio F-91W wristwatch, powered by a Microchip SAM L22 microcontroller.
Loading...
Searching...
No Matches
Functions
Sleep Control

This section covers functions related to the various sleep modes available to the watch, including Sleep, Deep Sleep, and BACKUP mode. More...

Functions

void watch_register_extwake_callback (uint8_t pin, ext_irq_cb_t callback, bool level)
 Registers a callback on one of the RTC's external wake pins, which can wake the device from Sleep, Deep Sleep and BACKUP modes (but see warning re: BACKUP mode). More...
 
void watch_disable_extwake_interrupt (uint8_t pin)
 Unregisters the RTC interrupt on one of the EXTWAKE pins. This will prevent a value change on one of these pins from waking the device. More...
 
void watch_store_backup_data (uint32_t data, uint8_t reg)
 Stores data in one of the RTC's backup registers, which retain their data in BACKUP mode. More...
 
uint32_t watch_get_backup_data (uint8_t reg)
 Gets 32 bits of data from the RTC's BACKUP register. More...
 
void watch_enter_sleep_mode (void)
 enters Sleep Mode by disabling all pins and peripherals except the RTC and the LCD. More...
 
void watch_enter_deep_sleep_mode (void)
 enters Deep Sleep Mode by disabling all pins and peripherals except the RTC. More...
 
void watch_enter_backup_mode (void)
 Enters the SAM L22's lowest-power mode, BACKUP. More...
 

Detailed Description

This section covers functions related to the various sleep modes available to the watch, including Sleep, Deep Sleep, and BACKUP mode.

These terms changed meaning a bit over the course of development; if you are coming to this documentation after having worked with an earlier version of the library, these definitions should clarify the terminology. Terms in all caps are modes of the SAM L22; terms in Title Case are specific implementations in this library.

Function Documentation

◆ watch_disable_extwake_interrupt()

void watch_disable_extwake_interrupt ( uint8_t  pin)

Unregisters the RTC interrupt on one of the EXTWAKE pins. This will prevent a value change on one of these pins from waking the device.

Parameters
pinEither pin BTN_ALARM, A2, or A4. If the pin is BTN_ALARM, this function DOES NOT disable the internal pull down on that pin.

◆ watch_enter_backup_mode()

void watch_enter_backup_mode ( void  )

Enters the SAM L22's lowest-power mode, BACKUP.

This function does some housekeeping before entering BACKUP mode. It first disables all pins and peripherals except for the RTC, and disables the tick interrupt (since that would wake us up from BACKUP mode). Once again, if you wish to wake from the A2 or the A4 interrupt, you must first configure this by calling watch_register_extwake_callback.

Note
If you have a callback set for an external wake interrupt, it will be called if triggered while in ACTIVE, STANDBY, Sleep and Deep Sleep modes, but it will not be called when waking from BACKUP mode. Waking from backup is effectively like waking from reset, except that your app_wake_from_backup function will be called.
Warning
On current revisions of the SAM L22 silicon, the ALARM_BTN pin (PA02 RTC/IN2) cannot wake the device from deep sleep mode. There is an errata note (Reference: 15010) that says that due to a silicon bug, RTC/IN2 is not functional in BACKUP. As a result, you should not call this function unless you have a device on the nine-pin connector with an external interrupt on pin A2 or A4 (i.e. an accelerometer with an interrupt pin).

◆ watch_enter_deep_sleep_mode()

void watch_enter_deep_sleep_mode ( void  )

enters Deep Sleep Mode by disabling all pins and peripherals except the RTC.

Short of BACKUP mode, this is the lowest power mode you can enter while retaining your application state (and the ability to wake with the alarm button). Just note that the display will be completely off, so you should document to the user of your application that they will need to press the alarm button to wake the device, or use a sensor board with support for an external wake pin.

All notes from watch_enter_sleep_mode apply here, except for power consumption. You can estimate the power consumption of this mode to be on the order of 4µA at room temperature.

◆ watch_enter_sleep_mode()

void watch_enter_sleep_mode ( void  )

enters Sleep Mode by disabling all pins and peripherals except the RTC and the LCD.

This sleep mode is not the lowest power mode available, but it has the benefit of allowing you to display a message to the user while asleep. You can also set an alarm interrupt to wake at a configfurable interval (every minute, hour or day) to update the display. You can wake from this mode by pressing the ALARM button, if you registered an extwake callback on the ALARM button. Also note that when your app wakes from this sleep mode, your app_setup method will be called again, since this function will have disabled things you set up there.

Note that to wake from either the ALARM button, the A2 interrupt or the A4 interrupt, you must first configure this by calling watch_register_extwake_callback.

Power consumption depends on temperature, but as a rough estimate, this mode will consume:

  • 6.0 ~ 7.5µA while at normal room temperatures
  • 9.5µA while worn on a wrist (temperature ≈ 31° C)

◆ watch_get_backup_data()

uint32_t watch_get_backup_data ( uint8_t  reg)

Gets 32 bits of data from the RTC's BACKUP register.

Parameters
regA register from 0-7.
Returns
An unsigned 32 bit integer with the from the backup register.

◆ watch_register_extwake_callback()

void watch_register_extwake_callback ( uint8_t  pin,
ext_irq_cb_t  callback,
bool  level 
)

Registers a callback on one of the RTC's external wake pins, which can wake the device from Sleep, Deep Sleep and BACKUP modes (but see warning re: BACKUP mode).

Parameters
pinEither pin BTN_ALARM, A2, or A4. These are the three external wake pins. If the pin is BTN_ALARM, this function also enables an internal pull down on that pin.
callbackThe callback to be called if this pin triggers outside of BACKUP mode. If this is NULL, no callback will be called even in normal modes, but the interrupt will still be enabled so that it can wake the device.
levelThe level you wish to scan for: true for rising, false for falling. Note that you cannot scan for both rising and falling edges like you can with the external interrupt pins; with the external wake interrupt, you can only get one or the other.
Note
When in ACTIVE, STANDBY and Sleep / Deep sleep modes, this will function much like a standard external interrupt situation: these pins will wake the device, and your callback will be called. However, if the device enters BACKUP mode and one of these pins wakes the device, your callback WILL NOT be called, as the device is basically waking from reset at that point.
Warning
As of the current SAM L22 silicon revision (rev B), the BTN_ALARM pin cannot wake the device from BACKUP mode. You can still use this function to register a BTN_ALARM interrupt in normal or deep sleep mode, but to wake from BACKUP, you will need to use pin A2 or A4.

◆ watch_store_backup_data()

void watch_store_backup_data ( uint32_t  data,
uint8_t  reg 
)

Stores data in one of the RTC's backup registers, which retain their data in BACKUP mode.

Parameters
dataAn unsigned 32 bit integer with the data you wish to store.
regA register from 0-7.