Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp5268932ybi; Tue, 28 May 2019 10:09:10 -0700 (PDT) X-Google-Smtp-Source: APXvYqzch8fmkOekQeJCMY5LxBoFLqdLgm2aD64yoRuCIYJfZur7RDZeWgzKhY4mQrm9Mo6urL0S X-Received: by 2002:a17:902:4181:: with SMTP id f1mr112468332pld.22.1559063350893; Tue, 28 May 2019 10:09:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559063350; cv=none; d=google.com; s=arc-20160816; b=rjw2dcKy50+KowzWLYAmKp+Yt1X61mX1fOiTQWvaZY1vx+KqT/Wf2RcWAlALipjjl1 Zv5mCGUwTQsgJROJyoPm8wLMs4W54akHmvrJ8dDgi8OpA5tj9/SHWfXRuvZwklc/H+iN Nh9NrMvF9Xskz4fvSVaWI9+1U5HRt55tD4WuZwxvCcIWQNuccpZr5wOZGMFnJA7Zo39Z HFA3Jp+by/ccjB1Tqv4eW7YpoRSqtLy9ici0jP3wVkIE9iQFNmwgMNp4p9jBymp7BG+8 DI7/gt9mB0iVBLqur08e2dFK1YSZ5qsb/+PbHvmSrww1qsBwZMD7tDsFqJ3Oe5r5cZ07 TGFQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=F4LExrLHPInWopmRm5L/V+gNTgVfAKuBU1wg80ulrPM=; b=PBhvVkg2gr0VDQVd5084MMkrgub79f8T6riSHFwIEnTk48HsrWehzdfTY6WzqZg9+M mirRG/vim6fTHFgc60NsoTphihwVncJ39qihL15TAq+PqFxGCmEMps42zOCYUUZvgSyp 7Ks+1OMxJRj1dRgJcKTWt068XPl9ndtA4aZOcMU072bYs7lO1tBT3teVMxkqzCqWx71a ZC/vzRqfioprCwFlEA0vzHdSoyFuzqLX99rJB6/G1KuZXi+4Mn+TPbc7v3weh9aT/a5P RCH2muPyr45YHHuKqjJTo7+s/XekWzN0Is7LsuQo4HSsKRgMyAHYqRaWubpRd6Ku7bYd YGsw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=Hj9Nn0Jo; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n6si4241827pjp.62.2019.05.28.10.08.54; Tue, 28 May 2019 10:09:10 -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; dkim=pass header.i=@google.com header.s=20161025 header.b=Hj9Nn0Jo; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727344AbfE1RGU (ORCPT + 99 others); Tue, 28 May 2019 13:06:20 -0400 Received: from mail-pf1-f196.google.com ([209.85.210.196]:33863 "EHLO mail-pf1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726515AbfE1RGU (ORCPT ); Tue, 28 May 2019 13:06:20 -0400 Received: by mail-pf1-f196.google.com with SMTP id n19so11882465pfa.1 for ; Tue, 28 May 2019 10:06:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=F4LExrLHPInWopmRm5L/V+gNTgVfAKuBU1wg80ulrPM=; b=Hj9Nn0Joe+/+t2CpRFn4XbObe6fCInyzXXFdZiZv/yrwtn+RfPO1A/CiDBZ8PjcqWB /oabD67I2tJfLp/hQWgFYJaupSCl0di0qa3IYEM+HuyuHnFYM4+SbDNSl+91nT2ZS4uI Gma+LtXjoStU47d8raIMU1YlHGrTPSN7EeDce7+NI1US7b8YmnyTBGrysM3lPUitwQ3m kCG9o33TmDK21534wE3tlnWdkLtPFcrXHkut8z65cdHu/1RxL0jxWFcN/PDnMyq2qExS Sbl3U4p7DmffcFnB0bEUwss3CLUM5M9M+svovu+nRAPFjwIK9NULdOTgufHcPivQq+tI JwhA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=F4LExrLHPInWopmRm5L/V+gNTgVfAKuBU1wg80ulrPM=; b=Uz/8Nu1tbU0gsJoQ9lefIL79r7hqAz9dxTPFt5U2j5cV/GscsmpMaRnQQiee2apGoj /ZN73/aQHudxhEyMWks/X8rkc+JkccU1BuU6LdWmFmTaHoWCTidPmeea/jAU3Sc/eMTa zNTnDneAP5d+4PJuNweYwcayggYanHSsC+sfmukhjvQM+ApAc42Wr/Y+aRSV5F+PWW0E PWhMDkEM2AWUJKmSQRoR1SVrZ1il5fsw4+8uSjy/gI2nWzhZnciobjGp1VCrIMnmbueH zWqOvt3XpOcnmxoVgwN6VvGJHK5YWmJXnz74rGiXXE/AvzMkEZ7jAsSTHkVZf9SwPhCm mA6A== X-Gm-Message-State: APjAAAVOkmOZ/hg6Koo8ClM+Y9lJYQGv/hIxdHmshYlobRCDHvoE9Rzn iYw2uuq4X2kVuXAWaMBWk8nwQg== X-Received: by 2002:a17:90a:4fa6:: with SMTP id q35mr7274194pjh.74.1559063178470; Tue, 28 May 2019 10:06:18 -0700 (PDT) Received: from jchowdhary0.mtv.corp.google.com ([2620:0:1000:1612:e11d:1467:a8a:6428]) by smtp.gmail.com with ESMTPSA id d85sm17553492pfd.94.2019.05.28.10.06.15 (version=TLS1_3 cipher=AEAD-AES128-GCM-SHA256 bits=128/128); Tue, 28 May 2019 10:06:16 -0700 (PDT) Subject: Re: uapi headers userspace build results To: Randy Dunlap , LKML Cc: linux-kbuild , Andrew Morton , kernel-team@android.com, trong@google.com, maennich@google.com References: <8b90457a-5b1d-818c-d2d6-ba3d16ad3eaf@infradead.org> <1ef3a7b9-5172-9f7a-01fa-4866e765fbbe@google.com> <8a36d3ba-977b-49ca-c431-90ef53071f88@google.com> <9b76d1b6-08a4-36cf-4fc8-661b216ca433@infradead.org> From: Jayant Chowdhary Message-ID: <40fd548e-11ff-077c-6bdb-093cd2910e6e@google.com> Date: Tue, 28 May 2019 10:06:14 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Randy, Apologies for not keeping everyone up to date on this. A couple of colleagues (cc'ed): Tri and Matthias, are going to be taking over this work. Thanks, Jayant On 5/27/19 3:12 PM, Randy Dunlap wrote: > Hi Jayant, > > What ever happened to this script and subsequent patches? > > thanks. > > On 6/19/18 11:17 AM, Randy Dunlap wrote: >> On 06/18/2018 06:47 PM, Jayant Chowdhary wrote: >>> Hi Randy, >>> >>> On 06/12/2018 05:07 PM, Randy Dunlap wrote: >>>> On 06/12/2018 01:39 PM, Jayant Chowdhary wrote: >>>>> Hi Randy, >>>>> >>>>> On 06/11/2018 10:49 PM, Randy Dunlap wrote: >>>>>> Hi, >>>>>> >>>>>> Here is what I have so far. It begins with a makefile and some >>>>>> template files that are added to. There's a good bit of Perl also. >>>>>> >>>>>> I put all of these files in tools/uapi/ and run them from there. >>>>>> >>>>>> There is one .c file generated for each .h file in builddir/usr/include >>>>>> (O=builddir). >>>>>> >>>>> >>>>> Thanks for this! I wrote a small Makefile (uapi-compile.mk) which I'd put in >>>>> tools/build (I can change this to tools/uapi, if that is more apt). >>>> >>>> Your makefile foo is much better than mine is. >>>> Yes, I think that it deserves to be in its own sub-directory. >>>> >>>>> uapi-compile.mk straight-away compiles the uapi headers, without pulling them >>>>> into any generated c source files. It may also be invoked with an environment >>>> >>>> Hm, I didn't even know that is possible. >>>> >>>>> variable 'UAPI_DIR' specifying the directory, for which the user would like to >>>>> compile headers. This way we can test a directory at a time as well. In your >>>> >>>> Yes, good, I was planning to make a way to restrict the build to certain sub-dirs. >>>> >>>>> opinion, would this be simpler to have rather than having to auto-generate c >>>>> source files including each uapi header and also autog-enerating the make >>>>> targets? I feel like this approach would make maintaining these makefiles/ >>>>> scripts easier as well. >>>> >>>> Sure, this is much better than my scripts. >>>> >>>>>> Out of 889 header files, I see 45 errors. That is better than I expected. >>>>>> >>>>>> The makefiles and scripts are attached (tar), as well as the output (I used >>>>>> 'make -ik' so that make would keep going after errors and attempt to build >>>>>> all target files). >>>>>> >>>>>> have fun! >>>>>> >>>>> >>>>> I did a 'make ARCH=arm64 headers_install' from the kernel source's root, and >>>>> then a 'make -kf uapi-compile.mk all > build.log 2>&1' to compile all the >>>>> headers. Out of 864 headers, I see 20 compilation failures. >>>>> >>>>> I'm attaching uapi-compile.mk and the build.log file along. >>>> >>>> I have some usage comments. >>>> >>>> Since I ran 'make ARCH=x86_64 O=xx64 headers_install', I had to modify >>>> uapi-compile.mk to use that SRC_DIR: >>>> >>>> SRC_DIR :=../../xx64 >>>> >>>> Also, I first tried to make BDIR as a sub-directory of tools/uapi/ and >>>> uapi-compile.mk did not work (when using BDIR=BDIR). >>>> Then I did 'mkdir ../../xx64/BDIR' and specified BDIR=../../xx64/BDIR and >>>> that worked. But: that sub-dir is not used: >>>> >>>> gcc -I../../xx64/usr/include/ --include=../../xx64/usr/include/linux/posix_types.h --include=../../xx64/usr/include/asm-generic/ipcbuf.h --include=stdarg.h --include=stdint.h --include=stddef.h -c ../../xx64/usr/include//linux/caif/caif_socket.h -o ../../xx64/BDIR/../../xx64/usr/include//linux/caif/caif_socket.o >>>> [see the next comment] >>>> >>>> Oh, this makefile builds the .o files in the same sub-dirs as their >>>> respective .h files. I don't especially like that, but as long as >>>> make clean works, it will do. [and make clean does work] >>>> >>> >>> Thanks for these comments. I'll take care of them in my patch-set. I've got a >>> couple of questions for you. Since most of the errors were found in the >>> include/uapi/linux directory, I tried investigating why. >> >> Please also repost your latest patch-set. >> >>> 1) I found that multiple headers depend on the definition of types such as >>> pid_t, which have no definition in the set of uapi headers. There is a >>> definition (of pid_t) in include/linux/types.h, and I thought we could try >>> exposing that in the set of uapi headers. One problem I can see with that is >>> that the header has some definitions which depend on kernel configs: eg: >>> CONFIG_ARCH_DMA_ADDR_T_64BIT. Since user-land programs shouldn't really assume >>> kernel configs, I was thinking we should re-factor this header so that >>> appropriate parts can be exposed to user-land. >> >> Sure, that's worth a try. Mostly on a case-by-case basis. >> >> I see that (at least in the distro that I am using) >> /usr/include/asm-generic/posix_types.h has a typedef for __kernel_pid_t. >> I wonder if that could be co-opted, but I expect that this would have >> type/size issues. >> >> OTOH, 'man getpid' uses pid_t and refers to and , >> so there should already be a pid_t for userspace. Just #include more >> headers files. :) >> >>> 2) Some headers try to expose information which should probably not be exposed >>> to user-land. eg: wait_queue_head in linux/coda_psdev.h (this header should >>> probably be removed altogether ?) >> >> I suppose that header file describes a kernel-to-userspace ("Venus") interface, >> so maybe not removed altogether. But the wait_queue_head_t part of it should >> just be some padding/reserved field (of what size/type?). >> >> >>> Do you have better ideas ? >> >> slow and steady. >> > >