Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1974218pxf; Sat, 13 Mar 2021 03:49:58 -0800 (PST) X-Google-Smtp-Source: ABdhPJwzbmB3QYUwxHAa3OvF2gUclQy1X9C0Sgtqrm6/IM4AowWG4yndwJGoQAb9bI7B/zl8yHYJ X-Received: by 2002:a05:6402:9:: with SMTP id d9mr19374701edu.67.1615636198060; Sat, 13 Mar 2021 03:49:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615636198; cv=none; d=google.com; s=arc-20160816; b=OGE5gjXdTcxMX7BNy/4T8Sy3KSOHEnhzezoXNeKgwruXAdNrvkAvhPMpGMo5d3s2Up Do+ZCiZd4KCqDPqtIbzk06QlXBtMI1UJgJMQzf9zuy3j7XAZ07yqe2K0YmgZKS5tu4q2 aDkMGzHVqEYVaYEhcCRcDw9J327oh2+M4CDFhpYoEDGFJMoPi5kGAxzbACMO2gFEld5P PSzwwKkWyBWQT805HPCCYzqo3kLjhjs8EJQVkdcxgx19uAd5xKZS5grRzoe3eaTIWQW3 U9FDk4TgbqW4x342cx9kmFC+bkrmq/B8KWEKAueDnU8r5mr/SbBTI0V7LTfHMKGyKaDG OJGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:reply-to:cc:from:to :dkim-signature:date; bh=vmmngqxOxcaVC9lxuUjw8Hw9KFLiK+YZkSVm3lvGvyM=; b=YinEhp9jidHDZBK/t69Z9/039Lr7Fc1RoESUlcunfgOvxr+Y6Lmrc/gCfquyjm/ToV WfuOb99aaE24xZw6jpRWgSJo4ZXEpPU4nLobJfUdV/vxHmfpGaTmkLNAuDVQ1rP49YdS WQTSxfonNs9jJR/IADboWQUgz6pjo8/2aL2sDszcfLjohiOSmk98WU//tQBzIsha1IW6 Dk6c54UYTOZJZv+FHxfkqY3YbaQp+2fhit6s6qnhTDBq5ow66SAvkwUpPZTYNsBKyQmu hXUjVBw/j3knNfhSwGgScn9FliWyru3mkBH0Ltwy9qSdjSFRuQDBu7MphDd5APwkADtb SefA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@pm.me header.s=protonmail header.b=Xm1z4AHZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=pm.me Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ks7si6263058ejb.682.2021.03.13.03.49.35; Sat, 13 Mar 2021 03:49:58 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@pm.me header.s=protonmail header.b=Xm1z4AHZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=pm.me Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233715AbhCMLiI (ORCPT + 99 others); Sat, 13 Mar 2021 06:38:08 -0500 Received: from mail2.protonmail.ch ([185.70.40.22]:48116 "EHLO mail2.protonmail.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233114AbhCMLhk (ORCPT ); Sat, 13 Mar 2021 06:37:40 -0500 Date: Sat, 13 Mar 2021 11:37:36 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=pm.me; s=protonmail; t=1615635459; bh=vmmngqxOxcaVC9lxuUjw8Hw9KFLiK+YZkSVm3lvGvyM=; h=Date:To:From:Cc:Reply-To:Subject:In-Reply-To:References:From; b=Xm1z4AHZ/pdLFeE4pfTfuYJZ/YQlYGLRrWBh0JK9nPJUM/dpmYb9eCz6I1EauqzZB IOj6441PiKGKr5WkwJn+FXQbIVeHEA2Bov4IoyuyzpwF3MF0WFUEfQy4IK0iETPMQN +sLu8ABHte7YwcaK9s8wtGT2qiApCNIGQJ4dach/O2sVlmb4Ejl1X9XAmGJaY2jyxH ZikkRZCQWoCjD3C2XR9KC8yUHJUuq25uw5706tZ+pZYQ9JwW9POFHMtPi0XDM7Hiwk AVPbYrHAPBtToTWGG+u5DpQ+sjiN9MU3JePAPODL38sV2bBkYxS22jR9aCxi4XJySa Qy8EMPDpgo8FQ== To: "David S. Miller" , Jakub Kicinski From: Alexander Lobakin Cc: Alexei Starovoitov , Daniel Borkmann , Andrii Nakryiko , Martin KaFai Lau , Song Liu , Yonghong Song , John Fastabend , KP Singh , Jonathan Lemon , Alexander Lobakin , Eric Dumazet , Willem de Bruijn , Kevin Hao , Pablo Neira Ayuso , Jakub Sitnicki , Marco Elver , Dexuan Cui , Vladimir Oltean , Ariel Levkovich , Wang Qing , Davide Caratti , Guillaume Nault , Eran Ben Elisha , Mauro Carvalho Chehab , Kirill Tkhai , Bartosz Golaszewski , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, bpf@vger.kernel.org Reply-To: Alexander Lobakin Subject: [PATCH v2 net-next 3/6] flow_dissector: constify raw input @data argument Message-ID: <20210313113645.5949-4-alobakin@pm.me> In-Reply-To: <20210313113645.5949-1-alobakin@pm.me> References: <20210313113645.5949-1-alobakin@pm.me> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-1.2 required=10.0 tests=ALL_TRUSTED,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF shortcircuit=no autolearn=disabled version=3.4.4 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on mailout.protonmail.ch Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Flow Dissector code never modifies the input buffer, neither skb nor raw data. Make @data argument const for all of the Flow dissector's functions. Signed-off-by: Alexander Lobakin --- include/linux/skbuff.h | 15 ++++++------- include/net/flow_dissector.h | 2 +- net/core/flow_dissector.c | 41 +++++++++++++++++++----------------- 3 files changed, 30 insertions(+), 28 deletions(-) diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index d6ea3dc3eddb..46c61e127e9f 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h @@ -1292,10 +1292,10 @@ __skb_set_sw_hash(struct sk_buff *skb, __u32 hash, = bool is_l4) void __skb_get_hash(struct sk_buff *skb); u32 __skb_get_hash_symmetric(const struct sk_buff *skb); u32 skb_get_poff(const struct sk_buff *skb); -u32 __skb_get_poff(const struct sk_buff *skb, void *data, +u32 __skb_get_poff(const struct sk_buff *skb, const void *data, =09=09 const struct flow_keys_basic *keys, int hlen); __be32 __skb_flow_get_ports(const struct sk_buff *skb, int thoff, u8 ip_pr= oto, -=09=09=09 void *data, int hlen_proto); +=09=09=09 const void *data, int hlen_proto); static inline __be32 skb_flow_get_ports(const struct sk_buff *skb, =09=09=09=09=09int thoff, u8 ip_proto) @@ -1314,9 +1314,8 @@ bool bpf_flow_dissect(struct bpf_prog *prog, struct b= pf_flow_dissector *ctx, bool __skb_flow_dissect(const struct net *net, =09=09=09const struct sk_buff *skb, =09=09=09struct flow_dissector *flow_dissector, -=09=09=09void *target_container, -=09=09=09void *data, __be16 proto, int nhoff, int hlen, -=09=09=09unsigned int flags); +=09=09=09void *target_container, const void *data, +=09=09=09__be16 proto, int nhoff, int hlen, unsigned int flags); static inline bool skb_flow_dissect(const struct sk_buff *skb, =09=09=09=09 struct flow_dissector *flow_dissector, @@ -1338,9 +1337,9 @@ static inline bool skb_flow_dissect_flow_keys(const s= truct sk_buff *skb, static inline bool skb_flow_dissect_flow_keys_basic(const struct net *net, =09=09=09=09 const struct sk_buff *skb, -=09=09=09=09 struct flow_keys_basic *flow, void *data, -=09=09=09=09 __be16 proto, int nhoff, int hlen, -=09=09=09=09 unsigned int flags) +=09=09=09=09 struct flow_keys_basic *flow, +=09=09=09=09 const void *data, __be16 proto, +=09=09=09=09 int nhoff, int hlen, unsigned int flags) { =09memset(flow, 0, sizeof(*flow)); =09return __skb_flow_dissect(net, skb, &flow_keys_basic_dissector, flow, diff --git a/include/net/flow_dissector.h b/include/net/flow_dissector.h index bf00e71816ed..ffd386ea0dbb 100644 --- a/include/net/flow_dissector.h +++ b/include/net/flow_dissector.h @@ -350,7 +350,7 @@ static inline bool flow_keys_have_l4(const struct flow_= keys *keys) u32 flow_hash_from_keys(struct flow_keys *keys); void skb_flow_get_icmp_tci(const struct sk_buff *skb, =09=09=09 struct flow_dissector_key_icmp *key_icmp, -=09=09=09 void *data, int thoff, int hlen); +=09=09=09 const void *data, int thoff, int hlen); static inline bool dissector_uses_key(const struct flow_dissector *flow_di= ssector, =09=09=09=09 enum flow_dissector_key_id key_id) diff --git a/net/core/flow_dissector.c b/net/core/flow_dissector.c index 2ef2224b3bff..2ed380d096ce 100644 --- a/net/core/flow_dissector.c +++ b/net/core/flow_dissector.c @@ -114,7 +114,7 @@ int flow_dissector_bpf_prog_attach_check(struct net *ne= t, * is the protocol port offset returned from proto_ports_offset */ __be32 __skb_flow_get_ports(const struct sk_buff *skb, int thoff, u8 ip_pr= oto, -=09=09=09 void *data, int hlen) +=09=09=09 const void *data, int hlen) { =09int poff =3D proto_ports_offset(ip_proto); @@ -161,7 +161,7 @@ static bool icmp_has_id(u8 type) */ void skb_flow_get_icmp_tci(const struct sk_buff *skb, =09=09=09 struct flow_dissector_key_icmp *key_icmp, -=09=09=09 void *data, int thoff, int hlen) +=09=09=09 const void *data, int thoff, int hlen) { =09struct icmphdr *ih, _ih; @@ -187,8 +187,8 @@ EXPORT_SYMBOL(skb_flow_get_icmp_tci); */ static void __skb_flow_dissect_icmp(const struct sk_buff *skb, =09=09=09=09 struct flow_dissector *flow_dissector, -=09=09=09=09 void *target_container, -=09=09=09=09 void *data, int thoff, int hlen) +=09=09=09=09 void *target_container, const void *data, +=09=09=09=09 int thoff, int hlen) { =09struct flow_dissector_key_icmp *key_icmp; @@ -409,8 +409,8 @@ EXPORT_SYMBOL(skb_flow_dissect_hash); static enum flow_dissect_ret __skb_flow_dissect_mpls(const struct sk_buff *skb, =09=09=09struct flow_dissector *flow_dissector, -=09=09=09void *target_container, void *data, int nhoff, int hlen, -=09=09=09int lse_index, bool *entropy_label) +=09=09=09void *target_container, const void *data, int nhoff, +=09=09=09int hlen, int lse_index, bool *entropy_label) { =09struct mpls_label *hdr, _hdr; =09u32 entry, label, bos; @@ -467,7 +467,8 @@ __skb_flow_dissect_mpls(const struct sk_buff *skb, static enum flow_dissect_ret __skb_flow_dissect_arp(const struct sk_buff *skb, =09=09 struct flow_dissector *flow_dissector, -=09=09 void *target_container, void *data, int nhoff, int hlen) +=09=09 void *target_container, const void *data, +=09=09 int nhoff, int hlen) { =09struct flow_dissector_key_arp *key_arp; =09struct { @@ -523,7 +524,7 @@ static enum flow_dissect_ret __skb_flow_dissect_gre(const struct sk_buff *skb, =09=09 struct flow_dissector_key_control *key_control, =09=09 struct flow_dissector *flow_dissector, -=09=09 void *target_container, void *data, +=09=09 void *target_container, const void *data, =09=09 __be16 *p_proto, int *p_nhoff, int *p_hlen, =09=09 unsigned int flags) { @@ -663,8 +664,8 @@ __skb_flow_dissect_gre(const struct sk_buff *skb, static enum flow_dissect_ret __skb_flow_dissect_batadv(const struct sk_buff *skb, =09=09=09 struct flow_dissector_key_control *key_control, -=09=09=09 void *data, __be16 *p_proto, int *p_nhoff, int hlen, -=09=09=09 unsigned int flags) +=09=09=09 const void *data, __be16 *p_proto, int *p_nhoff, +=09=09=09 int hlen, unsigned int flags) { =09struct { =09=09struct batadv_unicast_packet batadv_unicast; @@ -695,7 +696,8 @@ __skb_flow_dissect_batadv(const struct sk_buff *skb, static void __skb_flow_dissect_tcp(const struct sk_buff *skb, =09=09 struct flow_dissector *flow_dissector, -=09=09 void *target_container, void *data, int thoff, int hlen) +=09=09 void *target_container, const void *data, +=09=09 int thoff, int hlen) { =09struct flow_dissector_key_tcp *key_tcp; =09struct tcphdr *th, _th; @@ -719,8 +721,8 @@ __skb_flow_dissect_tcp(const struct sk_buff *skb, static void __skb_flow_dissect_ports(const struct sk_buff *skb, =09=09=09 struct flow_dissector *flow_dissector, -=09=09=09 void *target_container, void *data, int nhoff, -=09=09=09 u8 ip_proto, int hlen) +=09=09=09 void *target_container, const void *data, +=09=09=09 int nhoff, u8 ip_proto, int hlen) { =09enum flow_dissector_key_id dissector_ports =3D FLOW_DISSECTOR_KEY_MAX; =09struct flow_dissector_key_ports *key_ports; @@ -744,7 +746,8 @@ __skb_flow_dissect_ports(const struct sk_buff *skb, static void __skb_flow_dissect_ipv4(const struct sk_buff *skb, =09=09=09struct flow_dissector *flow_dissector, -=09=09=09void *target_container, void *data, const struct iphdr *iph) +=09=09=09void *target_container, const void *data, +=09=09=09const struct iphdr *iph) { =09struct flow_dissector_key_ip *key_ip; @@ -761,7 +764,8 @@ __skb_flow_dissect_ipv4(const struct sk_buff *skb, static void __skb_flow_dissect_ipv6(const struct sk_buff *skb, =09=09=09struct flow_dissector *flow_dissector, -=09=09=09void *target_container, void *data, const struct ipv6hdr *iph) +=09=09=09void *target_container, const void *data, +=09=09=09const struct ipv6hdr *iph) { =09struct flow_dissector_key_ip *key_ip; @@ -908,9 +912,8 @@ bool bpf_flow_dissect(struct bpf_prog *prog, struct bpf= _flow_dissector *ctx, bool __skb_flow_dissect(const struct net *net, =09=09=09const struct sk_buff *skb, =09=09=09struct flow_dissector *flow_dissector, -=09=09=09void *target_container, -=09=09=09void *data, __be16 proto, int nhoff, int hlen, -=09=09=09unsigned int flags) +=09=09=09void *target_container, const void *data, +=09=09=09__be16 proto, int nhoff, int hlen, unsigned int flags) { =09struct flow_dissector_key_control *key_control; =09struct flow_dissector_key_basic *key_basic; @@ -1642,7 +1645,7 @@ __u32 skb_get_hash_perturb(const struct sk_buff *skb, } EXPORT_SYMBOL(skb_get_hash_perturb); -u32 __skb_get_poff(const struct sk_buff *skb, void *data, +u32 __skb_get_poff(const struct sk_buff *skb, const void *data, =09=09 const struct flow_keys_basic *keys, int hlen) { =09u32 poff =3D keys->control.thoff; -- 2.30.2