Received: by 10.213.65.68 with SMTP id h4csp499019imn; Tue, 27 Mar 2018 03:35:19 -0700 (PDT) X-Google-Smtp-Source: AIpwx49wNzwBs1w0bym6FB9B2Hn2vrlbw4K7t7NX8sZoTHKyrJQ1ivgnBmpLOgKPE2tskCili3wN X-Received: by 2002:a17:902:b086:: with SMTP id p6-v6mr539381plr.392.1522146919153; Tue, 27 Mar 2018 03:35:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522146919; cv=none; d=google.com; s=arc-20160816; b=WCpFIA2g9z8/sXqy7QONqJvNQ5hygQY8gITaRTOJM2iG1CiQRZdXLhKRLEW3elWbwl hfSywVBBL4w/cMsL8ETRbUa2DYtDeGPadCdNrZnpGX9eUi35ioNBX0p4ZBQ2jDNW+y59 aw4lrSK0enM5I/XRFL69z1EIe9BvN1edSiUT377vLp367X2oGFuDGi9eb3YZofK3VxD3 V+GIsryd/3VUDbopODF/KQGa+ow9ehxmX5FcYm8ITbNMV6irgBiyJIp3GFdR2BHZX+LX sD9yzoxqYK5KQyOcCK9pYjafLl67wkGEwfF9mrjZPIPtYqlGlZVfuyqG6Tm6TdEYFXCu iCWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=WRKQyEL/FF3LruxmuhDa7JOvFDTUejPDsh9vDJ0yeJs=; b=Tpu8QttPnGHMg31NWrAuylVjxQJ2vIptkHq4HJ3Dwy21ph9jrJk6DESw6jr+KxkfF2 7WmFfr2/TageQqDEpS9oZwUE9IEdYbQmFIJvXf8qkIPehsZCenATFBWOrcaYoWyt4whz b5z3GFkeBINxAkOiDlgg8KorViTtEbKZbIqRavFpPuqrJHJICZE78t8v+Q1Q/5+gPXBQ zYroq8MmHOS8G6igieZTcAJ2H4SX2Qu5Ioz/U9awtl5LsuUlofnKBMRP6I+YKo+bw0iL Mx5udwqja8jmpRPj2NTc+0sx21cOtNfo97KHPhK9xfMbTMB2Sq8h2Oirc/zpVkcZS9/J chWA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w16-v6si945425plp.621.2018.03.27.03.35.05; Tue, 27 Mar 2018 03:35:19 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752590AbeC0K2a (ORCPT + 99 others); Tue, 27 Mar 2018 06:28:30 -0400 Received: from mga01.intel.com ([192.55.52.88]:60708 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752004AbeC0K22 (ORCPT ); Tue, 27 Mar 2018 06:28:28 -0400 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from fmsmga005.fm.intel.com ([10.253.24.32]) by fmsmga101.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 27 Mar 2018 03:28:26 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.48,367,1517904000"; d="scan'208";a="215235085" Received: from gvt-dell.bj.intel.com (HELO intel.com) ([10.238.154.59]) by fmsmga005.fm.intel.com with SMTP; 27 Mar 2018 03:28:25 -0700 Date: Tue, 27 Mar 2018 18:19:02 +0800 From: "Du, Changbin" To: Daniel Borkmann Cc: "Du, Changbin" , Alexei Starovoitov , shuah@kernel.org, linux-kselftest@vger.kernel.org, linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: Re: [PATCH 4/4] selftests/bpf: fix compiling errors Message-ID: <20180327101902.syypntlrlmgk326j@intel.com> References: <1522056208-4004-1-git-send-email-changbin.du@intel.com> <1522056208-4004-5-git-send-email-changbin.du@intel.com> <20180326145511.lzoi6wja6iht5lvq@ast-mbp.dhcp.thefacebook.com> <20180327022010.57u6rn73inbkrycn@intel.com> <20180327030229.txifuth2qmnjo3hy@ast-mbp> <20180327030613.hkp7hox3g4prnbsg@intel.com> <2dd7c04a-eb10-e730-148e-3b04a18e9b44@iogearbox.net> <20180327090000.fou6oyvr663lbyuq@intel.com> <90ce8146-cecd-c928-f9c6-470db97b2051@iogearbox.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <90ce8146-cecd-c928-f9c6-470db97b2051@iogearbox.net> User-Agent: NeoMutt/20180323-6-5ca392 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 27, 2018 at 11:52:27AM +0200, Daniel Borkmann wrote: > On 03/27/2018 11:00 AM, Du, Changbin wrote: > > On Tue, Mar 27, 2018 at 10:52:57AM +0200, Daniel Borkmann wrote: > >> On 03/27/2018 05:06 AM, Du, Changbin wrote: > >>> On Mon, Mar 26, 2018 at 08:02:30PM -0700, Alexei Starovoitov wrote: > >>>> On Tue, Mar 27, 2018 at 10:20:10AM +0800, Du, Changbin wrote: > >>>>> On Mon, Mar 26, 2018 at 07:55:13AM -0700, Alexei Starovoitov wrote: > >>>>>> On Mon, Mar 26, 2018 at 05:23:28PM +0800, changbin.du@intel.com wrote: > >>>>>>> Signed-off-by: Changbin Du > >>>>>>> --- > >>>>>>> tools/testing/selftests/bpf/Makefile | 5 +++-- > >>>>>>> 1 file changed, 3 insertions(+), 2 deletions(-) > >>>>>>> > >>>>>>> diff --git a/tools/testing/selftests/bpf/Makefile b/tools/testing/selftests/bpf/Makefile > >>>>>>> index 5c43c18..dc0fdc8 100644 > >>>>>>> --- a/tools/testing/selftests/bpf/Makefile > >>>>>>> +++ b/tools/testing/selftests/bpf/Makefile > >>>>>>> @@ -10,7 +10,8 @@ ifneq ($(wildcard $(GENHDR)),) > >>>>>>> GENFLAGS := -DHAVE_GENHDR > >>>>>>> endif > >>>>>>> > >>>>>>> -CFLAGS += -Wall -O2 -I$(APIDIR) -I$(LIBDIR) -I$(GENDIR) $(GENFLAGS) -I../../../include > >>>>>>> +CFLAGS += -Wall -O2 -I$(APIDIR) -I$(LIBDIR) -I$(GENDIR) $(GENFLAGS) \ > >>>>>>> + -I../../../include -I../../../../usr/include > >>>>>>> LDLIBS += -lcap -lelf -lrt -lpthread > >>>>>>> > >>>>>>> # Order correspond to 'make run_tests' order > >>>>>>> @@ -62,7 +63,7 @@ else > >>>>>>> CPU ?= generic > >>>>>>> endif > >>>>>>> > >>>>>>> -CLANG_FLAGS = -I. -I./include/uapi -I../../../include/uapi \ > >>>>>>> +CLANG_FLAGS = -I. -I./include/uapi -I../../../include/uapi -I../../../../usr/include \ > >>>>>>> -Wno-compare-distinct-pointer-types > >>>>>> > >>>>>> Nack. > >>>>>> I suspect that will break the build for everyone else who's doing it in the directory > >>>>>> itself instead of the outer one. > >>>>> > >>>>> This one? But I didn't see any problem. > >>>> > >>>> because the build was lucky and additional path ../../../../usr/include didn't point > >>>> to a valid dir? > >> > >> Agree. > >> > >>> I am sorry but I don't understand why you mean *lucky*. Of cause, the path is valid. > >> > >> The problem is that this suddenly requires users to do a 'make headers_install' in > >> order to populate usr/include/ directory in the first place. While it's annoying > >> enough for BPF samples where this is needed, I absolutely don't want to introduce > >> this for BPF kselftests. It's the wrong approach. Besides, in tools infra, there is > >> a tools/arch/*/include/uapi/asm/bitsperlong.h header copy already, so we really need > >> to use that instead. Please adapt your patch accordingly and respin. Please also Cc > >> us and netdev@vger.kernel.org for BPF kselftests changes. > >> > > Thanks for the explanation. So we expect that tools/arch/*/include is in the searching list, right? > > The corrent makefile seems not. How do you get this built? > > E.g. take a look at tools/include/asm/barrier.h or tools/include/uapi/asm/bpf_perf_event.h > just to name two examples. We'd need something similar to this which then points to the > arch specific includes. > > Thanks, > Daniel > ok, I see. But I am going to skip this fix this time. Because one get fixed, another appears. IMHO, It doesn't sound like a good idea to sync all these files manually. We should have better solution I think. clang -I. -I./include/uapi -I../../../include/uapi -Wno-compare-distinct-pointer-types \ -O2 -target bpf -emit-llvm -c test_pkt_access.c -o - | \ llc -march=bpf -mcpu=generic -filetype=obj -o /home/changbin/work/linux/tools/testing/selftests/bpf/test_pkt_access.o In file included from test_pkt_access.c:12: /usr/include/linux/ip.h:20:10: fatal error: 'asm/byteorder.h' file not found #include > > changbin@gvt-dell-host:~/work/linux/tools/testing/selftests/bpf$ make -p > > [...] > > clang -I. -I./include/uapi -I../../../include/uapi -Wno-compare-distinct-pointer-types \ > > -O2 -target bpf -emit-llvm -c test_pkt_access.c -o - | \ > > llc -march=bpf -mcpu=generic -filetype=obj -o /home/changbin/work/linux/tools/testing/selftests/bpf/test_pkt_access.o > > In file included from test_pkt_access.c:9: > > In file included from ../../../include/uapi/linux/bpf.h:11: > > In file included from ./include/uapi/linux/types.h:5: > > /usr/include/asm-generic/int-ll64.h:11:10: fatal error: 'asm/bitsperlong.h' file not found > > #include > > > > > -- Thanks, Changbin Du