diff options
author | PikalaxALT <PikalaxALT@users.noreply.github.com> | 2021-08-28 17:02:46 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-08-28 17:02:46 -0400 |
commit | 118a959ee77459bb3a663b182183b66499acb95e (patch) | |
tree | 3dc6e2460fe72b1fae23c6b53ac0ef52ba5986f6 /arm7/lib/src/SND_alarm.c | |
parent | c7e516625377682250abbc56abb5f10cd8e9b75d (diff) | |
parent | 7994935696dcf9d81888e2d9d991f4b6a3e00738 (diff) |
Merge branch 'master' into msgenc_refactor
Diffstat (limited to 'arm7/lib/src/SND_alarm.c')
-rw-r--r-- | arm7/lib/src/SND_alarm.c | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/arm7/lib/src/SND_alarm.c b/arm7/lib/src/SND_alarm.c new file mode 100644 index 00000000..9b71d8f3 --- /dev/null +++ b/arm7/lib/src/SND_alarm.c @@ -0,0 +1,83 @@ +#include "SND_alarm.h" + +#include "OS_alarm.h" +#include "OS_tick.h" +#include "PXI_fifo.h" +#include "SND_work.h" + +static void AlarmHandler(void *msg); + +void SND_AlarmInit(void) +{ + for (s32 i = 0; i < SND_ALARM_COUNT; i++) + { + SNDi_Work.alarms[i].enable = 0; + SNDi_Work.alarms[i].id = 0; + } +} + +void SND_SetupAlarm(s32 idx, OSTick tick, OSTick period, u32 id) +{ + struct SNDAlarm *alarm = &SNDi_Work.alarms[idx]; + + if (alarm->enable) + { + OS_CancelAlarm(&alarm->alarm); + alarm->enable = 0; + } + + alarm->tick = tick; + alarm->period = period; + alarm->id = (u8)id; +} + +void SND_StartAlarm(s32 idx) +{ + OSTick tick; + OSTick period; + + struct SNDAlarm *alarm = &SNDi_Work.alarms[idx]; + + if (alarm->enable != 0) + { + OS_CancelAlarm(&alarm->alarm); + alarm->enable = 0; + } + + tick = alarm->tick; + period = alarm->period; + s32 arg = idx | (alarm->id << 8); + + OS_CreateAlarm(&alarm->alarm); + + if (period == 0) + { + OS_SetAlarm(&alarm->alarm, tick, AlarmHandler, (void *)arg); + } + else + { + OS_SetPeriodicAlarm(&alarm->alarm, tick + OS_GetTick(), period, AlarmHandler, (void *)arg); + } + + alarm->enable = 1; +} + +void SND_StopAlarm(s32 idx) +{ + struct SNDAlarm *alarm = &SNDi_Work.alarms[idx]; + + if (alarm->enable != 0) + { + OS_CancelAlarm(&alarm->alarm); + alarm->id++; + alarm->enable = 0; + } +} + +static void AlarmHandler(void *msg) +{ + while (PXI_SendWordByFifo(7, (u32)msg, 0) < 0) + { + // nothing + } +} |