X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/d9a64523371fa019c4575bb400cbbc3a50ac9903..94ff46dc2849db4d43eaaf144872decc522aafb4:/bsd/sys/monotonic.h diff --git a/bsd/sys/monotonic.h b/bsd/sys/monotonic.h index e880a9a0a..6ec648972 100644 --- a/bsd/sys/monotonic.h +++ b/bsd/sys/monotonic.h @@ -1,9 +1,49 @@ +/* + * Copyright (c) 2017-2019 Apple Inc. All rights reserved. + * + * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ + * + * This file contains Original Code and/or Modifications of Original Code + * as defined in and that are subject to the Apple Public Source License + * Version 2.0 (the 'License'). You may not use this file except in + * compliance with the License. The rights granted to you under the License + * may not be used to create, or enable the creation or redistribution of, + * unlawful or unlicensed copies of an Apple operating system, or to + * circumvent, violate, or enable the circumvention or violation of, any + * terms of an Apple operating system software license agreement. + * + * Please obtain a copy of the License at + * http://www.opensource.apple.com/apsl/ and read it before using this file. + * + * The Original Code and all software distributed under the License are + * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER + * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, + * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. + * Please see the License for the specific language governing rights and + * limitations under the License. + * + * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ + */ + #ifndef SYS_MONOTONIC_H #define SYS_MONOTONIC_H #include #include #include + +__BEGIN_DECLS + +struct mt_cpu_inscyc { + uint64_t mtci_instructions; + uint64_t mtci_cycles; +}; + +__END_DECLS + +#if !MACH_KERNEL_PRIVATE + #include __BEGIN_DECLS @@ -13,10 +53,17 @@ __BEGIN_DECLS */ #define MT_IOC(x) _IO('m', (x)) - #define MT_IOC_RESET MT_IOC(0) - #define MT_IOC_ADD MT_IOC(1) +#define MT_IOC_ENABLE MT_IOC(2) +#define MT_IOC_COUNTS MT_IOC(3) +#define MT_IOC_GET_INFO MT_IOC(4) + +__END_DECLS + +#endif /* !MACH_KERNEL_PRIVATE */ + +__BEGIN_DECLS struct monotonic_config { uint64_t event; @@ -34,19 +81,12 @@ union monotonic_ctl_add { } out; }; -/* - * - Consider a separate IOC for disable -- to avoid the copyin to determine - * which way to set it. - */ -#define MT_IOC_ENABLE MT_IOC(2) - union monotonic_ctl_enable { struct { bool enable; } in; }; -#define MT_IOC_COUNTS MT_IOC(3) union monotonic_ctl_counts { struct { @@ -58,7 +98,6 @@ union monotonic_ctl_counts { } out; }; -#define MT_IOC_GET_INFO MT_IOC(4) union monotonic_ctl_info { struct { @@ -67,13 +106,19 @@ union monotonic_ctl_info { } out; }; +__END_DECLS + #if XNU_KERNEL_PRIVATE +#if MONOTONIC + #include #include #include #include +__BEGIN_DECLS + #ifdef MT_CORE_INSTRS #define COUNTS_INSTRS __counts[MT_CORE_INSTRS] #else /* defined(MT_CORE_INSTRS) */ @@ -95,13 +140,13 @@ union monotonic_ctl_info { #define MT_KDBG_TMPCPU_(CODE, FUNC) \ do { \ - if (kdebug_enable && \ - kdebug_debugid_enabled(MT_KDBG_TMPCPU_EVT(CODE))) { \ - uint64_t __counts[MT_CORE_NFIXED]; \ - mt_fixed_counts(__counts); \ - KDBG(MT_KDBG_TMPCPU_EVT(CODE) | (FUNC), COUNTS_INSTRS, \ - __counts[MT_CORE_CYCLES]); \ - } \ + if (kdebug_enable && \ + kdebug_debugid_enabled(MT_KDBG_TMPCPU_EVT(CODE))) { \ + uint64_t __counts[MT_CORE_NFIXED]; \ + mt_fixed_counts(__counts); \ + KDBG(MT_KDBG_TMPCPU_EVT(CODE) | (FUNC), COUNTS_INSTRS, \ + __counts[MT_CORE_CYCLES]); \ + } \ } while (0) #define MT_KDBG_TMPCPU(CODE) MT_KDBG_TMPCPU_(CODE, DBG_FUNC_NONE) @@ -118,26 +163,30 @@ union monotonic_ctl_info { #define MT_KDBG_TMPTH_(CODE, FUNC) \ do { \ - if (kdebug_enable && \ - kdebug_debugid_enabled(MT_KDBG_TMPTH_EVT(CODE))) { \ - uint64_t __counts[MT_CORE_NFIXED]; \ - mt_cur_thread_fixed_counts(__counts); \ - KDBG(MT_KDBG_TMPTH_EVT(CODE) | (FUNC), COUNTS_INSTRS, \ - __counts[MT_CORE_CYCLES]); \ - } \ + if (kdebug_enable && \ + kdebug_debugid_enabled(MT_KDBG_TMPTH_EVT(CODE))) { \ + uint64_t __counts[MT_CORE_NFIXED]; \ + mt_cur_thread_fixed_counts(__counts); \ + KDBG(MT_KDBG_TMPTH_EVT(CODE) | (FUNC), COUNTS_INSTRS, \ + __counts[MT_CORE_CYCLES]); \ + } \ } while (0) #define MT_KDBG_TMPTH(CODE) MT_KDBG_TMPTH_(CODE, DBG_FUNC_NONE) #define MT_KDBG_TMPTH_START(CODE) MT_KDBG_TMPTH_(CODE, DBG_FUNC_START) #define MT_KDBG_TMPTH_END(CODE) MT_KDBG_TMPTH_(CODE, DBG_FUNC_END) +extern lck_grp_t * mt_lock_grp; + +int mt_dev_init(void); + struct mt_device { const char *mtd_name; - int (* const mtd_init)(struct mt_device *dev); - int (* const mtd_add)(struct monotonic_config *config, uint32_t *ctr_out); - void (* const mtd_reset)(void); - void (* const mtd_enable)(bool enable); - int (* const mtd_read)(uint64_t ctr_mask, uint64_t *counts_out); + int(*const mtd_init)(struct mt_device *dev); + int(*const mtd_add)(struct monotonic_config *config, uint32_t *ctr_out); + void(*const mtd_reset)(void); + void(*const mtd_enable)(bool enable); + int(*const mtd_read)(uint64_t ctr_mask, uint64_t *counts_out); decl_lck_mtx_data(, mtd_lock); uint8_t mtd_nmonitors; @@ -148,12 +197,10 @@ typedef struct mt_device *mt_device_t; extern struct mt_device mt_devices[]; -extern lck_grp_t *mt_lock_grp; +__END_DECLS -int mt_dev_init(void); +#endif /* MONOTONIC */ #endif /* XNU_KERNEL_PRIVATE */ -__END_DECLS - #endif /* !defined(SYS_MONOTONIC_H) */