mirror of
https://github.com/tildearrow/furnace.git
synced 2024-11-25 14:05:12 +00:00
S3M/IT/XM import: hardening
This commit is contained in:
parent
6b2c010afa
commit
6449bc9af2
3 changed files with 32 additions and 10 deletions
|
@ -547,7 +547,7 @@ bool DivEngine::loadIT(unsigned char* file, size_t len) {
|
|||
reader.read(magic,4);
|
||||
|
||||
if (memcmp(magic,"IMPS",4)!=0) {
|
||||
logE("invalid sample header!");
|
||||
logW("invalid sample header!");
|
||||
lastError="invalid sample header";
|
||||
delete s;
|
||||
delete[] file;
|
||||
|
@ -575,7 +575,16 @@ bool DivEngine::loadIT(unsigned char* file, size_t len) {
|
|||
s->depth=DIV_SAMPLE_DEPTH_8BIT;
|
||||
}
|
||||
|
||||
s->init((unsigned int)reader.readI());
|
||||
unsigned int sampleLen=reader.readI();
|
||||
|
||||
if (sampleLen>16777216) {
|
||||
logE("abnormal sample size! %x",reader.tell());
|
||||
lastError="bad sample size";
|
||||
delete[] file;
|
||||
return false;
|
||||
}
|
||||
|
||||
s->init(sampleLen);
|
||||
s->loopStart=reader.readI();
|
||||
s->loopEnd=reader.readI();
|
||||
s->centerRate=reader.readI()/2;
|
||||
|
|
|
@ -414,7 +414,12 @@ bool DivEngine::loadS3M(unsigned char* file, size_t len) {
|
|||
|
||||
unsigned int length=reader.readI();
|
||||
|
||||
logV("length: %x",length);
|
||||
if (length>16777216) {
|
||||
logE("abnormal sample size! %x",reader.tell());
|
||||
lastError="bad sample size";
|
||||
delete[] file;
|
||||
return false;
|
||||
}
|
||||
|
||||
DivSample* s=new DivSample;
|
||||
|
||||
|
|
|
@ -204,6 +204,20 @@ bool DivEngine::loadXM(unsigned char* file, size_t len) {
|
|||
double bpm=(unsigned short)reader.readS();
|
||||
ds.subsong[0]->hz=(double)bpm/2.5;
|
||||
|
||||
if (ordersLen>256) {
|
||||
logE("invalid order count!");
|
||||
lastError="invalid order count";
|
||||
delete[] file;
|
||||
return false;
|
||||
}
|
||||
|
||||
if (patCount>256) {
|
||||
logE("too many patterns!");
|
||||
lastError="too many patterns";
|
||||
delete[] file;
|
||||
return false;
|
||||
}
|
||||
|
||||
if (ds.insLen<0 || ds.insLen>256) {
|
||||
logE("invalid instrument count!");
|
||||
lastError="invalid instrument count";
|
||||
|
@ -435,8 +449,6 @@ bool DivEngine::loadXM(unsigned char* file, size_t len) {
|
|||
headerSeek=reader.tell();
|
||||
headerSeek+=reader.readI();
|
||||
|
||||
logV("the freaking thing ends at %x",headerSeek);
|
||||
|
||||
ins->name=reader.readStringLatin1(22);
|
||||
ins->type=DIV_INS_ES5506;
|
||||
ins->amiga.useNoteMap=true;
|
||||
|
@ -493,11 +505,7 @@ bool DivEngine::loadXM(unsigned char* file, size_t len) {
|
|||
unsigned short volFade=reader.readS();
|
||||
reader.readS(); // reserved
|
||||
|
||||
logV("%d",vibType);
|
||||
logV("%d",vibSweep);
|
||||
logV("%d",vibDepth);
|
||||
logV("%d",vibRate);
|
||||
logV("volFade: %d",volFade);
|
||||
logV("vibrato: %d %d %d %d",vibType,vibSweep,vibDepth,vibRate);
|
||||
|
||||
// convert envelopes
|
||||
readEnvelope(ins,0,volType,volEnvLen,volLoopStart,volLoopEnd,volSusPoint,volEnv);
|
||||
|
|
Loading…
Reference in a new issue