Updated modplay, and added safety checks to signature verification
parent
a2ced7c506
commit
de8df552c2
|
@ -314,9 +314,9 @@ typedef struct
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
int8_t *_ptr;
|
uint8_t *_ptr;
|
||||||
uintptr_t _cnt;
|
uintptr_t _cnt;
|
||||||
int8_t *_base;
|
uint8_t *_base;
|
||||||
uintptr_t _bufsiz;
|
uintptr_t _bufsiz;
|
||||||
int32_t _eof;
|
int32_t _eof;
|
||||||
} MEM;
|
} MEM;
|
||||||
|
@ -330,7 +330,7 @@ typedef struct
|
||||||
int16_t *amigaPeriods;
|
int16_t *amigaPeriods;
|
||||||
uint32_t *LogTab;
|
uint32_t *LogTab;
|
||||||
int8_t LinearFrqTab;
|
int8_t LinearFrqTab;
|
||||||
uint32_t soundBufferSize;
|
int32_t soundBufferSize;
|
||||||
uint32_t outputFreq;
|
uint32_t outputFreq;
|
||||||
|
|
||||||
TonTyp *NilPatternLine;
|
TonTyp *NilPatternLine;
|
||||||
|
@ -363,6 +363,8 @@ typedef struct
|
||||||
int8_t Playing;// = 0;
|
int8_t Playing;// = 0;
|
||||||
uint8_t numChannels;// = 127;
|
uint8_t numChannels;// = 127;
|
||||||
|
|
||||||
|
uint8_t muted[16];
|
||||||
|
|
||||||
uint32_t loopCount;
|
uint32_t loopCount;
|
||||||
uint8_t playedOrder[8192];
|
uint8_t playedOrder[8192];
|
||||||
} PLAYER;
|
} PLAYER;
|
||||||
|
@ -371,7 +373,7 @@ enum { _soundBufferSize = 512 };
|
||||||
|
|
||||||
// FUNCTION DECLARATIONS
|
// FUNCTION DECLARATIONS
|
||||||
|
|
||||||
static MEM *mopen(const int8_t *src, uintptr_t length);
|
static MEM *mopen(const uint8_t *src, uintptr_t length);
|
||||||
static void mclose(MEM *buf);
|
static void mclose(MEM *buf);
|
||||||
//static intptr_t mtell(MEM *buf);
|
//static intptr_t mtell(MEM *buf);
|
||||||
static size_t mread(void *buffer, size_t size, size_t count, MEM *buf);
|
static size_t mread(void *buffer, size_t size, size_t count, MEM *buf);
|
||||||
|
@ -2478,7 +2480,7 @@ static void ft2play_FreeSong(void *_p)
|
||||||
p->ModuleLoaded = 0;
|
p->ModuleLoaded = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int8_t ft2play_LoadModule(void *_p, const int8_t *buffer, size_t size)
|
int8_t ft2play_LoadModule(void *_p, const uint8_t *buffer, size_t size)
|
||||||
{
|
{
|
||||||
PLAYER *p = (PLAYER *)_p;
|
PLAYER *p = (PLAYER *)_p;
|
||||||
MEM *buf;
|
MEM *buf;
|
||||||
|
@ -2815,8 +2817,8 @@ static inline void mix8b(PLAYER *p, uint32_t ch, uint32_t samples)
|
||||||
|
|
||||||
p->voice[ch].samplePosition = samplePosition;
|
p->voice[ch].samplePosition = samplePosition;
|
||||||
p->voice[ch].loopDir = loopDir;
|
p->voice[ch].loopDir = loopDir;
|
||||||
p->voice[ch].interpolating = interpolating;
|
p->voice[ch].interpolating = (int8_t)interpolating;
|
||||||
p->voice[ch].oversampleCount = oversampleCount;
|
p->voice[ch].oversampleCount = (int8_t)oversampleCount;
|
||||||
|
|
||||||
if ( !lanczos_resampler_ready(resampler) )
|
if ( !lanczos_resampler_ready(resampler) )
|
||||||
{
|
{
|
||||||
|
@ -2974,8 +2976,8 @@ static inline void mix8bstereo(PLAYER *p, uint32_t ch, uint32_t samples)
|
||||||
|
|
||||||
p->voice[ch].samplePosition = samplePosition;
|
p->voice[ch].samplePosition = samplePosition;
|
||||||
p->voice[ch].loopDir = loopDir;
|
p->voice[ch].loopDir = loopDir;
|
||||||
p->voice[ch].interpolating = interpolating;
|
p->voice[ch].interpolating = (int8_t)interpolating;
|
||||||
p->voice[ch].oversampleCount = oversampleCount;
|
p->voice[ch].oversampleCount = (int8_t)oversampleCount;
|
||||||
|
|
||||||
if ( !lanczos_resampler_ready(resampler[0]) )
|
if ( !lanczos_resampler_ready(resampler[0]) )
|
||||||
{
|
{
|
||||||
|
@ -3131,8 +3133,8 @@ static inline void mix16b(PLAYER *p, uint32_t ch, uint32_t samples)
|
||||||
|
|
||||||
p->voice[ch].samplePosition = samplePosition;
|
p->voice[ch].samplePosition = samplePosition;
|
||||||
p->voice[ch].loopDir = loopDir;
|
p->voice[ch].loopDir = loopDir;
|
||||||
p->voice[ch].interpolating = interpolating;
|
p->voice[ch].interpolating = (int8_t)interpolating;
|
||||||
p->voice[ch].oversampleCount = oversampleCount;
|
p->voice[ch].oversampleCount = (int8_t)oversampleCount;
|
||||||
|
|
||||||
if ( !lanczos_resampler_ready(resampler) )
|
if ( !lanczos_resampler_ready(resampler) )
|
||||||
{
|
{
|
||||||
|
@ -3290,8 +3292,8 @@ static inline void mix16bstereo(PLAYER *p, uint32_t ch, uint32_t samples)
|
||||||
|
|
||||||
p->voice[ch].samplePosition = samplePosition;
|
p->voice[ch].samplePosition = samplePosition;
|
||||||
p->voice[ch].loopDir = loopDir;
|
p->voice[ch].loopDir = loopDir;
|
||||||
p->voice[ch].interpolating = interpolating;
|
p->voice[ch].interpolating = (int8_t)interpolating;
|
||||||
p->voice[ch].oversampleCount = oversampleCount;
|
p->voice[ch].oversampleCount = (int8_t)oversampleCount;
|
||||||
|
|
||||||
if ( !lanczos_resampler_ready(resampler[0]) )
|
if ( !lanczos_resampler_ready(resampler[0]) )
|
||||||
{
|
{
|
||||||
|
@ -3375,6 +3377,8 @@ static void mixSampleBlock(PLAYER *p, float *outputStream, uint32_t sampleBlockL
|
||||||
|
|
||||||
for (i = 0; i < p->numChannels; ++i)
|
for (i = 0; i < p->numChannels; ++i)
|
||||||
{
|
{
|
||||||
|
if (p->muted[i / 8] & (1 << (i % 8)))
|
||||||
|
continue;
|
||||||
mixChannel(p, i, sampleBlockLength);
|
mixChannel(p, i, sampleBlockLength);
|
||||||
mixChannel(p, i + 127, sampleBlockLength);
|
mixChannel(p, i + 127, sampleBlockLength);
|
||||||
}
|
}
|
||||||
|
@ -3530,7 +3534,7 @@ void * ft2play_Alloc(uint32_t _samplingFrequency, int8_t interpolation)
|
||||||
// generate tables
|
// generate tables
|
||||||
|
|
||||||
for (i = 0; i < 768; ++i)
|
for (i = 0; i < 768; ++i)
|
||||||
p->LogTab[i] = (uint32_t)(floorf(((256.0f * 8363.0f) * expf((float)(i) / 768.0f * logf(2.0f))) + 0.5f));
|
p->LogTab[i] = (uint32_t)(floor(((256.0f * 8363.0f) * exp((float)(i) / 768.0f * logf(2.0f))) + 0.5f));
|
||||||
|
|
||||||
for (i = 0; i < ((12 * 10 * 16) + 16); ++i)
|
for (i = 0; i < ((12 * 10 * 16) + 16); ++i)
|
||||||
p->linearPeriods[i] = (((12 * 10 * 16) + 16) * 4) - (i << 2);
|
p->linearPeriods[i] = (((12 * 10 * 16) + 16) * 4) - (i << 2);
|
||||||
|
@ -3615,16 +3619,16 @@ void ft2play_PlaySong(void *_p, int32_t startOrder)
|
||||||
setSamplesPerFrame(p, ((p->outputFreq * 5UL) / 2 / p->Song.Speed));
|
setSamplesPerFrame(p, ((p->outputFreq * 5UL) / 2 / p->Song.Speed));
|
||||||
p->isMixing = 1;
|
p->isMixing = 1;
|
||||||
|
|
||||||
SetPos(p, startOrder, 0);
|
SetPos(p, (int16_t)startOrder, 0);
|
||||||
|
|
||||||
p->Song.startOrder = startOrder;
|
p->Song.startOrder = (int16_t)startOrder;
|
||||||
|
|
||||||
p->loopCount = 0;
|
p->loopCount = 0;
|
||||||
memset(p->playedOrder, 0, sizeof(p->playedOrder));
|
memset(p->playedOrder, 0, sizeof(p->playedOrder));
|
||||||
p->playedOrder[startOrder / 8] = 1 << (startOrder % 8);
|
p->playedOrder[startOrder / 8] = 1 << (startOrder % 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static MEM *mopen(const int8_t *src, uintptr_t length)
|
static MEM *mopen(const uint8_t *src, uintptr_t length)
|
||||||
{
|
{
|
||||||
MEM *b;
|
MEM *b;
|
||||||
|
|
||||||
|
@ -3633,8 +3637,8 @@ static MEM *mopen(const int8_t *src, uintptr_t length)
|
||||||
b = (MEM *)(malloc(sizeof (MEM)));
|
b = (MEM *)(malloc(sizeof (MEM)));
|
||||||
if (b == NULL) return (NULL);
|
if (b == NULL) return (NULL);
|
||||||
|
|
||||||
b->_base = (int8_t *)(src);
|
b->_base = (uint8_t *)(src);
|
||||||
b->_ptr = (int8_t *)(src);
|
b->_ptr = (uint8_t *)(src);
|
||||||
b->_cnt = length;
|
b->_cnt = length;
|
||||||
b->_bufsiz = length;
|
b->_bufsiz = length;
|
||||||
b->_eof = 0;
|
b->_eof = 0;
|
||||||
|
@ -3756,6 +3760,18 @@ static void setSamplesPerFrame(PLAYER *p, uint32_t val)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ft2play_Mute(void *_p, int8_t channel, int8_t mute)
|
||||||
|
{
|
||||||
|
PLAYER * p = (PLAYER *)_p;
|
||||||
|
int8_t mask = 1 << (channel % 8);
|
||||||
|
if (channel > 127)
|
||||||
|
return;
|
||||||
|
if (mute)
|
||||||
|
p->muted[channel / 8] |= mask;
|
||||||
|
else
|
||||||
|
p->muted[channel / 8] &= ~mask;
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t ft2play_GetLoopCount(void *_p)
|
uint32_t ft2play_GetLoopCount(void *_p)
|
||||||
{
|
{
|
||||||
PLAYER * p = (PLAYER *)_p;
|
PLAYER * p = (PLAYER *)_p;
|
||||||
|
|
|
@ -10,7 +10,7 @@ extern "C" {
|
||||||
void * ft2play_Alloc(uint32_t _samplingFrequency, int8_t interpolation);
|
void * ft2play_Alloc(uint32_t _samplingFrequency, int8_t interpolation);
|
||||||
void ft2play_Free(void *);
|
void ft2play_Free(void *);
|
||||||
|
|
||||||
int8_t ft2play_LoadModule(void *, const int8_t *buffer, size_t size);
|
int8_t ft2play_LoadModule(void *, const uint8_t *buffer, size_t size);
|
||||||
|
|
||||||
void ft2play_PlaySong(void *, int32_t startOrder);
|
void ft2play_PlaySong(void *, int32_t startOrder);
|
||||||
|
|
||||||
|
@ -20,6 +20,8 @@ void ft2play_RenderFloat(void *, float *buffer, int32_t count);
|
||||||
/* These two absolutely require a real buffer */
|
/* These two absolutely require a real buffer */
|
||||||
void ft2play_RenderFixed32(void *, int32_t *buffer, int32_t count, int8_t depth);
|
void ft2play_RenderFixed32(void *, int32_t *buffer, int32_t count, int8_t depth);
|
||||||
void ft2play_RenderFixed16(void *, int16_t *buffer, int32_t count, int8_t depth);
|
void ft2play_RenderFixed16(void *, int16_t *buffer, int32_t count, int8_t depth);
|
||||||
|
|
||||||
|
void ft2play_Mute(void *, int8_t channel, int8_t mute);
|
||||||
|
|
||||||
uint32_t ft2play_GetLoopCount(void *);
|
uint32_t ft2play_GetLoopCount(void *);
|
||||||
|
|
||||||
|
|
|
@ -214,6 +214,8 @@ typedef struct
|
||||||
uint8_t mastervol;
|
uint8_t mastervol;
|
||||||
uint32_t mseg_len;
|
uint32_t mseg_len;
|
||||||
|
|
||||||
|
uint8_t muted[4];
|
||||||
|
|
||||||
uint32_t loopCount;
|
uint32_t loopCount;
|
||||||
uint8_t playedOrder[8192];
|
uint8_t playedOrder[8192];
|
||||||
} PLAYER;
|
} PLAYER;
|
||||||
|
@ -3099,6 +3101,8 @@ void mixSampleBlock(PLAYER *p, float *outputStream, uint32_t sampleBlockLength)
|
||||||
|
|
||||||
for (i = 0; i < 32; ++i)
|
for (i = 0; i < 32; ++i)
|
||||||
{
|
{
|
||||||
|
if (p->muted[i / 8] & (1 << (i % 8)))
|
||||||
|
continue;
|
||||||
if (p->voice[i].incRate && p->voice[i].mixing)
|
if (p->voice[i].incRate && p->voice[i].mixing)
|
||||||
{
|
{
|
||||||
if (p->voice[i].stereo)
|
if (p->voice[i].stereo)
|
||||||
|
@ -3222,6 +3226,18 @@ void FreeSong(PLAYER *p)
|
||||||
p->ModuleLoaded = 0;
|
p->ModuleLoaded = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void st3play_Mute(void *_p, int8_t channel, int8_t mute)
|
||||||
|
{
|
||||||
|
PLAYER * p = (PLAYER *)_p;
|
||||||
|
int8_t mask = 1 << (channel % 8);
|
||||||
|
if (channel > 31)
|
||||||
|
return;
|
||||||
|
if (mute)
|
||||||
|
p->muted[channel / 8] |= mask;
|
||||||
|
else
|
||||||
|
p->muted[channel / 8] &= ~mask;
|
||||||
|
}
|
||||||
|
|
||||||
int32_t st3play_GetLoopCount(void *_p)
|
int32_t st3play_GetLoopCount(void *_p)
|
||||||
{
|
{
|
||||||
PLAYER * p = (PLAYER *)_p;
|
PLAYER * p = (PLAYER *)_p;
|
||||||
|
|
|
@ -21,14 +21,16 @@ void st3play_RenderFloat(void *, float *buffer, int32_t count);
|
||||||
/* These two absolutely require a real buffer */
|
/* These two absolutely require a real buffer */
|
||||||
void st3play_RenderFixed32(void *, int32_t *buffer, int32_t count, int8_t depth);
|
void st3play_RenderFixed32(void *, int32_t *buffer, int32_t count, int8_t depth);
|
||||||
void st3play_RenderFixed16(void *, int16_t *buffer, int32_t count, int8_t depth);
|
void st3play_RenderFixed16(void *, int16_t *buffer, int32_t count, int8_t depth);
|
||||||
|
|
||||||
|
void st3play_Mute(void *, int8_t channel, int8_t mute);
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
uint16_t order;
|
uint16_t order;
|
||||||
uint16_t pattern;
|
uint16_t pattern;
|
||||||
uint16_t row;
|
uint16_t row;
|
||||||
uint8_t speed;
|
uint8_t speed;
|
||||||
uint8_t tempo;
|
uint16_t tempo;
|
||||||
uint8_t channels_playing;
|
uint8_t channels_playing;
|
||||||
} st3_info;
|
} st3_info;
|
||||||
|
|
||||||
|
|
|
@ -141,9 +141,9 @@ BOOL xm_probe_length( unsigned long * intro_length, unsigned long * loop_length,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( memcmp( data + 0x2C, "SCRM", 4 ) == 0 )
|
if ( size >= (0x2C + 4) && memcmp( data + 0x2C, "SCRM", 4 ) == 0 )
|
||||||
type = TYPE_S3M;
|
type = TYPE_S3M;
|
||||||
else if ( memcmp( data, "Extended Module: ", 17 ) == 0 )
|
else if ( size >= 17 && memcmp( data, "Extended Module: ", 17 ) == 0 )
|
||||||
type = TYPE_XM;
|
type = TYPE_XM;
|
||||||
else
|
else
|
||||||
return NO;
|
return NO;
|
||||||
|
|
Loading…
Reference in New Issue