Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp2657286rwn; Fri, 16 Sep 2022 14:01:15 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5hD1pYBjsOCCt3LmyK2/q0xKj974DJ4JOT/VoIB2XRohl3VlWl6c5trYuUfIWW+08ba9qU X-Received: by 2002:a63:fe02:0:b0:438:703b:5309 with SMTP id p2-20020a63fe02000000b00438703b5309mr6267953pgh.370.1663362075398; Fri, 16 Sep 2022 14:01:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663362075; cv=none; d=google.com; s=arc-20160816; b=dLA3v5sdEBSseDyJ7dk8PxPqsOuEAeclzEfKW1J/d1Uw0oeziIj9Hd3/Jzv3C1EQdJ LwnnoosAE0WuD7XYEFEu/R18eN6u4l4pQDtOjYyHjIt9zbDYLb62dJFyirQX2R00zRrW A+9FoP5DJOyLFcSNGAfdy1nWzpz6+eMcwcm3duNSSU+9rlPHJy19ryc+JXvSXFklWvqO LiwB0cIVlvguu83f0TTPw/o/jblL5u6XOIC0q/pudls6UeVIO3EQZgsmQTt2T24JPoNo Uxg24NEdgy5iUqaG9IsIzBkv4W7iydxFAWacCj4FECjbaRdedr/XvznjShF6VToBRvce z+tg== 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:mime-version:date :dkim-signature:message-id; bh=TdFPJ/E73gfYJJ71FfMTa2muu9d+Trfydz6NY8WdwhU=; b=d33r8kCfBp7icShuNc1RwKDXksDgAniazcB58sTCe2LuyF/0R2c8fhLP2ooQn/P6ge gPq+j4C9nrizAHZI57GEQv4GjqLc0+q7QPHEQcAUUF7xeQzHDPY1ASHH5uLWiKnlR8OT el5W8AjysHPXwAphIBARNs5DKWry7XBO/1zTcDW+R/RkVZ2CRs1GBUrpqJwnWYaVrGfb 8Zan1xFi/e7mZI/GbaRx0YAH+udaKXFznafpDrSaAyU8ySUWXmDPeY8eTJ7WlwU2xlA6 MF1TdNu0Ls6jbKLcsmckcec2DdmKuE9XBBryhRfJCp3CV2VZgqI0LIYnS9/IB/zwfJXV hc1g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.dev header.s=key1 header.b=G8MmkhFS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.dev Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id u1-20020a17090341c100b00176d6e8c127si23872097ple.126.2022.09.16.14.00.41; Fri, 16 Sep 2022 14:01:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linux.dev header.s=key1 header.b=G8MmkhFS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.dev Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229972AbiIPUU7 (ORCPT + 99 others); Fri, 16 Sep 2022 16:20:59 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57352 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229484AbiIPUU5 (ORCPT ); Fri, 16 Sep 2022 16:20:57 -0400 Received: from out1.migadu.com (out1.migadu.com [IPv6:2001:41d0:2:863f::]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EB07FA722A; Fri, 16 Sep 2022 13:20:54 -0700 (PDT) Message-ID: DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.dev; s=key1; t=1663359652; h=from:from:reply-to:subject:subject: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=TdFPJ/E73gfYJJ71FfMTa2muu9d+Trfydz6NY8WdwhU=; b=G8MmkhFSmV3qP2EPiZtkTIjy70MCOmQV3emF9RFbLEOlAT0ii1FP9VsV60b0i32ccZ3WFM R8R8wDhxE5MmVK3QAbzkKgZmVwVOvf5vX1rOaCq7y1NE2wVwaNtwdvflhHgHrg8qu0e6sh G4GUqGqKuYiQxGTCvwz/6N5tUgdX1GA= Date: Fri, 16 Sep 2022 13:20:41 -0700 MIME-Version: 1.0 Subject: Re: [PATCH bpf-next] bpf: Move nf_conn extern declarations to filter.h Content-Language: en-US To: Daniel Xu Cc: pablo@netfilter.org, fw@strlen.de, toke@kernel.org, netfilter-devel@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, bpf@vger.kernel.org, ast@kernel.org, daniel@iogearbox.net, andrii@kernel.org, memxor@gmail.com References: X-Report-Abuse: Please report any abuse attempt to abuse@migadu.com and include these headers. From: Martin KaFai Lau In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Migadu-Flow: FLOW_OUT X-Migadu-Auth-User: linux.dev X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW,SPF_HELO_PASS, SPF_PASS autolearn=ham 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 On 9/11/22 11:19 AM, Daniel Xu wrote: > We're seeing the following new warnings on netdev/build_32bit and > netdev/build_allmodconfig_warn CI jobs: > > ../net/core/filter.c:8608:1: warning: symbol > 'nf_conn_btf_access_lock' was not declared. Should it be static? > ../net/core/filter.c:8611:5: warning: symbol 'nfct_bsa' was not > declared. Should it be static? > > Fix by ensuring extern declaration is present while compiling filter.o. > > Signed-off-by: Daniel Xu > --- > include/linux/filter.h | 6 ++++++ > include/net/netfilter/nf_conntrack_bpf.h | 7 +------ > 2 files changed, 7 insertions(+), 6 deletions(-) > > diff --git a/include/linux/filter.h b/include/linux/filter.h > index 527ae1d64e27..96de256b2c8d 100644 > --- a/include/linux/filter.h > +++ b/include/linux/filter.h > @@ -567,6 +567,12 @@ struct sk_filter { > > DECLARE_STATIC_KEY_FALSE(bpf_stats_enabled_key); > > +extern struct mutex nf_conn_btf_access_lock; > +extern int (*nfct_bsa)(struct bpf_verifier_log *log, const struct btf *btf, > + const struct btf_type *t, int off, int size, > + enum bpf_access_type atype, u32 *next_btf_id, > + enum bpf_type_flag *flag); Can it avoid leaking the nfct specific details like 'nf_conn_btf_access_lock' and the null checking on 'nfct_bsa' to filter.c? In particular, this code snippet in filter.c: mutex_lock(&nf_conn_btf_access_lock); if (nfct_bsa) ret = nfct_bsa(log, btf, ....); mutex_unlock(&nf_conn_btf_access_lock); Can the lock and null check be done as one function (eg. nfct_btf_struct_access()) in nf_conntrack_bpf.c and use it in filter.c instead? btw, 'bsa' stands for btf_struct_access? It is a bit too short to guess ;) Also, please add a Fixes tag.