aboutsummaryrefslogtreecommitdiffstats
path: root/OpenAL32/Include
Commit message (Collapse)AuthorAgeFilesLines
* Check for and use copysignfChris Robinson2018-08-291-1/+1
|
* Use a separate method to warp the azimuth for plain stereo outputChris Robinson2018-08-291-6/+10
|
* EFX: Autowah implementationRaulshc2018-07-252-1/+11
| | | Add autowah effect using biquad peaking filter and envelope follower
* Correctly check byte order for newer Android compiler, fix #203Jan Niklas Hasse2018-06-201-2/+2
|
* Fix a couple property variable namesChris Robinson2018-05-221-3/+3
|
* Merge pull request #193 from Raulshc/Frequency-shifterkcat2018-05-222-1/+10
|\ | | | | EFX: Frequency shifter
| * EFX: Frequency Shifter implementationRaulshc2018-05-202-1/+10
| | | | | | Add frequency shifter effect using discrete Hilbert transform. Only mono signal processing by now (LEFT_DIRECTION).
* | Use the __BYTE_ORDER__ macro when availableChris Robinson2018-05-211-0/+4
|/
* Add a function to calculate coefficients from X, Y, Z componentsChris Robinson2018-05-171-10/+30
|
* Avoid using unsigned values for signedChris Robinson2018-05-151-0/+10
|
* Avoid unnecessary function-like macrosChris Robinson2018-05-151-5/+5
|
* Make a faster float2int method for x87 targetsChris Robinson2018-05-121-1/+24
|
* Fix MSVCChris Robinson2018-05-121-3/+3
|
* Fix non-SEE (32-bit) GCC buildsChris Robinson2018-05-121-1/+1
|
* Add and use a method for fast float roundingChris Robinson2018-05-121-0/+54
| | | | | Unlike fastf2i, this keeps the result as a float instead of converting to integer.
* Another fix attempt for 32-bit MSVCChris Robinson2018-05-041-5/+5
|
* Try to fix 32-bit MSVC buildsChris Robinson2018-05-041-1/+1
|
* Don't assume round-to-zero for fastf2iChris Robinson2018-05-041-21/+29
|
* Add a specific function for truncating float-to-int conversionsChris Robinson2018-05-031-0/+7
|
* Only use fast float-to-int workarounds for x87Chris Robinson2018-04-211-0/+18
| | | | | | At least SSE and ARM have opcodes that handle float-to-int conversions well enough. Also, Clang doesn't inline lrintf, incurring function call overhead for what should be a single opcode.
* Improve ASSUME for ClangChris Robinson2018-04-211-0/+9
| | | | | | | | For some reason, the { if(!x)__builtin_unreachable(); } construct does not provide the same optimization opportunity for Clang (even though the condition being false would trigger undefined behavior by reaching unreachable code, it still performs checks and such for the condition potentially being false). Using __builtin_assume seems to work better.
* Add an ASSUME macro that requires a true conditionChris Robinson2018-04-171-0/+17
|
* Rename BiquadState to BiquadFilterChris Robinson2018-04-041-4/+4
|
* Store the ALbufferlistitem's composited/max sample lengthChris Robinson2018-03-271-0/+1
|
* Rename ALfilterState/Type to BiquadState/TypeChris Robinson2018-03-231-4/+4
|
* Move NFC filters to the filter directoryChris Robinson2018-03-221-1/+1
|
* Move the filter implementation to a separate directoryChris Robinson2018-03-222-117/+3
|
* EFX:Pitch Shifter implementationRaulshc2018-03-182-1/+9
| | | Add pitch shifter effect using standard phase vocoder, based on work of Stephan Bernsee. Only mono signal processing by now.
* Apply a distance decay on the source send for the reverb's DecayLFRatioChris Robinson2018-03-111-0/+1
|
* Add extern "C" to some headersChris Robinson2018-03-091-17/+17
|
* Use function-like macros to call filter and effect vtable methodsChris Robinson2018-03-082-2/+18
|
* Fix struct forward declaration typoChris Robinson2018-03-081-1/+1
|
* Use a plain mutex for the property lockChris Robinson2018-03-031-2/+1
|
* Use atomic variables instead of volatileChris Robinson2018-03-021-2/+2
|
* Fix a comment regarding the effect slot channel scalingChris Robinson2018-02-281-3/+3
|
* Avoid AL prefix on internal effect state factory typesChris Robinson2018-02-281-20/+21
| | | | Also avoid using the generic V/V0 macros for them
* Avoid using static inline in headersChris Robinson2018-02-251-4/+4
|
* Don't make the source state atomicChris Robinson2018-02-241-1/+1
|
* Remove the unnecessary ComputeAmbientGainsChris Robinson2018-02-181-15/+0
|
* Combine multiple functions called sequentiallyChris Robinson2018-02-111-1/+1
|
* Use a function pointer for applying the dry mix post-processChris Robinson2018-02-102-2/+7
|
* Make the Connected state atomicChris Robinson2018-02-041-1/+1
| | | | Also don't send the Disconnected event more than once.
* Provide more descriptive messages to disconnection eventsChris Robinson2018-02-031-1/+1
|
* Add a disconnected event typeChris Robinson2018-02-032-1/+2
|
* Remove the unused thunk codeChris Robinson2018-02-021-20/+0
|
* Remove the individual source queue and buffer locksChris Robinson2018-02-022-3/+0
| | | | | | | They're inherently protected by the mutex for their respective lists. Should those mutexes be replaced by rwlocks the individual locks should also be reinstated, but they're unlikely to be unless a lot of contention starts happening in the read-only case.
* Store an index to a given source's voiceChris Robinson2018-02-011-0/+5
| | | | For more efficient voice lookups when needed.
* Use a semaphore to signal the event handlerChris Robinson2018-02-011-1/+1
| | | | | | | | | | | Semaphores allow for semi-persistent signals, compared to a condition variable which requires a mutex for proper detection. A semaphore can be 'post'ed after writing some data on one thread, and another thread will be able to recognize it quickly even if the post occured in between checking for data and waiting. This more correctly fixes a race condition with events since the mixer shouldn't be using mutexes, and arbitrary wake-ups just to make sure an event wasn't missed was quite inefficient.
* Send buffer completed events when enabledChris Robinson2018-02-011-1/+1
|
* Add a thread to marshal events from the mixerChris Robinson2018-01-311-1/+14
| | | | | | To avoid having unknown user code running in the mixer thread that could significantly delay the mixed output, a lockless ringbuffer is used for the mixer to provide events that a secondary thread will pop off and process.