Received: by 2002:a05:6512:2355:0:0:0:0 with SMTP id p21csp207205lfu; Wed, 30 Mar 2022 20:59:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxTINUn8AChgZ0OzDiy9gEmLVixH5DW/w++toCDmQ8L8/0l5NlukIpK75BpWHyOfJWwykuD X-Received: by 2002:a05:6a00:887:b0:4f2:6d3f:5b53 with SMTP id q7-20020a056a00088700b004f26d3f5b53mr36966018pfj.21.1648699158811; Wed, 30 Mar 2022 20:59:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648699158; cv=none; d=google.com; s=arc-20160816; b=j//nf0Yagoqh4kQZ9Qw2k+katEmnkLJr67omsqeJCdlsiNeg0buIQjKI/wvmfjsh5d OtZ7q0x+k2eHeYsqilZqI+klWb1qyrQQR2Q8iaqfGvT2CNrg6qvctul+UwxpStVSqz20 DqCMlybev3vTSGAoORuvQwYCXeLJqB9J3kDOssNQHpnOygdV2tplDyOILlQAJ5uDsg/8 nKaxlmr1HheoGPpRmyeYCso5/A+nPsSWOF1ALlC6fKjko7oidj5xTlpzKrab0ATQ3D18 uNELdQKYW3eD4Ojscj9I61MJVrrKcqGdflDbxo2s4Dq/ktqhctNYx/e9CDCLckp4nkEM adQw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature:dkim-signature; bh=JZ7etbOkud23rePgYHX93VM2Npayks8E311gepaCXY8=; b=uMAmo5Q23ZMqRWuXOQHJlmNm5sw2b5oRvXCTWHjrgvZhMqyi/tN30Y8wT9iqPHnMtq cc1rWJVKcyQd4A2SZWP87SRnKIcECbbjW0mgEoH0LLkY9K28kf44uAs82zkF7oCMdchM i2ZgZdq9A2oFrbMgv62ocAavkkS8tYdifClyGo5gu3oxWDcz3+Xzi853AHgvTI9jr4bk gybNbQeWNhLI6wPVtoOqXym54jEetcrMV8N9pxUujZpizxDpuNOxfLvm3weBjuQgOi9Y QoouzzwJ9E2c0brxVDtBiW3danC+jKkny6RjEbrQy/JMfumiAdMl1Eg1x3+eHAeBxvvb qwtg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b="WpI/P3lw"; dkim=neutral (no key) header.i=@suse.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id r10-20020a63ce4a000000b003816043f02esi21989380pgi.547.2022.03.30.20.59.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 30 Mar 2022 20:59:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b="WpI/P3lw"; dkim=neutral (no key) header.i=@suse.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Received: from out1.vger.email (out1.vger.email [IPv6:2620:137:e000::1:20]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id B90E9182AF2; Wed, 30 Mar 2022 20:11:34 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345532AbiC3Nfm (ORCPT + 99 others); Wed, 30 Mar 2022 09:35:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54634 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237223AbiC3Nfk (ORCPT ); Wed, 30 Mar 2022 09:35:40 -0400 Received: from smtp-out1.suse.de (smtp-out1.suse.de [195.135.220.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5732612ABF; Wed, 30 Mar 2022 06:33:55 -0700 (PDT) Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by smtp-out1.suse.de (Postfix) with ESMTPS id 1316A21603; Wed, 30 Mar 2022 13:33:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_rsa; t=1648647234; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=JZ7etbOkud23rePgYHX93VM2Npayks8E311gepaCXY8=; b=WpI/P3lwWz2bV3KFAUbTx0kz/vfwAV0U3f6iBQK1XjHMl8LXl4vOQYhPUvrL8MrCzkfgD7 MEQWIsGbyrQaHo8iX5NkpvPZHn4rXD89G6gSTIfbJLGtt8yC106/LGheJT0WpM/TEgjyZj yu2ij34aoVAdBsVxonQlWow8zrQ2Btw= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_ed25519; t=1648647234; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=JZ7etbOkud23rePgYHX93VM2Npayks8E311gepaCXY8=; b=Dj4Od0Ng8MqvY192E61SBMgtpwD6sjqpn+eheGNsS/vwgu8+LIwt970QapimTNpxsw82xp mCASVJH5OkqnCrBA== Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by imap2.suse-dmz.suse.de (Postfix) with ESMTPS id 561EE13AF3; Wed, 30 Mar 2022 13:33:53 +0000 (UTC) Received: from dovecot-director2.suse.de ([192.168.254.65]) by imap2.suse-dmz.suse.de with ESMTPSA id o57tEUFcRGK1WQAAMHmgww (envelope-from ); Wed, 30 Mar 2022 13:33:53 +0000 Message-ID: <9f7a92f5-5674-5c9f-e5ec-4a68ec8cb0d1@suse.de> Date: Wed, 30 Mar 2022 16:33:48 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 Subject: Re: [PATCH] tcp: Add tracepoint for tcp_set_ca_state Content-Language: ru To: jackygam2001 , edumazet@google.com, davem@davemloft.net, kuba@kernel.org, pabeni@redhat.com, rostedt@goodmis.org, mingo@redhat.com, yoshfuji@linux-ipv6.org, dsahern@kernel.org Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, ping.gan@dell.com References: <20220330130128.10256-1-jacky_gam_2001@163.com> From: Denis Kirjanov In-Reply-To: <20220330130128.10256-1-jacky_gam_2001@163.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,RDNS_NONE,SPF_HELO_NONE, T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3/30/22 16:01, jackygam2001 пишет: > The congestion status of a tcp flow may be updated since there > is congestion between tcp sender and receiver. It makes sense for > adding tracepoint for congestion status update function to evaluate > the performance of network and congestion algorithm. > > Link: https://github.com/iovisor/bcc/pull/3899 > > Signed-off-by: jackygam2001 Please use net-next prefix and use your real name in SOB > --- > include/net/tcp.h | 12 +++--------- > include/trace/events/tcp.h | 45 +++++++++++++++++++++++++++++++++++++++++++++ > net/ipv4/tcp_cong.c | 12 ++++++++++++ > 3 files changed, 60 insertions(+), 9 deletions(-) > > diff --git a/include/net/tcp.h b/include/net/tcp.h > index 70ca4a5e330a..9a3786f33798 100644 > --- a/include/net/tcp.h > +++ b/include/net/tcp.h > @@ -1139,15 +1139,6 @@ static inline bool tcp_ca_needs_ecn(const struct sock *sk) > return icsk->icsk_ca_ops->flags & TCP_CONG_NEEDS_ECN; > } > > -static inline void tcp_set_ca_state(struct sock *sk, const u8 ca_state) > -{ > - struct inet_connection_sock *icsk = inet_csk(sk); > - > - if (icsk->icsk_ca_ops->set_state) > - icsk->icsk_ca_ops->set_state(sk, ca_state); > - icsk->icsk_ca_state = ca_state; > -} > - > static inline void tcp_ca_event(struct sock *sk, const enum tcp_ca_event event) > { > const struct inet_connection_sock *icsk = inet_csk(sk); > @@ -1156,6 +1147,9 @@ static inline void tcp_ca_event(struct sock *sk, const enum tcp_ca_event event) > icsk->icsk_ca_ops->cwnd_event(sk, event); > } > > +/* From tcp_cong.c */ > +void tcp_set_ca_state(struct sock *sk, const u8 ca_state); > + > /* From tcp_rate.c */ > void tcp_rate_skb_sent(struct sock *sk, struct sk_buff *skb); > void tcp_rate_skb_delivered(struct sock *sk, struct sk_buff *skb, > diff --git a/include/trace/events/tcp.h b/include/trace/events/tcp.h > index 521059d8dc0a..69a68b01c1de 100644 > --- a/include/trace/events/tcp.h > +++ b/include/trace/events/tcp.h > @@ -371,6 +371,51 @@ DEFINE_EVENT(tcp_event_skb, tcp_bad_csum, > TP_ARGS(skb) > ); > > +TRACE_EVENT(tcp_cong_state_set, > + > + TP_PROTO(struct sock *sk, const u8 ca_state), > + > + TP_ARGS(sk, ca_state), > + > + TP_STRUCT__entry( > + __field(const void *, skaddr) > + __field(__u16, sport) > + __field(__u16, dport) > + __array(__u8, saddr, 4) > + __array(__u8, daddr, 4) > + __array(__u8, saddr_v6, 16) > + __array(__u8, daddr_v6, 16) > + __field(__u8, cong_state) > + ), > + > + TP_fast_assign( > + struct inet_sock *inet = inet_sk(sk); > + __be32 *p32; > + > + __entry->skaddr = sk; > + > + __entry->sport = ntohs(inet->inet_sport); > + __entry->dport = ntohs(inet->inet_dport); > + > + p32 = (__be32 *) __entry->saddr; > + *p32 = inet->inet_saddr; > + > + p32 = (__be32 *) __entry->daddr; > + *p32 = inet->inet_daddr; > + > + TP_STORE_ADDRS(__entry, inet->inet_saddr, inet->inet_daddr, > + sk->sk_v6_rcv_saddr, sk->sk_v6_daddr); > + > + __entry->cong_state = ca_state; > + ), > + > + TP_printk("sport=%hu dport=%hu saddr=%pI4 daddr=%pI4 saddrv6=%pI6c daddrv6=%pI6c cong_state=%u", > + __entry->sport, __entry->dport, > + __entry->saddr, __entry->daddr, > + __entry->saddr_v6, __entry->daddr_v6, > + __entry->cong_state) > +); > + > #endif /* _TRACE_TCP_H */ > > /* This part must be outside protection */ > diff --git a/net/ipv4/tcp_cong.c b/net/ipv4/tcp_cong.c > index dc95572163df..98b48bdb8be7 100644 > --- a/net/ipv4/tcp_cong.c > +++ b/net/ipv4/tcp_cong.c > @@ -16,6 +16,7 @@ > #include > #include > #include > +#include > > static DEFINE_SPINLOCK(tcp_cong_list_lock); > static LIST_HEAD(tcp_cong_list); > @@ -33,6 +34,17 @@ struct tcp_congestion_ops *tcp_ca_find(const char *name) > return NULL; > } > > +void tcp_set_ca_state(struct sock *sk, const u8 ca_state) > +{ > + struct inet_connection_sock *icsk = inet_csk(sk); > + > + trace_tcp_cong_state_set(sk, ca_state); > + > + if (icsk->icsk_ca_ops->set_state) > + icsk->icsk_ca_ops->set_state(sk, ca_state); > + icsk->icsk_ca_state = ca_state; > +} > + > /* Must be called with rcu lock held */ > static struct tcp_congestion_ops *tcp_ca_find_autoload(struct net *net, > const char *name)