ref: e85a63eb7284b1f323b09b77436da43a28dcf9b1
dir: /src/pt2_audio.h/
#pragma once #include <stdint.h> #include <stdbool.h> #include "pt2_header.h" // AMIGA_VOICES typedef struct audio_t { volatile bool locked, isSampling; bool forceMixerOff; double bpmTable[256-32], bpmTable28kHz[256-32], bpmTable22kHz[256-32], bpmTableMod2Wav[256-32]; uint32_t outputRate, audioBufferSize; double dPeriodToDeltaDiv; double dSamplesPerTick, dTickSampleCounter; // for audio sampling bool rescanAudioDevicesSupported; // for audio/video syncing bool resetSyncTickTimeFlag; uint64_t tickLengthTable[224]; } audio_t; typedef struct voice_t { volatile bool active; const int8_t *data, *newData; int32_t length, newLength, pos; double dVolume, dDelta, dDeltaMul, dPhase, dLastDelta, dLastDeltaMul, dLastPhase, dPanL, dPanR; // used for pt2_sync.c uint8_t syncFlags; uint8_t syncVolume; int32_t syncPeriod; int32_t syncTriggerLength; const int8_t *syncTriggerData; } paulaVoice_t; void updateReplayerTimingMode(void); void setSyncTickTimeLen(uint32_t timeLen, uint32_t timeLenFrac); void resetCachedMixerPeriod(void); void resetAudioDithering(void); uint16_t get16BitPeak(int16_t *sampleData, uint32_t sampleLength); uint32_t get32BitPeak(int32_t *sampleData, uint32_t sampleLength); float getFloatPeak(float *fSampleData, uint32_t sampleLength); double getDoublePeak(double *dSampleData, uint32_t sampleLength); void normalize16BitTo8Bit(int16_t *sampleData, uint32_t sampleLength); void normalize32BitTo8Bit(int32_t *sampleData, uint32_t sampleLength); void normalizeFloatTo8Bit(float *fSampleData, uint32_t sampleLength); void normalizeDoubleTo8Bit(double *dSampleData, uint32_t sampleLength); void recalcFilterCoeffs(int32_t outputRate); // for MOD2WAV void setLEDFilter(bool state, bool doLockAudio); void toggleLEDFilter(void); void toggleAmigaPanMode(void); void toggleFilterModel(void); void paulaStopDMA(int32_t ch); void paulaStartDMA(int32_t ch); void paulaSetPeriod(int32_t ch, uint16_t period); void paulaSetVolume(int32_t ch, uint16_t vol); void paulaSetLength(int32_t ch, uint16_t len); void paulaSetData(int32_t ch, const int8_t *src); void lockAudio(void); void unlockAudio(void); void mixerUpdateLoops(void); void mixerKillVoice(int32_t ch); void turnOffVoices(void); void mixerCalcVoicePans(uint8_t stereoSeparation); void outputAudio(int16_t *target, int32_t numSamples); void resetAudioDownsamplingStates(void); extern audio_t audio; // pt2_audio.c extern paulaVoice_t paula[AMIGA_VOICES]; // pt2_audio.c