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_capture.c | |
parent | c7e516625377682250abbc56abb5f10cd8e9b75d (diff) | |
parent | 7994935696dcf9d81888e2d9d991f4b6a3e00738 (diff) |
Merge branch 'master' into msgenc_refactor
Diffstat (limited to 'arm7/lib/src/SND_capture.c')
-rw-r--r-- | arm7/lib/src/SND_capture.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/arm7/lib/src/SND_capture.c b/arm7/lib/src/SND_capture.c new file mode 100644 index 00000000..57494b72 --- /dev/null +++ b/arm7/lib/src/SND_capture.c @@ -0,0 +1,25 @@ +#include "SND_capture.h" + +#include "registers.h" + +enum SNDLoop +{ + SND_CAP_LOOP = 0, + SND_CAP_ONESHOT = 1 +}; + +void SND_SetupCapture( + int idx, int format, void *captureData, int size, BOOL loop, int capCtrlSrc, int capCtrlDst) +{ + int off = idx * 8; + + reg_SNDCAPxCNT(idx) = (u8)((format << 3) | ((loop ? SND_CAP_LOOP : SND_CAP_ONESHOT) << 2) | + (capCtrlSrc << 1) | capCtrlDst); + *(vu32 *)(0x4000510 + off) = (u32)captureData; + *(vu16 *)(0x4000514 + off) = (u16)size; +} + +BOOL SND_IsCaptureActive(int idx) +{ + return (reg_SNDCAPxCNT(idx) & 0x80) != 0; +} |