Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Constify and use the correct size for an array | Chris Robinson | 2016-07-17 | 1 | -1/+1 |
| | |||||
* | Make a MAX_AMBI2D_COEFFS macro instead of a magic number | Chris Robinson | 2016-07-17 | 1 | -4/+4 |
| | |||||
* | Repack the ambisonic dual-band decoder matrices | Chris Robinson | 2016-07-17 | 1 | -94/+105 |
| | | | | | | The decoders use a row of the HF decoder matrix followed by a row of the LF decoder matrix, for each given output channel in turn. Packing the two matrices accordingly results in less memory hopping. | ||||
* | Improve the UHJ encoder's allpass processing loops | Chris Robinson | 2016-07-14 | 1 | -49/+70 |
| | |||||
* | Modify bs2b_cross_feed to do multiple samples at once | Chris Robinson | 2016-07-13 | 2 | -23/+73 |
| | |||||
* | Move the input channel array out of the DirectParams and SendParams | Chris Robinson | 2016-07-13 | 2 | -75/+74 |
| | |||||
* | Enumerate the embedded HRTF resources when available | Chris Robinson | 2016-07-12 | 1 | -3/+345 |
| | |||||
* | Add a cmake option to embed the HRTF data | Chris Robinson | 2016-07-12 | 2 | -0/+9 |
| | |||||
* | Store the voice output buffers separate from the params | Chris Robinson | 2016-07-11 | 2 | -34/+34 |
| | |||||
* | Update comment about the source radius calculations | Chris Robinson | 2016-07-10 | 1 | -9/+18 |
| | |||||
* | Avoid standard malloc/free for Hrtf allocation | Chris Robinson | 2016-07-07 | 1 | -3/+4 |
| | |||||
* | Avoid function calls to get the HRTF sample rate and IR size | Chris Robinson | 2016-07-07 | 6 | -36/+21 |
| | |||||
* | Avoid using memcpy to copy a single struct | Chris Robinson | 2016-07-06 | 1 | -4/+4 |
| | |||||
* | Remove the VirtOut buffer alias | Chris Robinson | 2016-07-05 | 2 | -24/+21 |
| | |||||
* | Use separate arrays for UIntMap keys and values | Chris Robinson | 2016-07-04 | 1 | -3/+3 |
| | |||||
* | Ensure voices has been updated once before mixing them | Chris Robinson | 2016-06-16 | 1 | -1/+2 |
| | | | | | | | | Sometimes the mixer is temporarily prevented from applying updates, when multiple sources need to be updated simultaneously for example, but does not prevent mixing. If the mixer runs during that time and a voice was just started, it would've mixed the voice without any internal properties being set for it. | ||||
* | Rename MaxNoOfSources for consistency | Chris Robinson | 2016-06-08 | 1 | -15/+15 |
| | |||||
* | Look in the executable's dir for another config file | Chris Robinson | 2016-06-04 | 3 | -0/+133 |
| | | | | | On Windows it'll look for alsoft.ini, and elsewhere is alsoft.conf. This applies after the user-local settings and before ALSOFT_CONF. | ||||
* | Add property queries to get the device latency with the clock | Chris Robinson | 2016-06-03 | 1 | -11/+32 |
| | |||||
* | Improve the filter processing function | Chris Robinson | 2016-06-03 | 1 | -2/+35 |
| | |||||
* | Implement a Neon-enhanced MixRow | Chris Robinson | 2016-06-01 | 3 | -0/+31 |
| | |||||
* | Use a macro to specify the ambisonic periphonic channel mask | Chris Robinson | 2016-06-01 | 2 | -3/+3 |
| | |||||
* | Use SSE for applying the HQ B-Format decoder matrices | Chris Robinson | 2016-05-31 | 4 | -27/+79 |
| | |||||
* | Don't access the band splitter fields in the processing loops | Chris Robinson | 2016-05-31 | 1 | -9/+16 |
| | | | | | | perf shows a 5% drop in relative execution time on the alffplay example with an audio-only file (20% to 15%). Kinda figured the optimizer would handle it better, but I guess not. | ||||
* | Clean up a couple variable names and declarations | Chris Robinson | 2016-05-30 | 2 | -7/+6 |
| | |||||
* | Remove unnecessary VECTOR_INSERT | Chris Robinson | 2016-05-30 | 2 | -54/+30 |
| | |||||
* | Use a linked list for active effect slots | Chris Robinson | 2016-05-29 | 2 | -23/+25 |
| | |||||
* | Change the backend getLatency method to return the clock time too | Chris Robinson | 2016-05-28 | 14 | -50/+111 |
| | | | | | | This will also allow backends to better synchronize the tracked clock time with the device output latency, without necessarily needing to lock if the backend API can allow for it. | ||||
* | Use a specific lock for the backend's stop/reset/play calls | Chris Robinson | 2016-05-27 | 1 | -30/+44 |
| | | | | | This helps protect against the device changing unexpectedly from multiple threads, instead of using the global list/library lock. | ||||
* | Increment the device's mix count closer to the mixing loops | Chris Robinson | 2016-05-23 | 1 | -3/+2 |
| | |||||
* | Properly pluralize some messages | Chris Robinson | 2016-05-22 | 2 | -8/+14 |
| | |||||
* | Improve locking for device attribute queries | Chris Robinson | 2016-05-22 | 1 | -8/+28 |
| | | | | | Avoids the backend device lock, instead using the list lock to prevent the device from changing while being queried, and adds some missing locks. | ||||
* | Avoid using realloc in a number of places | Chris Robinson | 2016-05-21 | 6 | -19/+26 |
| | |||||
* | Make the source position calues atomic | Chris Robinson | 2016-05-19 | 2 | -9/+9 |
| | |||||
* | Copy the source's Looping property into the voice | Chris Robinson | 2016-05-18 | 1 | -0/+2 |
| | |||||
* | Avoid redundantly storing distance model settings | Chris Robinson | 2016-05-17 | 1 | -7/+1 |
| | |||||
* | Update the right effect state when the device is reset | Chris Robinson | 2016-05-17 | 1 | -2/+2 |
| | |||||
* | Don't assume the "real" output buffer follows the dry buffer | Chris Robinson | 2016-05-17 | 1 | -15/+44 |
| | |||||
* | Improve reverb panning gains for "3D" output. | Chris Robinson | 2016-05-17 | 1 | -8/+8 |
| | |||||
* | Ignore the listening angle for the wet path sound cones | Chris Robinson | 2016-05-16 | 1 | -32/+51 |
| | | | | | | | Since the wet path is essentially the room response to a sound, the direction of the sound to the listener doesn't change the amount of energy the room receives. Instead, the surface area defined by the cones dictate the volume the room gets for the sound. | ||||
* | Use floats for the listener transforms | Chris Robinson | 2016-05-16 | 2 | -66/+28 |
| | |||||
* | Don't store the source's update method with the voice | Chris Robinson | 2016-05-16 | 1 | -38/+42 |
| | |||||
* | Avoid separate updates to sources that should apply together | Chris Robinson | 2016-05-15 | 2 | -12/+19 |
| | |||||
* | Allocate context storage before starting/resetting the device | Chris Robinson | 2016-05-15 | 1 | -19/+23 |
| | | | | | In case allocation fails, we don't have to worry about the playing status of the backend. | ||||
* | Avoid using a flag to specify if the effect state needs to be updated | Chris Robinson | 2016-05-15 | 2 | -6/+10 |
| | | | | | This fixes a potential missed state change if an update with a new state got replaced with one that doesn't. | ||||
* | Provide asynchronous property updates for sources | Chris Robinson | 2016-05-14 | 3 | -181/+153 |
| | | | | | | | | | | | | | | | | | | | | | | | | | This necessitates a change in how source updates are handled. Rather than just being able to update sources when a dependent object state is changed (e.g. a listener gain change), now all source updates must be proactively provided. Consequently, apps that do not utilize any deferring (AL_SOFT_defer_updates or alcSuspendContext/alcProcessContext) may utilize more CPU since it'll be filling out more update containers for the mixer thread to use. The upside is that there's less blocking between the app's calling thread and the mixer thread, particularly for vectors and other multi-value properties (filters and sends). Deferring behavior when used is also improved, since updates that shouldn't be applied yet are simply not provided. And when they are provided, the mixer doesn't have to ignore them, meaning the actual deferring of a context doesn't have to synchrnously force an update -- the process call will send any pending updates, which the mixer will apply even if another deferral occurs before the mixer runs, because it'll still be there waiting on the next mixer invocation. There is one slight bug introduced by this commit. When a listener change is made, or changes to multiple sources while updates are being deferred, it is possible for the mixer to run while the sources are prepping their updates, causing some of the source updates to be seen before the other. This will be fixed in short order. | ||||
* | Store the remaining context properties with the listener properties | Chris Robinson | 2016-05-13 | 1 | -2/+6 |
| | |||||
* | Get rid of an unnecessary copy of ALeffectProps | Chris Robinson | 2016-05-13 | 12 | -61/+59 |
| | |||||
* | Recognize AUX0...AUX15 for decoder speaker labels | Chris Robinson | 2016-05-12 | 1 | -3/+11 |
| | |||||
* | Hold the effect and filter maps while handling effects and filters | Chris Robinson | 2016-05-12 | 1 | -8/+0 |
| |