mirror of
https://git.hardenedbsd.org/hardenedbsd/HardenedBSD.git
synced 2025-01-01 00:18:15 +01:00
Export 'struct pcpu' to userland w/o requiring _KERNEL. A few ports
already define _KERNEL to get to this and I'm about to add hooks to libkvm to access per-CPU data. MFC after: 1 week
This commit is contained in:
parent
e5bfdc768a
commit
70d12a18f2
@ -33,8 +33,6 @@
|
||||
#error "sys/cdefs.h is a prerequisite for this file"
|
||||
#endif
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
/*
|
||||
* The SMP parts are setup in pmap.c and locore.s for the BSP, and
|
||||
* mp_machdep.c sets up the data for the AP's to "see" when they awake.
|
||||
@ -52,6 +50,8 @@
|
||||
u_int pc_apic_id; \
|
||||
u_int pc_acpi_id /* ACPI CPU id */
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#ifdef lint
|
||||
|
||||
extern struct pcpu *pcpup;
|
||||
|
@ -38,6 +38,8 @@
|
||||
|
||||
struct vmspace;
|
||||
|
||||
#endif /* _KERNEL */
|
||||
|
||||
/*
|
||||
* Inside the kernel, the globally reserved register g7 is used to
|
||||
* point at the globaldata structure.
|
||||
@ -45,6 +47,8 @@ struct vmspace;
|
||||
#define PCPU_MD_FIELDS \
|
||||
struct pcup *pc_prvspace;
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
struct pcb;
|
||||
struct pcpu;
|
||||
|
||||
|
@ -33,8 +33,6 @@
|
||||
#error "sys/cdefs.h is a prerequisite for this file"
|
||||
#endif
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#include <machine/segments.h>
|
||||
#include <machine/tss.h>
|
||||
|
||||
@ -82,6 +80,9 @@
|
||||
int pc_private_tss /* Flag indicating private tss */
|
||||
|
||||
#endif
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#ifdef lint
|
||||
|
||||
extern struct pcpu *pcpup;
|
||||
|
@ -30,8 +30,6 @@
|
||||
#ifndef _MACHINE_PCPU_H_
|
||||
#define _MACHINE_PCPU_H_
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#include <machine/pcb.h>
|
||||
|
||||
#define PCPU_MD_FIELDS \
|
||||
@ -43,6 +41,8 @@
|
||||
uint32_t pc_awake:1; /* CPU is awake? */ \
|
||||
uint32_t pc_acpi_id /* ACPI CPU id. */
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
struct pcpu;
|
||||
|
||||
register struct pcpu *pcpup __asm__("r13");
|
||||
|
@ -31,9 +31,8 @@
|
||||
#ifndef _MACHINE_PCPU_H_
|
||||
#define _MACHINE_PCPU_H_
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#include <machine/pte.h>
|
||||
|
||||
#define PCPU_MD_FIELDS \
|
||||
pd_entry_t *pc_segbase; /* curthread segbase */ \
|
||||
struct pmap *pc_curpmap; /* pmap of curthread */ \
|
||||
@ -42,6 +41,8 @@
|
||||
u_int pc_pending_ipis; /* the IPIs pending to this CPU */ \
|
||||
void *pc_boot_stack;
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#ifdef SMP
|
||||
static __inline struct pcpu*
|
||||
get_pcpup(void)
|
||||
|
@ -30,7 +30,6 @@
|
||||
#ifndef _MACHINE_PCPU_H_
|
||||
#define _MACHINE_PCPU_H_
|
||||
|
||||
#ifdef _KERNEL
|
||||
#include <machine/cpufunc.h>
|
||||
|
||||
struct pmap;
|
||||
@ -117,6 +116,8 @@ struct pmap;
|
||||
int pc_md_placeholder
|
||||
#endif
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#define pcpup ((struct pcpu *) powerpc_get_pcpup())
|
||||
|
||||
#define PCPU_GET(member) (pcpup->pc_ ## member)
|
||||
|
@ -30,8 +30,6 @@
|
||||
#ifndef _MACHINE_PCPU_H_
|
||||
#define _MACHINE_PCPU_H_
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#include <machine/asmacros.h>
|
||||
#include <machine/frame.h>
|
||||
#include <machine/intr_machdep.h>
|
||||
@ -59,6 +57,8 @@ struct pmap;
|
||||
u_int pc_tlb_ctx_max; \
|
||||
u_int pc_tlb_ctx_min
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
struct pcb;
|
||||
struct pcpu;
|
||||
|
||||
|
@ -30,8 +30,6 @@
|
||||
#ifndef _MACHINE_PCPU_H_
|
||||
#define _MACHINE_PCPU_H_
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
#include <machine/asmacros.h>
|
||||
#include <machine/frame.h>
|
||||
#include <machine/intr_machdep.h>
|
||||
@ -82,6 +80,9 @@ struct pmap;
|
||||
* be L2 cache aligned - they're surrounded by per-cpu data, so there is
|
||||
* no possibility of false sharing, but this might help in reducing misses
|
||||
*/
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
struct pcpu;
|
||||
|
||||
register struct pcpu *pcpup __asm__(__XSTRING(PCPU_REG));
|
||||
|
@ -33,10 +33,6 @@
|
||||
#ifndef _SYS_PCPU_H_
|
||||
#define _SYS_PCPU_H_
|
||||
|
||||
#ifndef _KERNEL
|
||||
#error "no user-serviceable parts inside"
|
||||
#endif
|
||||
|
||||
#ifdef LOCORE
|
||||
#error "no assembler-serviceable parts inside"
|
||||
#endif
|
||||
@ -106,6 +102,8 @@ struct pcpu {
|
||||
PCPU_MD_FIELDS;
|
||||
};
|
||||
|
||||
#ifdef _KERNEL
|
||||
|
||||
SLIST_HEAD(cpuhead, pcpu);
|
||||
|
||||
extern struct cpuhead cpuhead;
|
||||
@ -133,4 +131,6 @@ void pcpu_destroy(struct pcpu *pcpu);
|
||||
struct pcpu *pcpu_find(u_int cpuid);
|
||||
void pcpu_init(struct pcpu *pcpu, int cpuid, size_t size);
|
||||
|
||||
#endif /* _KERNEL */
|
||||
|
||||
#endif /* !_SYS_PCPU_H_ */
|
||||
|
@ -143,6 +143,7 @@ typedef __clockid_t clockid_t;
|
||||
#define _CLOCKID_T_DECLARED
|
||||
#endif
|
||||
|
||||
typedef __cpumask_t cpumask_t;
|
||||
typedef __critical_t critical_t; /* Critical section value */
|
||||
typedef __int64_t daddr_t; /* disk address */
|
||||
|
||||
@ -278,7 +279,6 @@ typedef __vm_size_t vm_size_t;
|
||||
|
||||
#ifdef _KERNEL
|
||||
typedef int boolean_t;
|
||||
typedef __cpumask_t cpumask_t;
|
||||
typedef struct device *device_t;
|
||||
typedef __intfptr_t intfptr_t;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user