diff options
| author | Daniel Brahneborg <basic@chello.se> | 2002-03-03 22:02:40 +0000 | 
|---|---|---|
| committer | Daniel Brahneborg <basic@chello.se> | 2002-03-03 22:02:40 +0000 | 
| commit | a4dcb0ecf632832258ebb523c6bc39b7b94f8775 (patch) | |
| tree | 18cf38bb6ecd95671401414c2ba8381b6c90132f /lib/sisfilerecord.cpp | |
| parent | d92c2abcca7d9270f49cbfb09a27bfda86642c31 (diff) | |
| download | plptools-a4dcb0ecf632832258ebb523c6bc39b7b94f8775.tar.gz plptools-a4dcb0ecf632832258ebb523c6bc39b7b94f8775.tar.bz2 plptools-a4dcb0ecf632832258ebb523c6bc39b7b94f8775.zip | |
Add buffer overflow checks to handle truncated and corrupted sis files.
Diffstat (limited to 'lib/sisfilerecord.cpp')
| -rw-r--r-- | lib/sisfilerecord.cpp | 22 | 
1 files changed, 16 insertions, 6 deletions
| diff --git a/lib/sisfilerecord.cpp b/lib/sisfilerecord.cpp index cb2665c..baa5776 100644 --- a/lib/sisfilerecord.cpp +++ b/lib/sisfilerecord.cpp @@ -25,9 +25,12 @@  #include <stdio.h> -void -SISFileRecord::fillFrom(uchar* buf, int* base, SISFile* sisFile) +SisRC +SISFileRecord::fillFrom(uchar* buf, int* base, off_t len, SISFile* sisFile)  { +	if (*base + 28 + 4 * 2 > len) +		return SIS_TRUNCATED; +  	uchar* p = buf + *base;  	int size = 0;  	m_flags = read32(p); @@ -79,27 +82,33 @@ SISFileRecord::fillFrom(uchar* buf, int* base, SISFile* sisFile)  			int n = sisFile->m_header.m_nlangs;  			m_fileLengths = new uint32[n];  			m_filePtrs = new uint32[n]; +			if (*base + size + n * 8 > len) +				return SIS_TRUNCATED;  			for (int i = 0; i < n; ++i)  				{  				m_fileLengths[i] = read32(p + size); +				if (m_fileLengths[i] > len) +					return SIS_TRUNCATED;  				size += 4;  				}  			for (int i = 0; i < n; ++i)  				{  				m_filePtrs[i] = read32(p + size); +				int fileLen = m_fileLengths[i]; +				if (m_filePtrs[i] + fileLen > len) +					return SIS_TRUNCATED;  				size += 4; -				int len = m_fileLengths[i];  				if (logLevel >= 2)  					printf("File %d (for %s) is %d bytes long (at %d)\n",  						   i,  						   sisFile->getLanguage(i)->m_name, -						   len, +						   fileLen,  						   m_filePtrs[i]);  				if (logLevel >= 1)  					printf("%d .. %d (%d bytes): File record (%s) for %.*s\n",  						   m_filePtrs[i], -						   m_filePtrs[i] + len, -						   len, +						   m_filePtrs[i] + fileLen, +						   fileLen,  						   sisFile->getLanguage(i)->m_name,  						   m_destLength, buf + m_destPtr);  				} @@ -111,5 +120,6 @@ SISFileRecord::fillFrom(uchar* buf, int* base, SISFile* sisFile)  				printf("Unknown file flags %d\n", m_flags);  		}  	*base += size; +	return SIS_OK;  } | 
