Skip to content

Commit 1ce1913

Browse files
merlokkconorpp
authored andcommitted
add checking some rare case in iso14443-4 chaining. add NAK checking and aborting the data sending.
1 parent 9041e59 commit 1ce1913

File tree

2 files changed

+20
-4
lines changed

2 files changed

+20
-4
lines changed

targets/stm32l432/src/nfc.c

+17-1
Original file line numberDiff line numberDiff line change
@@ -228,6 +228,8 @@ void nfc_write_response_chaining_plain(uint8_t req0, uint8_t * data, int len)
228228
{
229229
uint8_t res[32] = {0};
230230
res[0] = iBlock;
231+
res[1] = 0;
232+
res[2] = 0;
231233
if (len && data)
232234
memcpy(&res[block_offset], data, len);
233235
nfc_write_frame(res, len + block_offset);
@@ -268,6 +270,19 @@ void nfc_write_response_chaining_plain(uint8_t req0, uint8_t * data, int len)
268270
printf1(TAG_NFC, "R block RX timeout %d/%d.\r\n",sendlen,len);
269271
break;
270272
}
273+
274+
if (!IS_RBLOCK(recbuf[0]))
275+
{
276+
printf1(TAG_NFC, "R block RX error. Not a R block(0x%02x) %d/%d.\r\n", recbuf[0], sendlen, len);
277+
break;
278+
}
279+
280+
// NAK check
281+
if (recbuf[0] & NFC_CMD_RBLOCK_ACK)
282+
{
283+
printf1(TAG_NFC, "R block RX error. NAK received. %d/%d.\r\n", recbuf[0], sendlen, len);
284+
break;
285+
}
271286

272287
uint8_t rblock_offset = p14443_block_offset(recbuf[0]);
273288
if (reclen != rblock_offset)
@@ -466,7 +481,8 @@ void rblock_acknowledge(uint8_t req0, bool ack)
466481
NFC_STATE.block_num = !NFC_STATE.block_num;
467482

468483
buf[0] = NFC_CMD_RBLOCK | (req0 & 0x0f);
469-
if (ack)
484+
// iso14443-4:2001 page 16. ACK, if bit is set to 0, NAK, if bit is set to 1
485+
if (!ack)
470486
buf[0] |= NFC_CMD_RBLOCK_ACK;
471487

472488
nfc_write_frame(buf, block_offset);

targets/stm32l432/src/nfc.h

+3-3
Original file line numberDiff line numberDiff line change
@@ -34,9 +34,9 @@ typedef struct
3434
#define IS_PPSS_CMD(x) (((x) & 0xf0) == NFC_CMD_PPSS)
3535
#define NFC_CMD_IBLOCK 0x00
3636
#define IS_IBLOCK(x) ( (((x) & 0xc0) == NFC_CMD_IBLOCK) && (((x) & 0x02) == 0x02) )
37-
#define NFC_CMD_RBLOCK 0x80
38-
#define NFC_CMD_RBLOCK_ACK 0x20
39-
#define IS_RBLOCK(x) ( (((x) & 0xc0) == NFC_CMD_RBLOCK) && (((x) & 0x02) == 0x02) )
37+
#define NFC_CMD_RBLOCK 0xa0
38+
#define NFC_CMD_RBLOCK_ACK 0x10
39+
#define IS_RBLOCK(x) ( (((x) & 0xe0) == NFC_CMD_RBLOCK) && (((x) & 0x02) == 0x02) )
4040
#define NFC_CMD_SBLOCK 0xc0
4141
#define IS_SBLOCK(x) ( (((x) & 0xc0) == NFC_CMD_SBLOCK) && (((x) & 0x02) == 0x02) )
4242

0 commit comments

Comments
 (0)