From: Yang Wei <[email protected]> Date: Sun, 7 Jul 2019 21:37:40 +0800
> The frags_q is used before __skb_queue_head_init when conn_info is > NULL. It may result in illegal memory access. > > Signed-off-by: Yang Wei <[email protected]> > --- > net/nfc/nci/data.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/net/nfc/nci/data.c b/net/nfc/nci/data.c > index 0a0c265..b5f16cb 100644 > --- a/net/nfc/nci/data.c > +++ b/net/nfc/nci/data.c > @@ -104,14 +104,14 @@ static int nci_queue_tx_data_frags(struct nci_dev *ndev, > > pr_debug("conn_id 0x%x, total_len %d\n", conn_id, total_len); > > + __skb_queue_head_init(&frags_q); > + > conn_info = nci_get_conn_info_by_conn_id(ndev, conn_id); > if (!conn_info) { > rc = -EPROTO; > goto free_exit; > } > > - __skb_queue_head_init(&frags_q); > - Just change the goto into "goto exit;", much simpler one-line fix.

