Skip to content

Latest commit

 

History

History
93 lines (55 loc) · 6.78 KB

File metadata and controls

93 lines (55 loc) · 6.78 KB

Platform - Timer cascading

Type badge Technology badge License badge SDK badge Build badge Flash badge RAM badge

Overview

This project cascades two timers (TIMER0 and TIMER1) to be able to utilize a virtual timer peripheral, that has a bigger precision due to the extended bit size. The cascading is implemented in two different ways via PRS and the default linked conenction interface.

Gecko SDK version

  • GSDK v4.4.3

Hardware Required

Note:

Connections Required

Connect the board via the connector cable to your PC to flash the example.

Setup

To test this application, you can either create a project based on an example project or start with an "Empty C Project" project based on your hardware.

Create a project based on an example project

  1. Make sure that this repository is added to Preferences > Simplicity Studio > External Repos.

  2. From the Launcher Home, add your product name to My Products, click on it, and click on the EXAMPLE PROJECTS & DEMOS tab. Find the example project filtering by "cascading".

  3. Click the Create button on Platform - Timer cascading example. Example project creation dialog pops up -> click Create and Finish and the project should be generated.

create_project

  1. Build and flash this example to the board.

Start with an "Empty C Project" project

  1. Create an Empty C Project project for your hardware using Simplicity Studio 5.

  2. Copy all files in the inc and src folders into the project root folder (overwriting the existing file).

  3. Install the software components:

    3.1. Open the .slcp file in the project

    3.2. Select the SOFTWARE COMPONENTS tab

    3.3. Install the following components:

    • [Platform] → [Peripheral] → [GPIO]

    • [Platform] → [Peripheral] → [PRS]

    • [Platform] → [Peripheral] → [TIMER]

  4. Build and flash the project to your board.

How It Works

The example uses two timers (TIMER0 and TIMER1), that are available on all of the Series 2 device MCUs. TIMER0 is a 32-bit generic timer with 3 compare/capture channels, whereas TIMER1 can be both 32-bit and 16-bit long depending on the selected device, thus the maximum precision reachable by the application is 64-bit or 48-bit respectively.

The application defines the PRS_MODE macro to switch between the default timer connection interface and the PRS peripheral to connect the two timers together.

When the timer connection interface is used (PRS_MODE = 0), the timers are only allowed to count on overflow/underflow events from the lower numbered neighbouring timers to create a larger timer. This also means, that all timers must be set to count the same direction and less significant timer(s) can only be set to count up or down.

When PRS is used (PRS_MODE = 1), there are no constraints on which timer instances can be used with one another.

A specific output frequency can be on TIMER0 via the TIMER0_OUT_FREQ macro, which makes it easier to test the connection between the peripherals, whereas TIMER1_TOP sets the top value of the second timer. By default, both timers' output are routed to LED0 and LED1 respectively and a frequency of 1Hz is set for TIMER0, which is then devided by setting TIMER1_TOP.

The theoretical maximum precision achievable by the cascaded timers are defined by the bit count of each timer and the top values' configurations. If two 32-bit timers are used and the top values are set to the highest possible number (0xFFFFFFFF) then the combined precision on TIMER1's output reaches 64-bits.