lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.LFD.1.00.0803260846390.6148@localhost.localdomain>
Date:	Wed, 26 Mar 2008 08:53:35 -0400 (EDT)
From:	"Robert P. J. Day" <rpjday@...shcourse.ca>
To:	David Woodhouse <dwmw2@...radead.org>
cc:	Linux Kernel Mailing List <linux-kernel@...r.kernel.org>
Subject: Re: why so many unexported headers checking __KERNEL__?

On Wed, 26 Mar 2008, David Woodhouse wrote:

> On Sun, 2008-03-23 at 02:31 -0400, Robert P. J. Day wrote:
> >
> >   as an unintended side effect of checking for proper exporting to
> > user space and unifdef'ing, i noticed that there are literally
> > hundreds of kernel header files that check the value of __KERNEL__
> > in some way, but are never exported to user space.  what's the
> > point of that?  thanks.
>
> There's no point -- we just haven't got round to removing it yet.
>
> We should probably make headers_check or some other automated check
> catch these two cases:
>
> If a header is exported by header-y or not exported at all, it shouldn't
> contain any #ifdef __KERNEL__.
>
> And if it's exported and doesn't contain any #ifdef __KERNEL__, it
> should be header-y not unifdef-y (and that's the case we should be
> moving towards, by cleaning up headers to have separate files for
> the user-visible parts).

not surprisingly, the only reason i noticed the above was because i
hacked together a short script that went looking for all of the above
and i was surprised at the number of files it identified.  (i've
already submitted a few patches to clean up the obviously erroneous
cases, like being miscategorized or being in both categories at once
so, after the next merge window, those should all be gone.)

rday

p.s. the other case that could be identified is when a header file has
its *entire* contents encased in a __KERNEL__ test, (either ifdef or
ifndef).  AFAICT, unless that kind of test is partitioning *some* of a
header file content from the remainder, there's little value in a
__KERNEL__test if the end result is to either:

  a) leave the file exactly as is, or
  b) reduce it to empty

--

========================================================================
Robert P. J. Day
Linux Consulting, Training and Annoying Kernel Pedantry:
    Have classroom, will lecture.

http://crashcourse.ca                          Waterloo, Ontario, CANADA
========================================================================
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ