diff options
author | Rémi Calixte <remicalixte.rmc@gmail.com> | 2021-08-29 00:12:36 +0200 |
---|---|---|
committer | Rémi Calixte <remicalixte.rmc@gmail.com> | 2021-08-29 00:12:36 +0200 |
commit | c97046f4b518d53a2508c896b15fd467b6559346 (patch) | |
tree | 57ab33da23a252c502711be7c4d64b3a89f7fcf6 /arm7/lib/src/SND_work.c | |
parent | 8d383810aa08aa9594086ed2f8b3e6a50927d53c (diff) | |
parent | 7994935696dcf9d81888e2d9d991f4b6a3e00738 (diff) |
Merge branch 'master' into unk_02006D98
Diffstat (limited to 'arm7/lib/src/SND_work.c')
-rw-r--r-- | arm7/lib/src/SND_work.c | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/arm7/lib/src/SND_work.c b/arm7/lib/src/SND_work.c new file mode 100644 index 00000000..2256ee3f --- /dev/null +++ b/arm7/lib/src/SND_work.c @@ -0,0 +1,41 @@ +#include "SND_work.h" + +#include "SND_capture.h" +#include "SND_channel.h" +#include "SND_exChannel.h" + +struct SNDWork SNDi_Work; +struct SNDSharedWork *SNDi_SharedWork; + +void SND_SetPlayerLocalVariable(int player, int var, s16 value) +{ + SNDi_SharedWork->players[player].localVars[var] = value; +} + +void SND_SetPlayerGlobalVariable(int var, s16 value) +{ + SNDi_SharedWork->globalVars[var] = value; +} + +void SND_UpdateSharedWork(void) +{ + u16 channelActiveMask = 0; + u16 channelCaptureMask = 0; + + if (SNDi_SharedWork == NULL) + return; + + for (s32 i = 0; i < SND_CHANNEL_COUNT; i++) + { + if (SND_IsChannelActive(i)) + channelActiveMask |= 1 << i; + } + + if (SND_IsCaptureActive(0)) + channelCaptureMask |= 0x1; + if (SND_IsCaptureActive(1)) + channelCaptureMask |= 0x2; + + SNDi_SharedWork->channelStatus = channelActiveMask; + SNDi_SharedWork->captureStatus = channelCaptureMask; +} |