Skip to content

Commit dee704d

Browse files
committed
padding_depad + PKCS7 - reject invalid pad 0
1 parent 2adc261 commit dee704d

File tree

2 files changed

+2
-5
lines changed

2 files changed

+2
-5
lines changed

src/misc/padding/padding_depad.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -36,7 +36,7 @@ int padding_depad(const unsigned char *data, unsigned long *length, unsigned lon
3636
if (type < LTC_PAD_ONE_AND_ZERO) {
3737
pad = data[padded_length - 1];
3838

39-
if (pad > padded_length) return CRYPT_INVALID_ARG;
39+
if (pad > padded_length || pad == 0) return CRYPT_INVALID_ARG;
4040

4141
unpadded_length = padded_length - pad;
4242
} else {

tests/padding_test.c

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -201,10 +201,7 @@ int padding_test(void)
201201
int err;
202202

203203
err = padding_depad(data, &len, (LTC_PAD_PKCS7 | 16));
204-
if (err == CRYPT_OK) {
205-
fprintf(stderr, "XXX-FIXME padding_depad should fail (err=%d len=%lu)\n", err, len);
206-
/* return CRYPT_FAIL_TESTVECTOR; */
207-
}
204+
if (err == CRYPT_OK) return CRYPT_FAIL_TESTVECTOR; /* should fail */
208205
}
209206

210207
return CRYPT_OK;

0 commit comments

Comments
 (0)