Low Power Application on SAM E54 Using Harmony v3 Peripheral Libraries: Step 3

Step 3.1: Configure Analog-to-Digital Converter (ADC) Peripheral Library (PLIB)

Configure ADC Peripheral

1

Under the Available Components tab, expand Peripherals > ADC.
Select and double click on ADC1 to add the ADC1 module to the project graph.

add_adc.png

2

Select the ADC1 Peripheral Library and configure it to sample and convert the light sensor input. The ADC is also configured to generate an interrupt (and thereby wake the CPU) when the ADC result is greater than a set Window Monitor Low Threshold value (3000 in this example).

adc_schematic.png
  • When the light sensor is not covered (light is falling on the sensor), the phototransistor is turned on. The ADC input is ~0 V and the ADC RESULT register is close to 0x000.
  • When the light sensor is covered (light is not falling on the sensor), the phototransistor is turned off. The ADC input is ~3.3 V and the ADC RESULT register will be saturated (0xFFF).
  • The ADC RESULT register is compared with the Window Lower Threshold (WINLT), which is set to 3000.
  • When the light sensor is covered (ADC RESULT > WINLT), an ADC Window Monitor Interrupt is generated. This interrupt is used to bring the CPU out of Idle/Standby Sleep mode when you cover the light sensor.
adc_config_table.png

a

Select Prescaler: Peripheral clock divided by 2 divides the ADC input clock with the configured pre-scaler value and provides more sampling time (CLKADC = 1 MHz/2 = 500 kHz).

b

Select Reference: VDDANA.

c

Select Conversion Trigger: HW Event Trigger.

d

Start Event Input: Enabled on Rising Edge.

e

Select Positive Input: ADC AIN6 Pin (the light sensor is connected to AIN6 pin of ADC).

f

Select Result Resolution: 12-bit result (ADC conversion value range from 0 to 4096).

g

Open the Window Mode Configuration panel:

  • Select Window Monitor mode: Result > WINLT. A Window Monitor Interrupt is generated when the ADC result is greater than the configured WINLT value.
  • Window Upper Threshold: Sets the upper threshold of the window comparator. It is set to 0 as the ADC resolution is 12-bit.
  • Window Lower Threshold: Sets the lower threshold of the window comparator. It is set to 3000. This means that the ADC Window Monitor Interrupt will be generated when the ADC result is greater than 3000. This value is decided based on the light sensor voltage when we cover the light sensor; it approximately generates 2.2 V. Hence, the threshold is set near to this voltage.
  • Enable Window Monitor Interrupt: A Window Monitor Interrupt is generated when the ADC result is greater than the configured WINLT.

h

Open the Sleep Mode Configuration panel:

  • Enable Run During Standby.
  • Enable On Demand Control.
adc_configuration_options.png

Note: The Conversion Time value 26.0 uS (shown in the previous image) is after the ADC clock configured.

Configure ADC Pin

3

In the MPLAB® Harmony Configurator (MHC), select the Pin Settings tab and then scroll-down to PORT pin PB04 in Pin ID column and configure this pin as ADC_AIN6.

adc_pin_settings.png

Configure ADC Clock for Low-Power

4

In the MHC, select the Clock Easy View tab and configure the ADC Clock by opening the Peripheral Clock Configuration tab by clicking on the button in the Peripheral Clock Configuration.

peripheral_clock_config.png
adc_clock_configuration.png

The ADC peripheral clock is by default set to GCLK1. However, to benefit from the SAM E54 clock tree, the ADC peripheral clock is fed by GCLK2 to run at 1 MHz. Running a slower clock on the ADC reduces the power consumption during Sleep mode.

This completes the configuration of the ADC PLIB. The ADC is configured to start the conversion on a hardware event trigger and generate an interrupt if the converted value is higher than a defined WINLT value.

Step 3.2: Configure External Interrupt Controller (EIC) PLIB for Switch Button

In this step, the switch button will be configured as per the following USER_BUTTON design schematic on SAM E54 Xplained Ultra Evaluation Kit.

user_button_schematic.png

Configure EIC Pin

1

In the MHC, select the Pin Settings tab and then scroll down to 122 in the Pin Number column and configure the PORT pin PB31 as an external interrupt pin for switch functionality as shown below. Internal pull-up is enabled to avoid false edge detection as there is no external pull-up on the SAM E54 Xplained Pro Evaluation Kit.

eic_pin_configuration.png

Configure EIC Peripheral

2

Select the Project Graph tab.

3

Under the Available Components tab, expand Peripherals > EIC.
Select and double click on EIC to add the EIC module to the project.

eic_peripheral_adding.png

4

Configure the EIC block to generate an interrupt every time the user presses the switch SW0 as shown below, and enable filter functionality to avoid electrical noise on switch pin.

eic_configuration_setup.png

In the Peripheral Clock Configuration, EIC is by default connected to the GCLK1. However, the EIC clock configuration is set to run at 32 kHz using the OSCULP32K source clock directly, as defined in the Configuration Options of the EIC peripheral.

This completes the configuration of the EIC PLIB. The EIC is configured to produce an interrupt that will wake up the device from Sleep mode whenever the switch is pressed. The EIC is configured to run on the internal low power 32 kHz clock regardless of its configuration in the Peripheral Clock Configuration.

Step 3.3: Configure Event System (EVSYS) PLIB

1

The EVSYS is added by default to the project graph. Launch the Event System Configuration window by clicking on Tools > Event System Configuration.

open_evsys_configuration.png

Once open, you will see following window on your screen:

event_0_easy_view_not_configured.png

2

Configure the EVSYS channel 0 on the Event System Manager window:

  • Add Event Sytem channel and user by clicking Add Channel and Add User buttons.
  • Set the Real-Time Clock Compare 0 (RTC_CMP_0) event as the event generator. The event is configured to appear asynchronously and to run in Standby mode with the on-demand feature enabled.
  • Set the ADC Start of Conversion (ADC_START) as the event user.
event_0_easy_view.png

Make sure that the status of the event and user (Event Status and User Ready) is green. If it is red, verify that the Event Output and Event Input are enabled in the respective PLIB configuration (RTC and ADC in this application example).



Next Step >

© 2024 Microchip Technology, Inc.
Notice: ARM and Cortex are the registered trademarks of ARM Limited in the EU and other countries.
Information contained on this site regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.