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