Skip to content

Commit c01c065

Browse files
committed
Do not construct out-of-bound pointers in SHA512/SHA1/RIPEMD160 code
1 parent 94daebf commit c01c065

File tree

3 files changed

+3
-3
lines changed

3 files changed

+3
-3
lines changed

src/crypto/ripemd160.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -256,7 +256,7 @@ CRIPEMD160& CRIPEMD160::Write(const unsigned char* data, size_t len)
256256
ripemd160::Transform(s, buf);
257257
bufsize = 0;
258258
}
259-
while (end >= data + 64) {
259+
while (end - data >= 64) {
260260
// Process full chunks directly from the source.
261261
ripemd160::Transform(s, data);
262262
bytes += 64;

src/crypto/sha1.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -163,7 +163,7 @@ CSHA1& CSHA1::Write(const unsigned char* data, size_t len)
163163
sha1::Transform(s, buf);
164164
bufsize = 0;
165165
}
166-
while (end >= data + 64) {
166+
while (end - data >= 64) {
167167
// Process full chunks directly from the source.
168168
sha1::Transform(s, data);
169169
bytes += 64;

src/crypto/sha512.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -168,7 +168,7 @@ CSHA512& CSHA512::Write(const unsigned char* data, size_t len)
168168
sha512::Transform(s, buf);
169169
bufsize = 0;
170170
}
171-
while (end >= data + 128) {
171+
while (end - data >= 128) {
172172
// Process full chunks directly from the source.
173173
sha512::Transform(s, data);
174174
data += 128;

0 commit comments

Comments
 (0)