Difference between revisions of "Audio services"
Line 10: | Line 10: | ||
== OpenAudioOut == | == OpenAudioOut == | ||
− | Takes two u64s (an interface ID and a PID placeholder?), a PID, a process handle, and the name of the interface you want to connect to. Returns an [[#IAudioOut]] object. | + | Takes two u64s (an interface ID and a PID placeholder?), a PID, a process handle, and the name of the interface you want to connect to. Returns an [[#IAudioOut]] object and four u32s: the sample rate, channel count, PCM format, and an unknown field. PCM format 2 is INT16. |
== IAudioOut == | == IAudioOut == | ||
Line 23: | Line 23: | ||
| 2 || StopAudioOut | | 2 || StopAudioOut | ||
|- | |- | ||
− | | 3 || AppendAudioOutBuffer | + | | 3 || [[#AppendAudioOutBuffer]] taking a type 0x5 (A descriptor) buffer |
|- | |- | ||
− | | 4 || RegisterBufferEvent | + | | 4 || [[#RegisterBufferEvent]] |
|- | |- | ||
− | | 5 || GetReleasedAudioOutBuffer | + | | 5 || [[#GetReleasedAudioOutBuffer]] taking a type 0x6 (B descriptor) buffer |
|- | |- | ||
| 6 || ContainsAudioOutBuffer | | 6 || ContainsAudioOutBuffer | ||
+ | |- | ||
+ | | 7 || [[#AppendAudioOutBuffer]] taking a type 0x21 buffer | ||
+ | |- | ||
+ | | 8 || [[#GetReleasedAudioOutBuffer]] taking a type 0x22 buffer | ||
|} | |} | ||
Line 36: | Line 40: | ||
Returns an AudioOutState, 0x00=Started 0x01=Stopped | Returns an AudioOutState, 0x00=Started 0x01=Stopped | ||
− | = | + | === AppendAudioOutBuffer === |
+ | |||
+ | Takes a u64 (not sure what this is, might act as some sort of identifier for the audio buffer? official applications seem to use the address of the audio buffer struct for this) and a buffer. | ||
+ | The format of said buffer is as follows: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
− | ! | + | ! Offset || Size || Description |
|- | |- | ||
− | | | + | | 0x00 || 8 || Pointer to the sample data pointer. |
|- | |- | ||
− | | | + | | 0x08 || 8 || Pointer to sample data. |
− | | | ||
− | |||
− | |||
− | |||
− | |||
|- | |- | ||
− | + | | 0x10 || 8 || Capacity of sample buffer | |
|- | |- | ||
− | | | + | | 0x18 || 8 || Size of data in sample buffer |
|- | |- | ||
− | | | + | | 0x20 || 8 || Unknown. Zero works. |
|} | |} | ||
− | == | + | === RegisterBufferEvent === |
− | + | Returns an event handle that is signalled when a buffer is released | |
− | == | + | === GetReleasedAudioOutBuffer === |
− | Takes | + | Takes a buffer, which it will fill with the identifiers passed from [[#AppendAudioOutBuffer]] of audio buffers that have been released. Will return a u32 (may indicate how many buffers were released?) |
= audin:u = | = audin:u = | ||
Line 100: | Line 102: | ||
Returns an AudioInState, 0x00=Started 0x01=Stopped | Returns an AudioInState, 0x00=Started 0x01=Stopped | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
= audrec:u = | = audrec:u = | ||
Line 194: | Line 166: | ||
| 6 || StopAudioRenderer | | 6 || StopAudioRenderer | ||
|- | |- | ||
− | | 7 || | + | | 7 || Unknown |
|- | |- | ||
| 8 || SetAudioRendererRenderingTimeLimit | | 8 || SetAudioRendererRenderingTimeLimit | ||
Line 200: | Line 172: | ||
| 9 || GetAudioRendererRenderingTimeLimit | | 9 || GetAudioRendererRenderingTimeLimit | ||
|} | |} | ||
+ | |||
+ | = audout:a, audin:a, audrec:a and audren:a = | ||
+ | |||
+ | {| class="wikitable" border="1" | ||
+ | |- | ||
+ | ! Cmd || Name | ||
+ | |- | ||
+ | | 0 || RequestSuspend | ||
+ | |- | ||
+ | | 1 || RequestResume | ||
+ | |} | ||
+ | |||
+ | = audout:d, audin:d, audrec:d and audren:d = | ||
+ | |||
+ | {| class="wikitable" border="1" | ||
+ | |- | ||
+ | ! Cmd || Name | ||
+ | |- | ||
+ | | 0 || [[#RequestSuspendForDebug]] | ||
+ | |- | ||
+ | | 1 || [[#RequestResumeForDebug]] | ||
+ | |} | ||
+ | |||
+ | == RequestSuspendForDebug == | ||
+ | |||
+ | Takes an [[AM_services#AppletResourceUserId|AppletResourceUserId]]. (u64) | ||
+ | |||
+ | == RequestResumeForDebug == | ||
+ | |||
+ | Takes an [[AM_services#AppletResourceUserId|AppletResourceUserId]]. (u64) | ||
= codecctl = | = codecctl = |
Revision as of 22:09, 30 December 2017
audout:u
Cmd | Name |
---|---|
0 | ListAudioOuts |
1 | #OpenAudioOut |
OpenAudioOut
Takes two u64s (an interface ID and a PID placeholder?), a PID, a process handle, and the name of the interface you want to connect to. Returns an #IAudioOut object and four u32s: the sample rate, channel count, PCM format, and an unknown field. PCM format 2 is INT16.
IAudioOut
Cmd | Name |
---|---|
0 | #GetAudioOutState |
1 | StartAudioOut |
2 | StopAudioOut |
3 | #AppendAudioOutBuffer taking a type 0x5 (A descriptor) buffer |
4 | #RegisterBufferEvent |
5 | #GetReleasedAudioOutBuffer taking a type 0x6 (B descriptor) buffer |
6 | ContainsAudioOutBuffer |
7 | #AppendAudioOutBuffer taking a type 0x21 buffer |
8 | #GetReleasedAudioOutBuffer taking a type 0x22 buffer |
GetAudioOutState
Returns an AudioOutState, 0x00=Started 0x01=Stopped
AppendAudioOutBuffer
Takes a u64 (not sure what this is, might act as some sort of identifier for the audio buffer? official applications seem to use the address of the audio buffer struct for this) and a buffer. The format of said buffer is as follows:
Offset | Size | Description |
---|---|---|
0x00 | 8 | Pointer to the sample data pointer. |
0x08 | 8 | Pointer to sample data. |
0x10 | 8 | Capacity of sample buffer |
0x18 | 8 | Size of data in sample buffer |
0x20 | 8 | Unknown. Zero works. |
RegisterBufferEvent
Returns an event handle that is signalled when a buffer is released
GetReleasedAudioOutBuffer
Takes a buffer, which it will fill with the identifiers passed from #AppendAudioOutBuffer of audio buffers that have been released. Will return a u32 (may indicate how many buffers were released?)
audin:u
Cmd | Name |
---|---|
0 | ListAudioIns |
1 | OpenAudioIn |
IAudioIn
Cmd | Name |
---|---|
0 | #GetAudioInState |
1 | StartAudioIn |
2 | StopAudioIn |
3 | AppendAudioInBuffer |
4 | RegisterBufferEvent |
5 | GetReleasedAudioInBuffer |
6 | ContainsAudioInBuffer |
GetAudioInState
Returns an AudioInState, 0x00=Started 0x01=Stopped
audrec:u
Cmd | Name |
---|---|
0 | OpenFinalOutputRecorder |
IFinalOutputRecorder
Cmd | Name |
---|---|
0 | GetFinalOutputRecorderState |
1 | StartFinalOutputRecorder |
2 | StopFinalOutputRecorder |
3 | AppendFinalOutputRecorderBuffer |
4 | RegisterBufferEvent |
5 | GetReleasedFinalOutputRecorderBuffer |
6 | ContainsFinalOutputRecorderBuffer |
audren:u
Cmd | Name |
---|---|
0 | OpenAudioRenderer |
1 | GetAudioRendererWorkBufferSize |
2 | GetAudioRenderersProcessMasterVolume |
3 | SetAudioRenderersProcessMasterVolume |
IAudioRenderer
Cmd | Name |
---|---|
0 | GetAudioRendererSampleRate |
1 | GetAudioRendererSampleCount |
2 | GetAudioRendererMixBufferCount |
3 | GetAudioRendererState |
4 | RequestUpdateAudioRenderer |
5 | StartAudioRenderer |
6 | StopAudioRenderer |
7 | Unknown |
8 | SetAudioRendererRenderingTimeLimit |
9 | GetAudioRendererRenderingTimeLimit |
audout:a, audin:a, audrec:a and audren:a
Cmd | Name |
---|---|
0 | RequestSuspend |
1 | RequestResume |
audout:d, audin:d, audrec:d and audren:d
Cmd | Name |
---|---|
0 | #RequestSuspendForDebug |
1 | #RequestResumeForDebug |
RequestSuspendForDebug
Takes an AppletResourceUserId. (u64)
RequestResumeForDebug
Takes an AppletResourceUserId. (u64)
codecctl
Cmd | Name |
---|---|
0 | InitializeCodecController |
1 | FinalizeCodecController |
2 | SleepCodecController |
3 | WakeCodecController |
4 | #SetCodecVolume |
5 | GetCodecVolumeMax |
6 | GetCodecVolumeMin |
7 | SetCodecActiveTarget |
8 | Unknown |
9 | BindCodecHeadphoneMicJackInterrupt |
10 | IsCodecHeadphoneMicJackInserted |
11 | ClearCodecHeadphoneMicJackInterrupt |
12 | IsCodecDeviceRequested |
SetCodecVolume
Takes a Volume (uint32)