diff options
Diffstat (limited to 'linden/indra/newview/llvocache.cpp')
-rw-r--r-- | linden/indra/newview/llvocache.cpp | 45 |
1 files changed, 31 insertions, 14 deletions
diff --git a/linden/indra/newview/llvocache.cpp b/linden/indra/newview/llvocache.cpp index f249c87..2b3569d 100644 --- a/linden/indra/newview/llvocache.cpp +++ b/linden/indra/newview/llvocache.cpp | |||
@@ -60,16 +60,25 @@ LLVOCacheEntry::LLVOCacheEntry() | |||
60 | } | 60 | } |
61 | 61 | ||
62 | 62 | ||
63 | static inline void checkedRead(FILE *fp, void *data, size_t nbytes) | ||
64 | { | ||
65 | if (fread(data, 1, nbytes, fp) != nbytes) | ||
66 | { | ||
67 | llwarns << "Short read" << llendl; | ||
68 | memset(data, 0, nbytes); | ||
69 | } | ||
70 | } | ||
71 | |||
63 | LLVOCacheEntry::LLVOCacheEntry(FILE *fp) | 72 | LLVOCacheEntry::LLVOCacheEntry(FILE *fp) |
64 | { | 73 | { |
65 | S32 size; | 74 | S32 size; |
66 | fread(&mLocalID, 1, sizeof(U32), fp); | 75 | checkedRead(fp, &mLocalID, sizeof(U32)); |
67 | fread(&mCRC, 1, sizeof(U32), fp); | 76 | checkedRead(fp, &mCRC, sizeof(U32)); |
68 | fread(&mHitCount, 1, sizeof(S32), fp); | 77 | checkedRead(fp, &mHitCount, sizeof(S32)); |
69 | fread(&mDupeCount, 1, sizeof(S32), fp); | 78 | checkedRead(fp, &mDupeCount, sizeof(S32)); |
70 | fread(&mCRCChangeCount, 1, sizeof(S32), fp); | 79 | checkedRead(fp, &mCRCChangeCount, sizeof(S32)); |
71 | 80 | ||
72 | fread(&size, 1, sizeof(S32), fp); | 81 | checkedRead(fp, &size, sizeof(S32)); |
73 | 82 | ||
74 | // Corruption in the cache entries | 83 | // Corruption in the cache entries |
75 | if ((size > 10000) || (size < 1)) | 84 | if ((size > 10000) || (size < 1)) |
@@ -85,7 +94,7 @@ LLVOCacheEntry::LLVOCacheEntry(FILE *fp) | |||
85 | } | 94 | } |
86 | 95 | ||
87 | mBuffer = new U8[size]; | 96 | mBuffer = new U8[size]; |
88 | fread(mBuffer, 1, size, fp); | 97 | checkedRead(fp, mBuffer, size); |
89 | mDP.assignBuffer(mBuffer, size); | 98 | mDP.assignBuffer(mBuffer, size); |
90 | } | 99 | } |
91 | 100 | ||
@@ -141,14 +150,22 @@ void LLVOCacheEntry::dump() const | |||
141 | << llendl; | 150 | << llendl; |
142 | } | 151 | } |
143 | 152 | ||
153 | static inline void checkedWrite(FILE *fp, const void *data, size_t nbytes) | ||
154 | { | ||
155 | if (fwrite(data, 1, nbytes, fp) != nbytes) | ||
156 | { | ||
157 | llwarns << "Short write" << llendl; | ||
158 | } | ||
159 | } | ||
160 | |||
144 | void LLVOCacheEntry::writeToFile(FILE *fp) const | 161 | void LLVOCacheEntry::writeToFile(FILE *fp) const |
145 | { | 162 | { |
146 | fwrite(&mLocalID, 1, sizeof(U32), fp); | 163 | checkedWrite(fp, &mLocalID, sizeof(U32)); |
147 | fwrite(&mCRC, 1, sizeof(U32), fp); | 164 | checkedWrite(fp, &mCRC, sizeof(U32)); |
148 | fwrite(&mHitCount, 1, sizeof(S32), fp); | 165 | checkedWrite(fp, &mHitCount, sizeof(S32)); |
149 | fwrite(&mDupeCount, 1, sizeof(S32), fp); | 166 | checkedWrite(fp, &mDupeCount, sizeof(S32)); |
150 | fwrite(&mCRCChangeCount, 1, sizeof(S32), fp); | 167 | checkedWrite(fp, &mCRCChangeCount, sizeof(S32)); |
151 | S32 size = mDP.getBufferSize(); | 168 | S32 size = mDP.getBufferSize(); |
152 | fwrite(&size, 1, sizeof(S32), fp); | 169 | checkedWrite(fp, &size, sizeof(S32)); |
153 | fwrite(mBuffer, 1, size, fp); | 170 | checkedWrite(fp, mBuffer, size); |
154 | } | 171 | } |