Timer 1

Description

Execution timing and event counting, for use within task iterations

This resource provides access to AUX Timer 1 for use within task code blocks.

AUX Timer 1 is an 8-bit timer with a 2^N prescaler, where N is between 0 and 15.

The timer can either increment on each clock cycle, or on each edge of a selected tick source.

The timer counts up to the specified delay value, pulses an event output signal, and either stops or restarts from 0. The event signal can either be waited for in task code, or it can be used as a trigger signal, for example for the ADC.

The following operations are supported:

  • Start the timer in single or periodical event mode
    • Without tick source: The timer increments at the Sensor Controller clock rate used in the current power mode
    • With tick source: The timer increments at the selected edge of the selected tick source event signal
  • Wait for the timer event
  • Check whether the timer is running (the single event has not yet occurred)
  • Stop the timer

The timer must be stopped before exiting the task code block where it has been used.

Note: This resource uses the AUX Timer 1 hardware module. The following procedures cannot be called while AUX Timer 1 is in use by this resource (started by timer1Start() , stopped by timeout in single mode or by timer1Stop() ):

  • evhSetupTimer1Trigger()
  • rtcmecCheckCaptEv()
  • rtcmecClearCapt()
  • rtcmecInit()
  • rtcmecSetPeriod()

Examples

Single Event

// Generate timer event after 100 us
timer1Start(TIMER1_MODE_SINGLE, 150, 4);
gpioSetOutput(AUXIO_O_LED);

// Wait for the timeout
timer1Wait();
gpioClearOutput(AUXIO_O_LED);

Periodical Events

// Generate timer events at every 100 us
timer1Start(TIMER1_MODE_PERIODICAL, 150, 4);

// Generate one pulse right away
gpioSetOutput(AUXIO_O_LED);
gpioClearOutput(AUXIO_O_LED);

// Generate another 3 pulses
for (U16 n = 0; n < 3; n++) {

    // Wait for timer event before generating each pulse
    timer1Wait();
    gpioSetOutput(AUXIO_O_LED);
    gpioClearOutput(AUXIO_O_LED);
}

// Stop the timer
timer1Stop();

Timeout

// Start an 4.8 ms timeout
timer1Start(TIMER1_MODE_SINGLE, 225, 9);

// Wait for sensor interrupt or timeout, whichever comes first
U16 interrupt;
do {

    // Check whether the timeout has occured
    U16 timer1IsRunning;
    timer1CheckState(timer1IsRunning);
    U16 timeout = timer1IsRunning ^ 0x0001;

    // Check whether the interrupt has occurred
    gpioGetInputValue(AUXIO_I_INTERRUPT; interrupt);

    U16 done = interrupt | timeout;
} while (done == 0);

// Stop the timer
timer1Stop();

Procedures Overview

Name Brief description
timer1CheckState() Checks whether AUX Timer 1 is currently running. More …
timer1Start() Sets up AUX Timer 1 to generate events, either one-shot after the specified delay or repeatedly at the specified interval. More …
timer1StartWithTickSrc() Sets up AUX Timer 1 to generate events, either one-shot after the specified delay or repeatedly at the specified interval. More …
timer1Stop() Stops AUX Timer 1 event generation. More …
timer1Wait() Waits for the next AUX Timer 1 event. More …

Constants

Name Description
TIMER1_MODE_PERIODICAL Timer 1 mode: Periodical events at the specified interval
TIMER1_MODE_SINGLE Timer 1 mode: Single event after the specified delay
TIMER1_TICKSRC_AUXIO_BASE Timer 1 tick source: AUXIO (base + index)
TIMER1_TICKSRC_AUX_ADC_DONE Timer 1 tick source: ADC done
TIMER1_TICKSRC_AUX_COMPA Timer 1 tick source: COMPA output
TIMER1_TICKSRC_AUX_COMPB Timer 1 tick source: COMPB output
TIMER1_TICKSRC_AUX_TIMER0_EV Timer 1 tick source: Timer 0 event

Global Variables

None.

Procedures

timer1CheckState

Prototype: timer1CheckState(isRunning)

Checks whether AUX Timer 1 is currently running.

After task code calls timer1Start() , this procedure returns 1 until task code calls timer1Stop() or the delay expires in single event mode.

Return value(s)

  • isRunning : 1 if AUX Timer 1 is running, otherwise 0

timer1Start

Prototype: timer1Start(#mode, mant, #exp)

Sets up AUX Timer 1 to generate events, either one-shot after the specified delay or repeatedly at the specified interval.

Parameter value(s)

  • #mode : Select single event or periodical events (TIMER1_MODE_XYZ)
  • mant : Delay/interval mantissa value (2-255). Resulting delay/interval is mant * 2^exp [Sensor Controller clock periods].
  • #exp : Delay/interval exponent value (0-15). Resulting delay/interval is mant * 2^exp [Sensor Controller clock periods].

timer1StartWithTickSrc

Prototype: timer1StartWithTickSrc(#tickSrc, #edge, #mode, mant, #exp)

Sets up AUX Timer 1 to generate events, either one-shot after the specified delay or repeatedly at the specified interval.

The timer increments when the selected edge occurs on the selected tick source event signal.

Parameter value(s)

  • #tickSrc : Select the event signal to count periodical events (TIMER1_TICKSRC_XYZ)
  • #edge : The event signal edge that shall increment the Timer 1 counter (1 = rising, 0 = falling)
  • #mode : Select single event or periodical events (TIMER1_MODE_XYZ)
  • mant : Timer 1 event delay/interval mantissa value (2-255). Resulting delay/interval is mant * 2^exp [tick source edges].
  • #exp : Timer 1 event delay/interval exponent value (0-15). Resulting delay/interval is mant * 2^exp [tick source edges].

timer1Stop

Prototype: timer1Stop()

Stops AUX Timer 1 event generation.

timer1Wait

Prototype: timer1Wait()

Waits for the next AUX Timer 1 event.

Note that this procedure must be called before the event occurs. Otherwise it will wait for the next event or block indefinitely in single event mode. In single event mode, use timer0CheckState() to check whether the timeout already has occurred.