xref: /titanic_41/usr/src/uts/i86pc/sys/comm_page.h (revision dd7afb26c5036958cddc0c2c1e499571664a6ed0)
1*dd7afb26SPatrick Mooney /*
2*dd7afb26SPatrick Mooney  * This file and its contents are supplied under the terms of the
3*dd7afb26SPatrick Mooney  * Common Development and Distribution License ("CDDL"), version 1.0.
4*dd7afb26SPatrick Mooney  * You may only use this file in accordance with the terms of version
5*dd7afb26SPatrick Mooney  * 1.0 of the CDDL.
6*dd7afb26SPatrick Mooney  *
7*dd7afb26SPatrick Mooney  * A full copy of the text of the CDDL should have accompanied this
8*dd7afb26SPatrick Mooney  * source.  A copy of the CDDL is also available via the Internet at
9*dd7afb26SPatrick Mooney  * http://www.illumos.org/license/CDDL.
10*dd7afb26SPatrick Mooney  */
11*dd7afb26SPatrick Mooney 
12*dd7afb26SPatrick Mooney /*
13*dd7afb26SPatrick Mooney  * Copyright 2016 Joyent, Inc.
14*dd7afb26SPatrick Mooney  */
15*dd7afb26SPatrick Mooney 
16*dd7afb26SPatrick Mooney #ifndef _COMM_PAGE_H
17*dd7afb26SPatrick Mooney #define	_COMM_PAGE_H
18*dd7afb26SPatrick Mooney 
19*dd7afb26SPatrick Mooney #ifndef _ASM
20*dd7afb26SPatrick Mooney #include <sys/types.h>
21*dd7afb26SPatrick Mooney #include <sys/param.h>
22*dd7afb26SPatrick Mooney #include <sys/time.h>
23*dd7afb26SPatrick Mooney #endif /* _ASM */
24*dd7afb26SPatrick Mooney 
25*dd7afb26SPatrick Mooney #ifdef __cplusplus
26*dd7afb26SPatrick Mooney extern "C" {
27*dd7afb26SPatrick Mooney #endif
28*dd7afb26SPatrick Mooney 
29*dd7afb26SPatrick Mooney #define	COMM_PAGE_SIZE	PAGESIZE
30*dd7afb26SPatrick Mooney 
31*dd7afb26SPatrick Mooney #ifndef _ASM
32*dd7afb26SPatrick Mooney 
33*dd7afb26SPatrick Mooney /*
34*dd7afb26SPatrick Mooney  * x86 comm page
35*dd7afb26SPatrick Mooney  *
36*dd7afb26SPatrick Mooney  * This struct defines the data format for the "comm page": kernel data made
37*dd7afb26SPatrick Mooney  * directly available to userspace for read-only operations.  This enables
38*dd7afb26SPatrick Mooney  * facilities such as clock_gettime to operate entirely in userspace without
39*dd7afb26SPatrick Mooney  * the need for a trap or fasttrap.
40*dd7afb26SPatrick Mooney  *
41*dd7afb26SPatrick Mooney  * A note about 32-bit/64-bit compatibility:
42*dd7afb26SPatrick Mooney  * The current format of the comm page is designed to be consistent for both
43*dd7afb26SPatrick Mooney  * 32-bit and 64-bit programs running in a 64-bit kernel.  On 32-bit kernels,
44*dd7afb26SPatrick Mooney  * the comm page is not exposed to userspace due to the difference in
45*dd7afb26SPatrick Mooney  * timespec_t sizing.
46*dd7afb26SPatrick Mooney  *
47*dd7afb26SPatrick Mooney  * This struct is instantiated "by hand" in assembly to preserve the global
48*dd7afb26SPatrick Mooney  * symbols it contains.  That layout must be kept in sync with the structure
49*dd7afb26SPatrick Mooney  * defined here.
50*dd7afb26SPatrick Mooney  * See: "uts/i86pc/ml/comm_page.s"
51*dd7afb26SPatrick Mooney  */
52*dd7afb26SPatrick Mooney typedef struct comm_page_s {
53*dd7afb26SPatrick Mooney 	hrtime_t		cp_tsc_last;
54*dd7afb26SPatrick Mooney 	hrtime_t		cp_tsc_hrtime_base;
55*dd7afb26SPatrick Mooney 	hrtime_t		cp_tsc_resume_cap;
56*dd7afb26SPatrick Mooney 	uint32_t		cp_tsc_type;
57*dd7afb26SPatrick Mooney 	uint32_t		cp_tsc_max_delta;
58*dd7afb26SPatrick Mooney 
59*dd7afb26SPatrick Mooney 	volatile uint32_t	cp_hres_lock;	/* must be 8-byte aligned */
60*dd7afb26SPatrick Mooney 	uint32_t		cp_nsec_scale;
61*dd7afb26SPatrick Mooney 	int64_t			cp_hrestime_adj;
62*dd7afb26SPatrick Mooney 	hrtime_t		cp_hres_last_tick;
63*dd7afb26SPatrick Mooney 	uint32_t		cp_tsc_ncpu;
64*dd7afb26SPatrick Mooney 	uint32_t		_cp_pad;
65*dd7afb26SPatrick Mooney 	volatile int64_t	cp_hrestime[2];
66*dd7afb26SPatrick Mooney #if defined(_MACHDEP)
67*dd7afb26SPatrick Mooney 	hrtime_t		cp_tsc_sync_tick_delta[NCPU];
68*dd7afb26SPatrick Mooney #else
69*dd7afb26SPatrick Mooney 	/* length resides in cp_ncpu */
70*dd7afb26SPatrick Mooney 	hrtime_t		cp_tsc_sync_tick_delta[];
71*dd7afb26SPatrick Mooney #endif /* defined(_MACHDEP) */
72*dd7afb26SPatrick Mooney } comm_page_t;
73*dd7afb26SPatrick Mooney 
74*dd7afb26SPatrick Mooney #if defined(_KERNEL)
75*dd7afb26SPatrick Mooney extern comm_page_t comm_page;
76*dd7afb26SPatrick Mooney 
77*dd7afb26SPatrick Mooney #if defined(_MACHDEP)
78*dd7afb26SPatrick Mooney extern hrtime_t tsc_last;
79*dd7afb26SPatrick Mooney extern hrtime_t tsc_hrtime_base;
80*dd7afb26SPatrick Mooney extern hrtime_t tsc_resume_cap;
81*dd7afb26SPatrick Mooney extern uint32_t tsc_type;
82*dd7afb26SPatrick Mooney extern uint32_t tsc_max_delta;
83*dd7afb26SPatrick Mooney extern volatile uint32_t hres_lock;
84*dd7afb26SPatrick Mooney extern uint32_t nsec_scale;
85*dd7afb26SPatrick Mooney extern int64_t hrestime_adj;
86*dd7afb26SPatrick Mooney extern hrtime_t hres_last_tick;
87*dd7afb26SPatrick Mooney extern uint32_t tsc_ncpu;
88*dd7afb26SPatrick Mooney extern volatile timestruc_t hrestime;
89*dd7afb26SPatrick Mooney extern hrtime_t tsc_sync_tick_delta[NCPU];
90*dd7afb26SPatrick Mooney #endif /* defined(_MACHDEP) */
91*dd7afb26SPatrick Mooney #endif /* defined(_KERNEL) */
92*dd7afb26SPatrick Mooney 
93*dd7afb26SPatrick Mooney #endif  /* _ASM */
94*dd7afb26SPatrick Mooney 
95*dd7afb26SPatrick Mooney #ifdef __cplusplus
96*dd7afb26SPatrick Mooney }
97*dd7afb26SPatrick Mooney #endif
98*dd7afb26SPatrick Mooney 
99*dd7afb26SPatrick Mooney #endif /* _COMM_PAGE_H */
100