profile.h revision 78908
11543Srgrimes/* 21543Srgrimes * Copyright (c) 1992, 1993 31543Srgrimes * The Regents of the University of California. All rights reserved. 41543Srgrimes * 51543Srgrimes * Redistribution and use in source and binary forms, with or without 61543Srgrimes * modification, are permitted provided that the following conditions 71543Srgrimes * are met: 81543Srgrimes * 1. Redistributions of source code must retain the above copyright 91543Srgrimes * notice, this list of conditions and the following disclaimer. 101543Srgrimes * 2. Redistributions in binary form must reproduce the above copyright 111543Srgrimes * notice, this list of conditions and the following disclaimer in the 121543Srgrimes * documentation and/or other materials provided with the distribution. 131543Srgrimes * 3. All advertising materials mentioning features or use of this software 141543Srgrimes * must display the following acknowledgement: 151543Srgrimes * This product includes software developed by the University of 161543Srgrimes * California, Berkeley and its contributors. 171543Srgrimes * 4. Neither the name of the University nor the names of its contributors 181543Srgrimes * may be used to endorse or promote products derived from this software 191543Srgrimes * without specific prior written permission. 201543Srgrimes * 211543Srgrimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 221543Srgrimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 231543Srgrimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 241543Srgrimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 251543Srgrimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 261543Srgrimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 271543Srgrimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 281543Srgrimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 291543Srgrimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 301543Srgrimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 311543Srgrimes * SUCH DAMAGE. 321543Srgrimes * 331543Srgrimes * @(#)profile.h 8.1 (Berkeley) 6/11/93 3450477Speter * $FreeBSD: head/sys/amd64/include/profile.h 78908 2001-06-28 04:03:29Z jhb $ 351543Srgrimes */ 361543Srgrimes 3713107Sbde#ifndef _MACHINE_PROFILE_H_ 3813107Sbde#define _MACHINE_PROFILE_H_ 392166Spaul 4055205Speter#ifdef _KERNEL 4137542Sbde 4213157Sbde/* 4322639Sbde * Config generates something to tell the compiler to align functions on 16 4422639Sbde * byte boundaries. A strict alignment is good for keeping the tables small. 4522639Sbde */ 4622639Sbde#define FUNCTION_ALIGNMENT 16 4722639Sbde 4822639Sbde/* 4913157Sbde * The kernel uses assembler stubs instead of unportable inlines. 5013157Sbde * This is mainly to save a little time when profiling is not enabled, 5113157Sbde * which is the usual case for the kernel. 5213157Sbde */ 5313157Sbde#define _MCOUNT_DECL void mcount 5413157Sbde#define MCOUNT 551543Srgrimes 5617879Sbde#ifdef GUPROF 5717879Sbde#define CALIB_SCALE 1000 5817879Sbde#define KCOUNT(p,index) ((p)->kcount[(index) \ 5922639Sbde / (HISTFRACTION * sizeof(HISTCOUNTER))]) 6017879Sbde#define MCOUNT_DECL(s) 6117879Sbde#define MCOUNT_ENTER(s) 6217879Sbde#define MCOUNT_EXIT(s) 6337629Sbde#define PC_TO_I(p, pc) ((uintfptr_t)(pc) - (uintfptr_t)(p)->lowpc) 6417879Sbde#else 6517879Sbde#define MCOUNT_DECL(s) u_long s; 6628921Sfsmp#ifdef SMP 6778908Sjhb#define MCOUNT_ENTER(s) { s = read_eflags(); disable_intr(); \ 6878908Sjhb while (!atomic_cmpset_acq_int(&mcount_lock, 0, 1) \ 6978908Sjhb /* nothing */ ; } 7078908Sjhb#define MCOUNT_EXIT(s) { atomic_store_rel_int(&mcount_lock, 0); \ 7178908Sjhb write_eflags(s); } 7228921Sfsmp#else 7331723Stegge#define MCOUNT_ENTER(s) { s = read_eflags(); disable_intr(); } 7417879Sbde#define MCOUNT_EXIT(s) (write_eflags(s)) 7528921Sfsmp#endif 7617879Sbde#endif /* GUPROF */ 7717879Sbde 7855205Speter#else /* !_KERNEL */ 7913157Sbde 8022639Sbde#define FUNCTION_ALIGNMENT 4 8122639Sbde 8213157Sbde#define _MCOUNT_DECL static __inline void _mcount 8313157Sbde 841543Srgrimes#define MCOUNT \ 8513157Sbdevoid \ 8613157Sbdemcount() \ 8713157Sbde{ \ 8837629Sbde uintfptr_t selfpc, frompc; \ 891543Srgrimes /* \ 9013107Sbde * Find the return address for mcount, \ 911543Srgrimes * and the return address for mcount's caller. \ 921543Srgrimes * \ 9313107Sbde * selfpc = pc pushed by call to mcount \ 941543Srgrimes */ \ 951543Srgrimes asm("movl 4(%%ebp),%0" : "=r" (selfpc)); \ 961543Srgrimes /* \ 9713107Sbde * frompc = pc pushed by call to mcount's caller. \ 9813107Sbde * The caller's stack frame has already been built, so %ebp is \ 9913107Sbde * the caller's frame pointer. The caller's raddr is in the \ 10013107Sbde * caller's frame following the caller's caller's frame pointer. \ 1011543Srgrimes */ \ 10213107Sbde asm("movl (%%ebp),%0" : "=r" (frompc)); \ 10337629Sbde frompc = ((uintfptr_t *)frompc)[1]; \ 10413107Sbde _mcount(frompc, selfpc); \ 1051543Srgrimes} 10637542Sbde 10737629Sbdetypedef unsigned int uintfptr_t; 10837542Sbde 10955205Speter#endif /* _KERNEL */ 1102166Spaul 11113107Sbde/* 11213107Sbde * An unsigned integral type that can hold non-negative difference between 11313107Sbde * function pointers. 11413107Sbde */ 11531723Steggetypedef u_int fptrdiff_t; 11613107Sbde 11755205Speter#ifdef _KERNEL 11819000Sbde 11937629Sbdevoid mcount __P((uintfptr_t frompc, uintfptr_t selfpc)); 12019000Sbde 12119000Sbde#ifdef GUPROF 12219000Sbdestruct gmonparam; 12319000Sbde 12419000Sbdevoid nullfunc_loop_profiled __P((void)); 12519000Sbdevoid nullfunc_profiled __P((void)); 12619000Sbdevoid startguprof __P((struct gmonparam *p)); 12719000Sbdevoid stopguprof __P((struct gmonparam *p)); 12813157Sbde#else 12919000Sbde#define startguprof(p) 13019000Sbde#define stopguprof(p) 13119000Sbde#endif /* GUPROF */ 13219000Sbde 13355205Speter#else /* !_KERNEL */ 13419000Sbde 13519000Sbde#include <sys/cdefs.h> 13619000Sbde 13719000Sbde__BEGIN_DECLS 13833047Sbde#ifdef __GNUC__ 13938928Sjdp#ifdef __ELF__ 14038928Sjdpvoid mcount __P((void)) __asm(".mcount"); 14138928Sjdp#else 14213157Sbdevoid mcount __P((void)) __asm("mcount"); 14333047Sbde#endif 14438928Sjdp#endif 14537629Sbdestatic void _mcount __P((uintfptr_t frompc, uintfptr_t selfpc)); 14619000Sbde__END_DECLS 14713157Sbde 14855205Speter#endif /* _KERNEL */ 14919000Sbde 15013157Sbde#ifdef GUPROF 15119000Sbde/* XXX doesn't quite work outside kernel yet. */ 15219000Sbdeextern int cputime_bias; 15319000Sbde 15419000Sbde__BEGIN_DECLS 15519000Sbdeint cputime __P((void)); 15619000Sbdevoid empty_loop __P((void)); 15737629Sbdevoid mexitcount __P((uintfptr_t selfpc)); 15819000Sbdevoid nullfunc __P((void)); 15919000Sbdevoid nullfunc_loop __P((void)); 16019000Sbde__END_DECLS 16113157Sbde#endif 16213107Sbde 16313157Sbde#endif /* !_MACHINE_PROFILE_H_ */ 164