aboutsummaryrefslogtreecommitdiffstats
path: root/net/nfc
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2017-06-16 08:29:20 -0400
committerDavid S. Miller <davem@davemloft.net>2017-06-16 11:48:37 -0400
commit59ae1d127ac0ae404baf414c434ba2651b793f46 (patch)
tree043e71496aa7a7db86bcc8219a3a51f533aac982 /net/nfc
parentb080db585384b9f037e015c0c28d1ad33be41dfc (diff)
networking: introduce and use skb_put_data()
A common pattern with skb_put() is to just want to memcpy() some data into the new space, introduce skb_put_data() for this. An spatch similar to the one for skb_put_zero() converts many of the places using it: @@ identifier p, p2; expression len, skb, data; type t, t2; @@ ( -p = skb_put(skb, len); +p = skb_put_data(skb, data, len); | -p = (t)skb_put(skb, len); +p = skb_put_data(skb, data, len); ) ( p2 = (t2)p; -memcpy(p2, data, len); | -memcpy(p, data, len); ) @@ type t, t2; identifier p, p2; expression skb, data; @@ t *p; ... ( -p = skb_put(skb, sizeof(t)); +p = skb_put_data(skb, data, sizeof(t)); | -p = (t *)skb_put(skb, sizeof(t)); +p = skb_put_data(skb, data, sizeof(t)); ) ( p2 = (t2)p; -memcpy(p2, data, sizeof(*p)); | -memcpy(p, data, sizeof(*p)); ) @@ expression skb, len, data; @@ -memcpy(skb_put(skb, len), data, len); +skb_put_data(skb, data, len); (again, manually post-processed to retain some comments) Reviewed-by: Stephen Hemminger <stephen@networkplumber.org> Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/nfc')
-rw-r--r--net/nfc/digital_dep.c17
-rw-r--r--net/nfc/hci/core.c6
-rw-r--r--net/nfc/llcp_commands.c15
-rw-r--r--net/nfc/llcp_core.c2
-rw-r--r--net/nfc/nci/core.c4
-rw-r--r--net/nfc/nci/data.c2
-rw-r--r--net/nfc/nci/hci.c7
-rw-r--r--net/nfc/nci/uart.c2
8 files changed, 25 insertions, 30 deletions
diff --git a/net/nfc/digital_dep.c b/net/nfc/digital_dep.c
index f864ce19e13d..f44f75a2a4d5 100644
--- a/net/nfc/digital_dep.c
+++ b/net/nfc/digital_dep.c
@@ -226,8 +226,7 @@ digital_send_dep_data_prep(struct nfc_digital_dev *ddev, struct sk_buff *skb,
226 return ERR_PTR(-ENOMEM); 226 return ERR_PTR(-ENOMEM);
227 } 227 }
228 228
229 memcpy(skb_put(new_skb, ddev->remote_payload_max), skb->data, 229 skb_put_data(new_skb, skb->data, ddev->remote_payload_max);
230 ddev->remote_payload_max);
231 skb_pull(skb, ddev->remote_payload_max); 230 skb_pull(skb, ddev->remote_payload_max);
232 231
233 ddev->chaining_skb = skb; 232 ddev->chaining_skb = skb;
@@ -277,8 +276,7 @@ digital_recv_dep_data_gather(struct nfc_digital_dev *ddev, u8 pfb,
277 ddev->chaining_skb = new_skb; 276 ddev->chaining_skb = new_skb;
278 } 277 }
279 278
280 memcpy(skb_put(ddev->chaining_skb, resp->len), resp->data, 279 skb_put_data(ddev->chaining_skb, resp->data, resp->len);
281 resp->len);
282 280
283 kfree_skb(resp); 281 kfree_skb(resp);
284 resp = NULL; 282 resp = NULL;
@@ -525,7 +523,7 @@ int digital_in_send_atr_req(struct nfc_digital_dev *ddev,
525 523
526 if (gb_len) { 524 if (gb_len) {
527 atr_req->pp |= DIGITAL_GB_BIT; 525 atr_req->pp |= DIGITAL_GB_BIT;
528 memcpy(skb_put(skb, gb_len), gb, gb_len); 526 skb_put_data(skb, gb, gb_len);
529 } 527 }
530 528
531 digital_skb_push_dep_sod(ddev, skb); 529 digital_skb_push_dep_sod(ddev, skb);
@@ -1012,8 +1010,7 @@ static int digital_tg_send_ack(struct nfc_digital_dev *ddev,
1012 if (ddev->did) { 1010 if (ddev->did) {
1013 dep_res->pfb |= DIGITAL_NFC_DEP_PFB_DID_BIT; 1011 dep_res->pfb |= DIGITAL_NFC_DEP_PFB_DID_BIT;
1014 1012
1015 memcpy(skb_put(skb, sizeof(ddev->did)), &ddev->did, 1013 skb_put_data(skb, &ddev->did, sizeof(ddev->did));
1016 sizeof(ddev->did));
1017 } 1014 }
1018 1015
1019 ddev->curr_nfc_dep_pni = 1016 ddev->curr_nfc_dep_pni =
@@ -1057,8 +1054,7 @@ static int digital_tg_send_atn(struct nfc_digital_dev *ddev)
1057 if (ddev->did) { 1054 if (ddev->did) {
1058 dep_res->pfb |= DIGITAL_NFC_DEP_PFB_DID_BIT; 1055 dep_res->pfb |= DIGITAL_NFC_DEP_PFB_DID_BIT;
1059 1056
1060 memcpy(skb_put(skb, sizeof(ddev->did)), &ddev->did, 1057 skb_put_data(skb, &ddev->did, sizeof(ddev->did));
1061 sizeof(ddev->did));
1062 } 1058 }
1063 1059
1064 digital_skb_push_dep_sod(ddev, skb); 1060 digital_skb_push_dep_sod(ddev, skb);
@@ -1325,8 +1321,7 @@ int digital_tg_send_dep_res(struct nfc_digital_dev *ddev, struct sk_buff *skb)
1325 if (ddev->did) { 1321 if (ddev->did) {
1326 dep_res->pfb |= DIGITAL_NFC_DEP_PFB_DID_BIT; 1322 dep_res->pfb |= DIGITAL_NFC_DEP_PFB_DID_BIT;
1327 1323
1328 memcpy(skb_put(skb, sizeof(ddev->did)), &ddev->did, 1324 skb_put_data(skb, &ddev->did, sizeof(ddev->did));
1329 sizeof(ddev->did));
1330 } 1325 }
1331 1326
1332 ddev->curr_nfc_dep_pni = 1327 ddev->curr_nfc_dep_pni =
diff --git a/net/nfc/hci/core.c b/net/nfc/hci/core.c
index 2b0f0ac498d2..8741ad47a6fb 100644
--- a/net/nfc/hci/core.c
+++ b/net/nfc/hci/core.c
@@ -878,9 +878,9 @@ static void nfc_hci_recv_from_llc(struct nfc_hci_dev *hdev, struct sk_buff *skb)
878 878
879 skb_queue_walk(&hdev->rx_hcp_frags, frag_skb) { 879 skb_queue_walk(&hdev->rx_hcp_frags, frag_skb) {
880 msg_len = frag_skb->len - NFC_HCI_HCP_PACKET_HEADER_LEN; 880 msg_len = frag_skb->len - NFC_HCI_HCP_PACKET_HEADER_LEN;
881 memcpy(skb_put(hcp_skb, msg_len), 881 skb_put_data(hcp_skb,
882 frag_skb->data + NFC_HCI_HCP_PACKET_HEADER_LEN, 882 frag_skb->data + NFC_HCI_HCP_PACKET_HEADER_LEN,
883 msg_len); 883 msg_len);
884 } 884 }
885 885
886 skb_queue_purge(&hdev->rx_hcp_frags); 886 skb_queue_purge(&hdev->rx_hcp_frags);
diff --git a/net/nfc/llcp_commands.c b/net/nfc/llcp_commands.c
index c5959ce503e6..367d8c027101 100644
--- a/net/nfc/llcp_commands.c
+++ b/net/nfc/llcp_commands.c
@@ -298,7 +298,7 @@ static struct sk_buff *llcp_add_header(struct sk_buff *pdu,
298 298
299 pr_debug("header 0x%x 0x%x\n", header[0], header[1]); 299 pr_debug("header 0x%x 0x%x\n", header[0], header[1]);
300 300
301 memcpy(skb_put(pdu, LLCP_HEADER_SIZE), header, LLCP_HEADER_SIZE); 301 skb_put_data(pdu, header, LLCP_HEADER_SIZE);
302 302
303 return pdu; 303 return pdu;
304} 304}
@@ -311,7 +311,7 @@ static struct sk_buff *llcp_add_tlv(struct sk_buff *pdu, u8 *tlv,
311 if (tlv == NULL) 311 if (tlv == NULL)
312 return NULL; 312 return NULL;
313 313
314 memcpy(skb_put(pdu, tlv_length), tlv, tlv_length); 314 skb_put_data(pdu, tlv, tlv_length);
315 315
316 return pdu; 316 return pdu;
317} 317}
@@ -549,7 +549,7 @@ int nfc_llcp_send_snl_sdres(struct nfc_llcp_local *local,
549 return PTR_ERR(skb); 549 return PTR_ERR(skb);
550 550
551 hlist_for_each_entry_safe(sdp, n, tlv_list, node) { 551 hlist_for_each_entry_safe(sdp, n, tlv_list, node) {
552 memcpy(skb_put(skb, sdp->tlv_len), sdp->tlv, sdp->tlv_len); 552 skb_put_data(skb, sdp->tlv, sdp->tlv_len);
553 553
554 hlist_del(&sdp->node); 554 hlist_del(&sdp->node);
555 555
@@ -581,8 +581,7 @@ int nfc_llcp_send_snl_sdreq(struct nfc_llcp_local *local,
581 hlist_for_each_entry_safe(sdreq, n, tlv_list, node) { 581 hlist_for_each_entry_safe(sdreq, n, tlv_list, node) {
582 pr_debug("tid %d for %s\n", sdreq->tid, sdreq->uri); 582 pr_debug("tid %d for %s\n", sdreq->tid, sdreq->uri);
583 583
584 memcpy(skb_put(skb, sdreq->tlv_len), sdreq->tlv, 584 skb_put_data(skb, sdreq->tlv, sdreq->tlv_len);
585 sdreq->tlv_len);
586 585
587 hlist_del(&sdreq->node); 586 hlist_del(&sdreq->node);
588 587
@@ -622,7 +621,7 @@ int nfc_llcp_send_dm(struct nfc_llcp_local *local, u8 ssap, u8 dsap, u8 reason)
622 621
623 skb = llcp_add_header(skb, dsap, ssap, LLCP_PDU_DM); 622 skb = llcp_add_header(skb, dsap, ssap, LLCP_PDU_DM);
624 623
625 memcpy(skb_put(skb, 1), &reason, 1); 624 skb_put_data(skb, &reason, 1);
626 625
627 skb_queue_head(&local->tx_queue, skb); 626 skb_queue_head(&local->tx_queue, skb);
628 627
@@ -693,7 +692,7 @@ int nfc_llcp_send_i_frame(struct nfc_llcp_sock *sock,
693 skb_put(pdu, LLCP_SEQUENCE_SIZE); 692 skb_put(pdu, LLCP_SEQUENCE_SIZE);
694 693
695 if (likely(frag_len > 0)) 694 if (likely(frag_len > 0))
696 memcpy(skb_put(pdu, frag_len), msg_ptr, frag_len); 695 skb_put_data(pdu, msg_ptr, frag_len);
697 696
698 skb_queue_tail(&sock->tx_queue, pdu); 697 skb_queue_tail(&sock->tx_queue, pdu);
699 698
@@ -759,7 +758,7 @@ int nfc_llcp_send_ui_frame(struct nfc_llcp_sock *sock, u8 ssap, u8 dsap,
759 pdu = llcp_add_header(pdu, dsap, ssap, LLCP_PDU_UI); 758 pdu = llcp_add_header(pdu, dsap, ssap, LLCP_PDU_UI);
760 759
761 if (likely(frag_len > 0)) 760 if (likely(frag_len > 0))
762 memcpy(skb_put(pdu, frag_len), msg_ptr, frag_len); 761 skb_put_data(pdu, msg_ptr, frag_len);
763 762
764 /* No need to check for the peer RW for UI frames */ 763 /* No need to check for the peer RW for UI frames */
765 skb_queue_tail(&local->tx_queue, pdu); 764 skb_queue_tail(&local->tx_queue, pdu);
diff --git a/net/nfc/llcp_core.c b/net/nfc/llcp_core.c
index e69786c6804c..02eef5cf3cce 100644
--- a/net/nfc/llcp_core.c
+++ b/net/nfc/llcp_core.c
@@ -1390,7 +1390,7 @@ static void nfc_llcp_recv_agf(struct nfc_llcp_local *local, struct sk_buff *skb)
1390 return; 1390 return;
1391 } 1391 }
1392 1392
1393 memcpy(skb_put(new_skb, pdu_len), skb->data, pdu_len); 1393 skb_put_data(new_skb, skb->data, pdu_len);
1394 1394
1395 nfc_llcp_rx_skb(local, new_skb); 1395 nfc_llcp_rx_skb(local, new_skb);
1396 1396
diff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c
index 61fff422424f..17b9f1ce23db 100644
--- a/net/nfc/nci/core.c
+++ b/net/nfc/nci/core.c
@@ -462,7 +462,7 @@ int nci_nfcc_loopback(struct nci_dev *ndev, void *data, size_t data_len,
462 return -ENOMEM; 462 return -ENOMEM;
463 463
464 skb_reserve(skb, NCI_DATA_HDR_SIZE); 464 skb_reserve(skb, NCI_DATA_HDR_SIZE);
465 memcpy(skb_put(skb, data_len), data, data_len); 465 skb_put_data(skb, data, data_len);
466 466
467 loopback_data.conn_id = conn_id; 467 loopback_data.conn_id = conn_id;
468 loopback_data.data = skb; 468 loopback_data.data = skb;
@@ -1350,7 +1350,7 @@ int nci_send_cmd(struct nci_dev *ndev, __u16 opcode, __u8 plen, void *payload)
1350 nci_pbf_set((__u8 *)hdr, NCI_PBF_LAST); 1350 nci_pbf_set((__u8 *)hdr, NCI_PBF_LAST);
1351 1351
1352 if (plen) 1352 if (plen)
1353 memcpy(skb_put(skb, plen), payload, plen); 1353 skb_put_data(skb, payload, plen);
1354 1354
1355 skb_queue_tail(&ndev->cmd_q, skb); 1355 skb_queue_tail(&ndev->cmd_q, skb);
1356 queue_work(ndev->cmd_wq, &ndev->cmd_work); 1356 queue_work(ndev->cmd_wq, &ndev->cmd_work);
diff --git a/net/nfc/nci/data.c b/net/nfc/nci/data.c
index dbd24254412a..2488d9241f1d 100644
--- a/net/nfc/nci/data.c
+++ b/net/nfc/nci/data.c
@@ -138,7 +138,7 @@ static int nci_queue_tx_data_frags(struct nci_dev *ndev,
138 skb_reserve(skb_frag, NCI_DATA_HDR_SIZE); 138 skb_reserve(skb_frag, NCI_DATA_HDR_SIZE);
139 139
140 /* first, copy the data */ 140 /* first, copy the data */
141 memcpy(skb_put(skb_frag, frag_len), data, frag_len); 141 skb_put_data(skb_frag, data, frag_len);
142 142
143 /* second, set the header */ 143 /* second, set the header */
144 nci_push_data_hdr(ndev, conn_id, skb_frag, 144 nci_push_data_hdr(ndev, conn_id, skb_frag,
diff --git a/net/nfc/nci/hci.c b/net/nfc/nci/hci.c
index a0ab26d535dc..d4a53ce818c3 100644
--- a/net/nfc/nci/hci.c
+++ b/net/nfc/nci/hci.c
@@ -187,7 +187,7 @@ static int nci_hci_send_data(struct nci_dev *ndev, u8 pipe,
187 *skb_push(skb, 1) = cb; 187 *skb_push(skb, 1) = cb;
188 188
189 if (len > 0) 189 if (len > 0)
190 memcpy(skb_put(skb, len), data + i, len); 190 skb_put_data(skb, data + i, len);
191 191
192 r = nci_send_data(ndev, conn_info->conn_id, skb); 192 r = nci_send_data(ndev, conn_info->conn_id, skb);
193 if (r < 0) 193 if (r < 0)
@@ -476,8 +476,9 @@ void nci_hci_data_received_cb(void *context,
476 476
477 skb_queue_walk(&ndev->hci_dev->rx_hcp_frags, frag_skb) { 477 skb_queue_walk(&ndev->hci_dev->rx_hcp_frags, frag_skb) {
478 msg_len = frag_skb->len - NCI_HCI_HCP_PACKET_HEADER_LEN; 478 msg_len = frag_skb->len - NCI_HCI_HCP_PACKET_HEADER_LEN;
479 memcpy(skb_put(hcp_skb, msg_len), frag_skb->data + 479 skb_put_data(hcp_skb,
480 NCI_HCI_HCP_PACKET_HEADER_LEN, msg_len); 480 frag_skb->data + NCI_HCI_HCP_PACKET_HEADER_LEN,
481 msg_len);
481 } 482 }
482 483
483 skb_queue_purge(&ndev->hci_dev->rx_hcp_frags); 484 skb_queue_purge(&ndev->hci_dev->rx_hcp_frags);
diff --git a/net/nfc/nci/uart.c b/net/nfc/nci/uart.c
index c468eabd6943..cfa7f352c1c3 100644
--- a/net/nfc/nci/uart.c
+++ b/net/nfc/nci/uart.c
@@ -371,7 +371,7 @@ static int nci_uart_default_recv_buf(struct nci_uart *nu, const u8 *data,
371 chunk_len = nu->rx_packet_len - nu->rx_skb->len; 371 chunk_len = nu->rx_packet_len - nu->rx_skb->len;
372 if (count < chunk_len) 372 if (count < chunk_len)
373 chunk_len = count; 373 chunk_len = count;
374 memcpy(skb_put(nu->rx_skb, chunk_len), data, chunk_len); 374 skb_put_data(nu->rx_skb, data, chunk_len);
375 data += chunk_len; 375 data += chunk_len;
376 count -= chunk_len; 376 count -= chunk_len;
377 377