ab1581
commit 9d294de90d1cc66956389856e60b6944b27b4817
ab1581
Author: Frank Morgner <frankmorgner@gmail.com>
ab1581
Date:   Thu Jun 4 10:04:10 2020 +0200
ab1581
ab1581
    prevent out of bounds write
ab1581
    
ab1581
    fixes https://oss-fuzz.com/testcase-detail/5226571123392512
ab1581
ab1581
diff --git a/src/libopensc/card-tcos.c b/src/libopensc/card-tcos.c
ab1581
index 673c2493..e88c80bd 100644
ab1581
--- a/src/libopensc/card-tcos.c
ab1581
+++ b/src/libopensc/card-tcos.c
ab1581
@@ -623,6 +623,8 @@ static int tcos_decipher(sc_card_t *card, const u8 * crgram, size_t crgram_len,
ab1581
 	apdu.data = sbuf;
ab1581
 	apdu.lc = apdu.datalen = crgram_len+1;
ab1581
 	sbuf[0] = tcos3 ? 0x00 : ((data->pad_flags & SC_ALGORITHM_RSA_PAD_PKCS1) ? 0x81 : 0x02);
ab1581
+	if (sizeof sbuf - 1 < crgram_len)
ab1581
+		return SC_ERROR_INVALID_ARGUMENTS;
ab1581
 	memcpy(sbuf+1, crgram, crgram_len);
ab1581
 
ab1581
 	r = sc_transmit_apdu(card, &apdu);