NFC: pn533: Store the correct frame size (normal vs ext)
The extended information frame are sent by PN533 to exchange frames larger than 255 bytes. These extended frame are very close from the standard ones except for the header size length. On each incoming frame, we set the correct header length, and we do that only for the standard pn533 chipsets as the acr122 does not seem to support extended frames properly. Signed-off-by: Olivier Guiter <olivier.guiter@linux.intel.com> Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
This commit is contained in:
parent
963a82e07d
commit
56a63c82cf
|
@ -435,7 +435,7 @@ struct pn533_frame_ops {
|
||||||
int tx_header_len;
|
int tx_header_len;
|
||||||
int tx_tail_len;
|
int tx_tail_len;
|
||||||
|
|
||||||
bool (*rx_is_frame_valid)(void *frame);
|
bool (*rx_is_frame_valid)(void *frame, struct pn533 *dev);
|
||||||
int (*rx_frame_size)(void *frame);
|
int (*rx_frame_size)(void *frame);
|
||||||
int rx_header_len;
|
int rx_header_len;
|
||||||
int rx_tail_len;
|
int rx_tail_len;
|
||||||
|
@ -510,7 +510,7 @@ static void pn533_acr122_tx_update_payload_len(void *_frame, int len)
|
||||||
frame->datalen += len;
|
frame->datalen += len;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool pn533_acr122_is_rx_frame_valid(void *_frame)
|
static bool pn533_acr122_is_rx_frame_valid(void *_frame, struct pn533 *dev)
|
||||||
{
|
{
|
||||||
struct pn533_acr122_rx_frame *frame = _frame;
|
struct pn533_acr122_rx_frame *frame = _frame;
|
||||||
|
|
||||||
|
@ -608,7 +608,7 @@ static void pn533_std_tx_update_payload_len(void *_frame, int len)
|
||||||
frame->datalen += len;
|
frame->datalen += len;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool pn533_std_rx_frame_is_valid(void *_frame)
|
static bool pn533_std_rx_frame_is_valid(void *_frame, struct pn533 *dev)
|
||||||
{
|
{
|
||||||
u8 checksum;
|
u8 checksum;
|
||||||
struct pn533_std_frame *stdf = _frame;
|
struct pn533_std_frame *stdf = _frame;
|
||||||
|
@ -618,6 +618,7 @@ static bool pn533_std_rx_frame_is_valid(void *_frame)
|
||||||
|
|
||||||
if (likely(!PN533_STD_IS_EXTENDED(stdf))) {
|
if (likely(!PN533_STD_IS_EXTENDED(stdf))) {
|
||||||
/* Standard frame code */
|
/* Standard frame code */
|
||||||
|
dev->ops->rx_header_len = PN533_STD_FRAME_HEADER_LEN;
|
||||||
|
|
||||||
checksum = pn533_std_checksum(stdf->datalen);
|
checksum = pn533_std_checksum(stdf->datalen);
|
||||||
if (checksum != stdf->datalen_checksum)
|
if (checksum != stdf->datalen_checksum)
|
||||||
|
@ -630,6 +631,8 @@ static bool pn533_std_rx_frame_is_valid(void *_frame)
|
||||||
/* Extended */
|
/* Extended */
|
||||||
struct pn533_ext_frame *eif = _frame;
|
struct pn533_ext_frame *eif = _frame;
|
||||||
|
|
||||||
|
dev->ops->rx_header_len = PN533_EXT_FRAME_HEADER_LEN;
|
||||||
|
|
||||||
checksum = pn533_ext_checksum(be16_to_cpu(eif->datalen));
|
checksum = pn533_ext_checksum(be16_to_cpu(eif->datalen));
|
||||||
if (checksum != eif->datalen_checksum)
|
if (checksum != eif->datalen_checksum)
|
||||||
return false;
|
return false;
|
||||||
|
@ -734,7 +737,7 @@ static void pn533_recv_response(struct urb *urb)
|
||||||
print_hex_dump_debug("PN533 RX: ", DUMP_PREFIX_NONE, 16, 1, in_frame,
|
print_hex_dump_debug("PN533 RX: ", DUMP_PREFIX_NONE, 16, 1, in_frame,
|
||||||
dev->ops->rx_frame_size(in_frame), false);
|
dev->ops->rx_frame_size(in_frame), false);
|
||||||
|
|
||||||
if (!dev->ops->rx_is_frame_valid(in_frame)) {
|
if (!dev->ops->rx_is_frame_valid(in_frame, dev)) {
|
||||||
nfc_dev_err(&dev->interface->dev, "Received an invalid frame");
|
nfc_dev_err(&dev->interface->dev, "Received an invalid frame");
|
||||||
cmd->status = -EIO;
|
cmd->status = -EIO;
|
||||||
goto sched_wq;
|
goto sched_wq;
|
||||||
|
@ -747,11 +750,6 @@ static void pn533_recv_response(struct urb *urb)
|
||||||
goto sched_wq;
|
goto sched_wq;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (PN533_STD_IS_EXTENDED((struct pn533_std_frame *)in_frame))
|
|
||||||
dev->ops->rx_header_len = PN533_EXT_FRAME_HEADER_LEN;
|
|
||||||
else
|
|
||||||
dev->ops->rx_header_len = PN533_STD_FRAME_HEADER_LEN;
|
|
||||||
|
|
||||||
sched_wq:
|
sched_wq:
|
||||||
queue_work(dev->wq, &dev->cmd_complete_work);
|
queue_work(dev->wq, &dev->cmd_complete_work);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue