Re: [RFC: 2.6 patch] don't export linux/nfsd/stats.h to userspace
From: J. Bruce Fields
Date: Mon Jun 23 2008 - 16:27:52 EST
On Mon, Jun 23, 2008 at 08:48:54PM +0300, Adrian Bunk wrote:
> The main contents is struct nfsd_stats which changes depending on a
> CONFIG_ variable.
>
> This would not work in userspace.
Makes sense, but could we just get this out of include/linux entirely,
and into fs/nfsd/?
$ git grep -l '^#include <linux/nfsd/stats.h>'
fs/nfsd/nfssvc.c
fs/nfsd/stats.c
include/linux/nfsd/nfsd.h
So the only user outside of fs/nfsd/ is nfsd.h. I doubt it really needs
it. And nfsd.h is included a lot of places it needn't be too:
$ git grep -l '^#include <linux/nfsd/nfsd.h>'
arch/parisc/kernel/sys_parisc32.c
arch/s390/kernel/compat_linux.c
arch/s390/kernel/compat_linux.h
arch/sparc64/kernel/sys_sparc32.c
Those includes are unnecessary.
fs/compat.c
That too, I think.
fs/lockd/svc4proc.c
fs/lockd/svcproc.c
Those might need it (though they shouldn't also need stats.h). Etc.
fs/nfsctl.c
fs/nfsd/auth.c
fs/nfsd/export.c
fs/nfsd/lockd.c
fs/nfsd/nfs2acl.c
fs/nfsd/nfs3acl.c
fs/nfsd/nfs3proc.c
fs/nfsd/nfs3xdr.c
fs/nfsd/nfs4callback.c
fs/nfsd/nfs4proc.c
fs/nfsd/nfs4recover.c
fs/nfsd/nfs4state.c
fs/nfsd/nfs4xdr.c
fs/nfsd/nfscache.c
fs/nfsd/nfsctl.c
fs/nfsd/nfsfh.c
fs/nfsd/nfsproc.c
fs/nfsd/nfssvc.c
fs/nfsd/nfsxdr.c
fs/nfsd/stats.c
fs/nfsd/vfs.c
--b.
>
> Signed-off-by: Adrian Bunk <bunk@xxxxxxxxxx>
>
> ---
>
> include/linux/nfsd/Kbuild | 1 -
> include/linux/nfsd/stats.h | 3 ---
> 2 files changed, 4 deletions(-)
>
> 9b6014db4d4182cf4cb342b97f9018c5d1090afa diff --git a/include/linux/nfsd/Kbuild b/include/linux/nfsd/Kbuild
> index fc97204..698e9ec 100644
> --- a/include/linux/nfsd/Kbuild
> +++ b/include/linux/nfsd/Kbuild
> @@ -2,5 +2,4 @@ unifdef-y += const.h
> unifdef-y += debug.h
> unifdef-y += export.h
> unifdef-y += nfsfh.h
> -unifdef-y += stats.h
> unifdef-y += syscall.h
> diff --git a/include/linux/nfsd/stats.h b/include/linux/nfsd/stats.h
> index 7678cfb..d949590 100644
> --- a/include/linux/nfsd/stats.h
> +++ b/include/linux/nfsd/stats.h
> @@ -38,13 +38,10 @@ struct nfsd_stats {
> /* thread usage wraps very million seconds (approx one fortnight) */
> #define NFSD_USAGE_WRAP (HZ*1000000)
>
> -#ifdef __KERNEL__
> -
> extern struct nfsd_stats nfsdstats;
> extern struct svc_stat nfsd_svcstats;
>
> void nfsd_stat_init(void);
> void nfsd_stat_shutdown(void);
>
> -#endif /* __KERNEL__ */
> #endif /* LINUX_NFSD_STATS_H */
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/