summaryrefslogtreecommitdiff
path: root/arm7/lib/src/SND_exChannel.c
diff options
context:
space:
mode:
authorMichael Panzlaff <michael.panzlaff@fau.de>2021-08-01 03:09:03 +0200
committerMichael Panzlaff <michael.panzlaff@fau.de>2021-08-25 18:03:49 +0200
commit72f92a37748688de99ad007f3d221853c394f203 (patch)
tree0ecabca2eb5417cc2c947a10de263ad9bff88521 /arm7/lib/src/SND_exChannel.c
parent80b1041da789f4c83318287ca59c5f95ae84fb6a (diff)
arm7: merge SND_lockChannel into SND_exChannel
Diffstat (limited to 'arm7/lib/src/SND_exChannel.c')
-rw-r--r--arm7/lib/src/SND_exChannel.c76
1 files changed, 75 insertions, 1 deletions
diff --git a/arm7/lib/src/SND_exChannel.c b/arm7/lib/src/SND_exChannel.c
index 7919b5f7..f3ba922b 100644
--- a/arm7/lib/src/SND_exChannel.c
+++ b/arm7/lib/src/SND_exChannel.c
@@ -3,7 +3,6 @@
#include "SND_channel.h"
#include "SND_main.h"
#include "SND_work.h"
-#include "SND_lockChannel.h"
#include "SND_util.h"
#include "registers.h"
@@ -12,6 +11,9 @@
extern u8 sChannelAllocationOrder[SND_CHANNEL_COUNT];
extern u8 sAttackCoeffTable[19];
+static u32 sLockedChannelMask;
+static u32 sWeakLockedChannelMask;
+
void SND_ExChannelInit(void) {
struct SNDExChannel *chn;
s32 i;
@@ -344,3 +346,75 @@ void SND_FreeExChannel(struct SNDExChannel *chn) {
chn->callbackUserData = NULL;
}
}
+
+void SND_StopUnlockedChannel(u32 channelMask, u32 weak) {
+ (void)weak;
+
+ struct SNDExChannel *chn;
+
+ for (int i = 0; i < SND_CHANNEL_COUNT && channelMask != 0; i++, channelMask >>= 1) {
+ if ((channelMask & 1) == 0)
+ continue;
+
+ chn = &SNDi_Work.channels[i];
+
+ if (sLockedChannelMask & (1 << i))
+ continue;
+
+ if (chn->callback)
+ chn->callback(chn, 0, chn->callbackUserData);
+
+ SND_StopChannel(i, 0);
+ chn->priority = 0;
+ SND_FreeExChannel(chn);
+ chn->flags.syncFlag = 0;
+ chn->flags.active = 0;
+ }
+}
+
+void SND_LockChannel(u32 channelMask, u32 weak) {
+ struct SNDExChannel *chn;
+ u32 j = channelMask;
+ int i = 0;
+
+ for (; i < SND_CHANNEL_COUNT && j != 0; i++, j >>= 1) {
+ if ((j & 1) == 0)
+ continue;
+
+ chn = &SNDi_Work.channels[i];
+
+ if (sLockedChannelMask & (1 << i))
+ continue;
+
+ if (chn->callback)
+ chn->callback(chn, 0, chn->callbackUserData);
+
+ SND_StopChannel(i, 0);
+ chn->priority = 0;
+ SND_FreeExChannel(chn);
+ chn->flags.syncFlag = 0;
+ chn->flags.active = 0;
+ }
+
+ if (weak & 1) {
+ sWeakLockedChannelMask |= channelMask;
+ } else {
+ sLockedChannelMask |= channelMask;
+ }
+}
+
+void SND_UnlockChannel(u32 channelMask, u32 weak) {
+ if (weak & 1) {
+ sWeakLockedChannelMask &= ~channelMask;
+ } else {
+ sLockedChannelMask &= ~channelMask;
+ }
+}
+
+u32 SND_GetLockedChannel(u32 weak) {
+ if (weak & 1) {
+ return sWeakLockedChannelMask;
+ } else {
+ return sLockedChannelMask;
+ }
+}