Timer는 일정 시간 이후에 1회 실행될 작업, 매 일정 시간마다 실행될 작업 등을 위한 기능입니다.
More...
#include <Timer.hpp>
Timer는 일정 시간 이후에 1회 실행될 작업, 매 일정 시간마다 실행될 작업 등을 위한 기능입니다.
Timer는 MCU에 내장된 하드웨어 타이머의 기능을 소프트웨어에서 사용하기 위한 API를 제공합니다.
◆ isOneShot()
bool Timer::isOneShot |
( |
void |
| ) |
|
Timer가 1회성인지 확인합니다.
- Returns
- 작업함수를 1회만 호출하면 true 를, 반복적으로 호출하면 false 를 반환합니다.
◆ isRunning()
bool Timer::isRunning |
( |
| ) |
|
Timer가 활성화된 상태인지 확인한다.
- Returns
- 현재 활성화된 상태면 true 를, 아니면 false 를 반환합니다.
◆ onFired()
void Timer::onFired |
( |
void(*)(void *) |
func, |
|
|
void * |
args = nullptr |
|
) |
| |
타이머 만료시 실행시킬 작업함수를 지정합니다.
작업함수 func
는 args
인자와 함께 호출됩니다.
- Parameters
-
func | 작업함수의 포인터 |
args | 작업함수의 인자로 호출될 파라미터 |
◆ startOneShot()
bool Timer::startOneShot |
( |
uint32_t |
millis, |
|
|
bool |
interrupt = false |
|
) |
| |
작업함수를 millis
밀리초 이후 1회 실행합니다.
- Parameters
-
millis | 작업을 실행하기 까지의 대기 시간(단위:밀리초). 최대 값은 4294967 밀리초입니다. |
interrupt | true 이면, 작업을 실행할 때 interrupt 모드에서 바로 실행합니다. 현재 실행 중인 작업을 중단하고 해당 작업을 실행하므로 타이밍이 중요한 응용에서 사용할 수 있습니다. false 이면, 스케줄러에 작업을 등록하고 현재 실행 중인 작업이 완료된 후 실행합니다. |
- Returns
- 타이머 등록 성공 여부
- Warning
- 인터럽트 모드에서는 다른 인터럽트의 실행이 불가능할 수도 있습니다. 따라서 인터럽트 모드를 사용하여 타이머를 실행할 경우, 시간이 오래걸리는 작업, I/O 등의 제어를 최소화하고 가능한 빨리 종료하여야 합니다.
◆ startOneShotMicros()
bool Timer::startOneShotMicros |
( |
uint32_t |
micros, |
|
|
bool |
interrupt = false |
|
) |
| |
작업함수를 micros
마이크로초 이후 1회 실행합니다.
- Parameters
-
micros | 작업을 실행하기 까지의 대기 시간(단위: 마이크로초). 최대 값은 4294967295 마이크로초 입니다. |
interrupt | true 이면, 작업을 실행할 때 interrupt 모드에서 바로 실행합니다. 현재 실행 중인 작업을 중단하고 해당 작업을 실행하므로 타이밍이 중요한 응용에서 사용할 수 있습니다. false 이면, 스케줄러에 작업을 등록하고 현재 실행 중인 작업이 완료된 후 실행합니다. |
- Returns
- 타이머 등록 성공 여부
- Warning
- 인터럽트 모드에서는 다른 인터럽트의 실행이 불가능할 수도 있습니다. 따라서 인터럽트 모드를 사용하여 타이머를 실행할 경우, 시간이 오래걸리는 작업, I/O 등의 제어를 최소화하고 가능한 빨리 종료하여야 합니다.
◆ startPeriodic()
bool Timer::startPeriodic |
( |
uint32_t |
millis, |
|
|
bool |
interrupt = false |
|
) |
| |
작업함수를 매 millis
밀리초 주기로 반복하여 실행합니다.
- Parameters
-
millis | 작업을 실행할 주기(단위:밀리초). 최대 값은 4294967 밀리초입니다. |
interrupt | true 이면, 작업을 실행할 때 interrupt 모드에서 바로 실행합니다. 현재 실행 중인 작업을 중단하고 해당 작업을 실행하므로 타이밍이 중요한 응용에서 사용할 수 있습니다. false 이면, 스케줄러에 작업을 등록하고 현재 실행 중인 작업이 완료된 후 실행합니다. |
- Returns
- 타이머 등록 성공 여부
- Warning
- 인터럽트 모드에서는 다른 인터럽트의 실행이 불가능할 수도 있습니다. 따라서 인터럽트 모드를 사용하여 타이머를 실행할 경우, 시간이 오래걸리는 작업, I/O 등의 제어를 최소화하고 가능한 빨리 종료하여야 합니다.
◆ startPeriodicMicros()
bool Timer::startPeriodicMicros |
( |
uint32_t |
micros, |
|
|
bool |
interrupt = false |
|
) |
| |
작업함수를 매 micros
마이크로초 주기로 반복하여 실행합니다.
- Parameters
-
micros | 작업을 실행할 주기(단위: 마이크로초). 최대 값은 4294967295 마이크로초 입니다. |
interrupt | true 이면, 작업을 실행할 때 interrupt 모드에서 바로 실행합니다. 현재 실행 중인 작업을 중단하고 해당 작업을 실행하므로 타이밍이 중요한 응용에서 사용할 수 있습니다. false 이면, 스케줄러에 작업을 등록하고 현재 실행 중인 작업이 완료된 후 실행합니다. |
- Returns
- 타이머 등록 성공 여부
- Warning
- 인터럽트 모드에서는 다른 인터럽트의 실행이 불가능할 수도 있습니다. 따라서 인터럽트 모드를 사용하여 타이머를 실행할 경우, 시간이 오래걸리는 작업, I/O 등의 제어를 최소화하고 가능한 빨리 종료하여야 합니다.
The documentation for this class was generated from the following file:
- libnola-publisher/libnola-common/include/Timer.hpp