Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Store filters in an array of lists | Chris Robinson | 2018-01-27 | 4 | -82/+164 |
| | |||||
* | Store effects in an array of lists | Chris Robinson | 2018-01-27 | 4 | -79/+160 |
| | |||||
* | Use a vector to store the effect slot pointers | Chris Robinson | 2018-01-27 | 4 | -81/+103 |
| | | | | And make the ID a simple index into it (1-base, to avoid ID 0). | ||||
* | Use an array lookup for source IDs | Chris Robinson | 2018-01-27 | 2 | -125/+204 |
| | | | | | This is now similar to buffers, being stored in groups of 64 in a vector with the ID providing the array indices. | ||||
* | Make some more functions static where they're used | Chris Robinson | 2018-01-27 | 2 | -21/+14 |
| | |||||
* | Add some casts to pacify MSVC | Chris Robinson | 2018-01-27 | 3 | -5/+6 |
| | |||||
* | Add a ctz64 fallback using _BitScanForward when available | Chris Robinson | 2018-01-27 | 1 | -1/+15 |
| | |||||
* | Check for _BitScanForward64 before using it | Chris Robinson | 2018-01-27 | 1 | -4/+4 |
| | |||||
* | Use a different method for storing and looking up buffers | Chris Robinson | 2018-01-27 | 4 | -100/+214 |
| | | | | | | | | | | | | | | | | | Rather than each buffer being individually allocated with a generated 'thunk' ID that's used with a uint:ptr map, buffers are allocated in arrays of 64 within a vector. Each group of 64 has an associated 64-bit mask indicating which are free to use, and the buffer ID is comprised of the two array indices which directly locate the buffer (no searching, binary or otherwise). Currently no buffers are actually deallocated after being allocated, though they are reused. So an app that creates a ton of buffers once, then deletes them all and uses only a couple from then on, will have a bit of waste, while an app that's more consistent with the number of used buffers won't be a problem. This can be improved by removing elements of the containing vector that contain all-free buffers while there are plenty of other free buffers. Also, this method can easily be applied to other resources, like sources. | ||||
* | Don't rely on alMain.h in alBuffer.h | Chris Robinson | 2018-01-26 | 2 | -71/+18 |
| | |||||
* | Make some functions static that are only used in one source | Chris Robinson | 2018-01-26 | 2 | -13/+12 |
| | |||||
* | Allow preserving converted samples | Chris Robinson | 2018-01-26 | 1 | -5/+5 |
| | |||||
* | Read the buffer unpack alignment under the buffer lock | Chris Robinson | 2018-01-26 | 1 | -69/+76 |
| | |||||
* | Improve error reporting for buffers | Chris Robinson | 2018-01-26 | 1 | -262/+269 |
| | |||||
* | Add the printf-format attribute to alSetError | Chris Robinson | 2018-01-25 | 3 | -50/+51 |
| | |||||
* | Construct error messages using parameterized values | Chris Robinson | 2018-01-25 | 11 | -401/+434 |
| | |||||
* | Use more appropriate enum values for events | Chris Robinson | 2018-01-24 | 1 | -7/+7 |
| | |||||
* | Add a deprecated event type for alDopplerVelocity | Chris Robinson | 2018-01-24 | 3 | -0/+15 |
| | |||||
* | Fix ordering of alGetPointervSOFT | Chris Robinson | 2018-01-24 | 1 | -28/+28 |
| | |||||
* | Provide messages for the remaining AL errors | Chris Robinson | 2018-01-24 | 10 | -364/+371 |
| | |||||
* | Set the buffer load error in LoadData | Chris Robinson | 2018-01-24 | 2 | -42/+37 |
| | |||||
* | Call the event callback when an error is generated | Chris Robinson | 2018-01-24 | 6 | -104/+114 |
| | | | | | Most errors don't yet provide correct object IDs or text messages for the AL error. | ||||
* | Handle event properties | Chris Robinson | 2018-01-23 | 3 | -2/+137 |
| | | | | | This just implements the event methods insofar as tracked state. No events are generated/reported yet. | ||||
* | Declare the beginnings of an event extension | Chris Robinson | 2018-01-23 | 1 | -0/+23 |
| | |||||
* | Fix some 'may be used initialized' warnings | Chris Robinson | 2018-01-23 | 1 | -53/+54 |
| | |||||
* | Use a new proper buffer function with a flags parameter | Chris Robinson | 2018-01-23 | 2 | -13/+16 |
| | | | | | | Rather than hackily combining bit flags with the format, to increase the number of potential flags. alBufferData now behaves as if calling alBufferStorageSOFT with a flags value of 0. | ||||
* | Ensure read or write flags are specified with persistent mappings | Chris Robinson | 2018-01-23 | 1 | -4/+7 |
| | |||||
* | Track the buffer's mapped section | Chris Robinson | 2018-01-23 | 2 | -3/+10 |
| | |||||
* | Add a flag for persistent mapping | Chris Robinson | 2018-01-23 | 3 | -8/+49 |
| | | | | And a function to "flush" a mapped buffer | ||||
* | Slightly simplify alBufferSubDataSOFT | Chris Robinson | 2018-01-22 | 1 | -36/+13 |
| | |||||
* | Ensure proper alignment when preserving data too | Chris Robinson | 2018-01-22 | 1 | -2/+3 |
| | |||||
* | Don't bother allocating cleared memory for buffer storage | Chris Robinson | 2018-01-22 | 1 | -1/+1 |
| | |||||
* | Add a flag for alBufferData to non-destructively resize the data | Chris Robinson | 2018-01-22 | 2 | -7/+25 |
| | | | | | | Requires having the same format as the last call to alBufferData. Also only makes sense when given a NULL data pointer, as otherwise the internal data will be overwritten anyway. | ||||
* | Don't convert/copy samples with a NULL dest buffer | Chris Robinson | 2018-01-22 | 1 | -6/+4 |
| | | | | Only happens with a 0 size, so there's nothing to copy or convert anyway. | ||||
* | More cleanup for buffer loading | Chris Robinson | 2018-01-21 | 5 | -829/+112 |
| | | | | | Don't bother with unnecessary and unused converters, and remove some unsupported queries. | ||||
* | Handle double-precision buffers in the mixer | Chris Robinson | 2018-01-21 | 2 | -29/+8 |
| | |||||
* | Remove support for (signed) byte and ushort sample storage | Chris Robinson | 2018-01-21 | 3 | -89/+24 |
| | | | | Also not used without buffer_samples | ||||
* | Remove (u)int32 sample storage conversion | Chris Robinson | 2018-01-21 | 3 | -69/+7 |
| | | | | Unused without the buffer_samples extension | ||||
* | Remove the old buffer_samples functions | Chris Robinson | 2018-01-21 | 2 | -178/+32 |
| | | | | | | | The symbols are still there and exported to retain ABI compatibility, but they no longer do anything except set an AL_INVALID_OPERATION error. They're also removed from the function and enum tables, since they're not part of any supported extension. | ||||
* | Fix the return type of the LPALUNMAPBUFFERSOFT typedef | Chris Robinson | 2018-01-21 | 1 | -1/+1 |
| | |||||
* | Avoid repeating some code | Chris Robinson | 2018-01-21 | 1 | -12/+6 |
| | |||||
* | Add methods to "map" a buffer's storage | Chris Robinson | 2018-01-20 | 4 | -12/+137 |
| | | | | | | | | | | | | | | | | | | | | | | Requires the MAP_READ_BIT or MAP_WRITE_BIT flags to be OR'd with the format upon a call to alBufferData, to enable mappable storage for the given access types. This will fail if the format requires internal conversion and doesn't resemble the original input data, so the app can be guaranteed the size, type, and layout of the original data is the same as what's in storage. Then alMapBufferSOFT may be called with appropriate bit flags to get a readable and/or writable pointer to the buffer's sample storage. alUnmapBufferSOFT must be called when access is finished. It is currently invalid to map a buffer that is attached to a source, or to attach a buffer to a source that is currently mapped. This restriction may be eased in the future, at least to allow read- only access while in use (perhaps also to allow writing, if coherency can be achieved). Currently the access flags occupy the upper 8 bits of a 32-bit bitfield to avoid clashing with format enum values, which don't use more than 16 or 17 bits. This means any future formats are limited to 24-bit enum values, and also means only 8 flags are possible when declaring storage. The alternative would be to add a new function (alBufferStorage?) with a separate flags parameter. | ||||
* | Return the effective alignment from SanitizeAlignment | Chris Robinson | 2018-01-19 | 1 | -28/+26 |
| | |||||
* | Store 8-bit sample types directly as unsigned byte | Chris Robinson | 2018-01-19 | 2 | -13/+13 |
| | |||||
* | Remove unnecessary private AL_SOFT_buffer_samples2 definitions | Chris Robinson | 2018-01-19 | 3 | -80/+4 |
| | |||||
* | Make a function static that's only used in one source file | Chris Robinson | 2018-01-17 | 2 | -3/+2 |
| | |||||
* | Reformat the format array | Chris Robinson | 2018-01-17 | 1 | -36/+36 |
| | |||||
* | Store mulaw and alaw samples directly in the buffer | Chris Robinson | 2018-01-17 | 4 | -26/+22 |
| | | | | | | | They're now decompressed on the fly in the mixer. This is not a significant performance issue given that it only needs a 512-byte lookup table, and the buffer stores half as much data (it may actually be faster, requiring less overall memory). | ||||
* | Use a voice flag to indicate it being static | Chris Robinson | 2018-01-16 | 2 | -5/+6 |
| | |||||
* | Define DECL_VLA where it's used | Chris Robinson | 2018-01-16 | 2 | -6/+7 |
| |