From ed7806879b9fb7bd34a9ec2ae1360760e87d244d Mon Sep 17 00:00:00 2001 From: Konstantin Belousov Date: Sat, 24 Apr 2010 12:49:52 +0000 Subject: [PATCH] Move the constants specifying the size of struct kinfo_proc into machine-specific header files. Add KINFO_PROC32_SIZE for struct kinfo_proc32 for architectures providing COMPAT_FREEBSD32. Add CTASSERT for the size of struct kinfo_proc32. Submitted by: pluknet Reviewed by: imp, jhb, nwhitehorn MFC after: 2 weeks --- sys/amd64/include/proc.h | 3 +++ sys/arm/include/proc.h | 2 ++ sys/i386/include/proc.h | 2 ++ sys/ia64/include/proc.h | 3 +++ sys/kern/kern_proc.c | 3 +++ sys/mips/include/proc.h | 6 ++++++ sys/powerpc/include/proc.h | 2 ++ sys/sparc64/include/proc.h | 2 ++ sys/sun4v/include/proc.h | 2 ++ sys/sys/user.h | 27 ++------------------------- 10 files changed, 27 insertions(+), 25 deletions(-) diff --git a/sys/amd64/include/proc.h b/sys/amd64/include/proc.h index 33d5181d2d53..126412cad45e 100644 --- a/sys/amd64/include/proc.h +++ b/sys/amd64/include/proc.h @@ -53,6 +53,9 @@ struct mdproc { struct system_segment_descriptor md_ldt_sd; }; +#define KINFO_PROC_SIZE 1088 +#define KINFO_PROC32_SIZE 768 + #ifdef _KERNEL /* Get the current kernel thread stack usage. */ diff --git a/sys/arm/include/proc.h b/sys/arm/include/proc.h index c7b2a4ef5c9c..37051bf518b4 100644 --- a/sys/arm/include/proc.h +++ b/sys/arm/include/proc.h @@ -60,4 +60,6 @@ struct mdproc { void *md_sigtramp; }; +#define KINFO_PROC_SIZE 792 + #endif /* !_MACHINE_PROC_H_ */ diff --git a/sys/i386/include/proc.h b/sys/i386/include/proc.h index 1e0b9f9db10a..0b9fca2b55f0 100644 --- a/sys/i386/include/proc.h +++ b/sys/i386/include/proc.h @@ -57,6 +57,8 @@ struct mdproc { struct proc_ldt *md_ldt; /* (t) per-process ldt */ }; +#define KINFO_PROC_SIZE 768 + #ifdef _KERNEL /* Get the current kernel thread stack usage. */ diff --git a/sys/ia64/include/proc.h b/sys/ia64/include/proc.h index 6bf9c78c88b0..81e2e4f7bb8b 100644 --- a/sys/ia64/include/proc.h +++ b/sys/ia64/include/proc.h @@ -38,4 +38,7 @@ struct mdproc { int __dummy; /* Avoid having an empty struct. */ }; +#define KINFO_PROC_SIZE 1088 +#define KINFO_PROC32_SIZE 768 + #endif /* !_MACHINE_PROC_H_ */ diff --git a/sys/kern/kern_proc.c b/sys/kern/kern_proc.c index d4943c09d8f6..5601ecf67cd7 100644 --- a/sys/kern/kern_proc.c +++ b/sys/kern/kern_proc.c @@ -151,6 +151,9 @@ int kstack_pages = KSTACK_PAGES; SYSCTL_INT(_kern, OID_AUTO, kstack_pages, CTLFLAG_RD, &kstack_pages, 0, ""); CTASSERT(sizeof(struct kinfo_proc) == KINFO_PROC_SIZE); +#ifdef COMPAT_FREEBSD32 +CTASSERT(sizeof(struct kinfo_proc32) == KINFO_PROC32_SIZE); +#endif /* * Initialize global process hashing structures. diff --git a/sys/mips/include/proc.h b/sys/mips/include/proc.h index 0491b11b02e7..1479edab2933 100644 --- a/sys/mips/include/proc.h +++ b/sys/mips/include/proc.h @@ -68,4 +68,10 @@ struct thread; void mips_cpu_switch(struct thread *, struct thread *, struct mtx *); void mips_cpu_throw(struct thread *, struct thread *); +#ifdef __mips_n64 +#define KINFO_PROC_SIZE 1088 +#else +#define KINFO_PROC_SIZE 816 +#endif + #endif /* !_MACHINE_PROC_H_ */ diff --git a/sys/powerpc/include/proc.h b/sys/powerpc/include/proc.h index c958fb76f0fb..cbe6da9ff23f 100644 --- a/sys/powerpc/include/proc.h +++ b/sys/powerpc/include/proc.h @@ -46,4 +46,6 @@ struct mdthread { struct mdproc { }; +#define KINFO_PROC_SIZE 768 + #endif /* !_MACHINE_PROC_H_ */ diff --git a/sys/sparc64/include/proc.h b/sys/sparc64/include/proc.h index bfd1268e433c..84eaed5a00ed 100644 --- a/sys/sparc64/include/proc.h +++ b/sys/sparc64/include/proc.h @@ -51,4 +51,6 @@ struct mdproc { void *md_sigtramp; }; +#define KINFO_PROC_SIZE 1088 + #endif /* !_MACHINE_PROC_H_ */ diff --git a/sys/sun4v/include/proc.h b/sys/sun4v/include/proc.h index bfd1268e433c..84eaed5a00ed 100644 --- a/sys/sun4v/include/proc.h +++ b/sys/sun4v/include/proc.h @@ -51,4 +51,6 @@ struct mdproc { void *md_sigtramp; }; +#define KINFO_PROC_SIZE 1088 + #endif /* !_MACHINE_PROC_H_ */ diff --git a/sys/sys/user.h b/sys/sys/user.h index d5e46feb58fd..34635e3dc18f 100644 --- a/sys/sys/user.h +++ b/sys/sys/user.h @@ -87,34 +87,11 @@ #define KI_NSPARE_LONG 12 #define KI_NSPARE_PTR 7 -#ifdef __amd64__ -#define KINFO_PROC_SIZE 1088 -#endif -#ifdef __arm__ -#define KINFO_PROC_SIZE 792 -#endif -#ifdef __ia64__ -#define KINFO_PROC_SIZE 1088 -#endif -#ifdef __i386__ -#define KINFO_PROC_SIZE 768 -#endif -#ifdef __mips__ -#ifdef __mips_n64 -#define KINFO_PROC_SIZE 1088 -#else -#define KINFO_PROC_SIZE 816 -#endif -#endif -#ifdef __powerpc__ -#define KINFO_PROC_SIZE 768 -#endif -#ifdef __sparc64__ -#define KINFO_PROC_SIZE 1088 -#endif +#ifndef _KERNEL #ifndef KINFO_PROC_SIZE #error "Unknown architecture" #endif +#endif /* !_KERNEL */ #define WMESGLEN 8 /* size of returned wchan message */ #define LOCKNAMELEN 8 /* size of returned lock name */