diff options
author | Johannes Berg <johannes.berg@intel.com> | 2017-06-16 08:29:20 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-06-16 11:48:37 -0400 |
commit | 59ae1d127ac0ae404baf414c434ba2651b793f46 (patch) | |
tree | 043e71496aa7a7db86bcc8219a3a51f533aac982 /net/nfc | |
parent | b080db585384b9f037e015c0c28d1ad33be41dfc (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.c | 17 | ||||
-rw-r--r-- | net/nfc/hci/core.c | 6 | ||||
-rw-r--r-- | net/nfc/llcp_commands.c | 15 | ||||
-rw-r--r-- | net/nfc/llcp_core.c | 2 | ||||
-rw-r--r-- | net/nfc/nci/core.c | 4 | ||||
-rw-r--r-- | net/nfc/nci/data.c | 2 | ||||
-rw-r--r-- | net/nfc/nci/hci.c | 7 | ||||
-rw-r--r-- | net/nfc/nci/uart.c | 2 |
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 | ||