1 1.22 riastrad /* $NetBSD: profile.h,v 1.22 2014/03/18 18:20:41 riastradh Exp $ */ 2 1.2 cgd 3 1.1 mycroft /* 4 1.1 mycroft * Copyright (c) 1992, 1993 5 1.1 mycroft * The Regents of the University of California. All rights reserved. 6 1.1 mycroft * 7 1.1 mycroft * Redistribution and use in source and binary forms, with or without 8 1.1 mycroft * modification, are permitted provided that the following conditions 9 1.1 mycroft * are met: 10 1.1 mycroft * 1. Redistributions of source code must retain the above copyright 11 1.1 mycroft * notice, this list of conditions and the following disclaimer. 12 1.1 mycroft * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 mycroft * notice, this list of conditions and the following disclaimer in the 14 1.1 mycroft * documentation and/or other materials provided with the distribution. 15 1.13 agc * 3. Neither the name of the University nor the names of its contributors 16 1.1 mycroft * may be used to endorse or promote products derived from this software 17 1.1 mycroft * without specific prior written permission. 18 1.1 mycroft * 19 1.1 mycroft * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20 1.1 mycroft * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 1.1 mycroft * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 1.1 mycroft * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23 1.1 mycroft * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 1.1 mycroft * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 1.1 mycroft * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 1.1 mycroft * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 1.1 mycroft * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 1.1 mycroft * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 1.1 mycroft * SUCH DAMAGE. 30 1.1 mycroft * 31 1.2 cgd * @(#)profile.h 8.1 (Berkeley) 6/10/93 32 1.1 mycroft */ 33 1.1 mycroft 34 1.18 perry #define _MCOUNT_DECL static __inline void _mcount 35 1.1 mycroft 36 1.10 kleink #ifdef __ELF__ 37 1.10 kleink #define MCOUNT_ENTRY "__mcount" 38 1.10 kleink #else 39 1.10 kleink #define MCOUNT_ENTRY "mcount" 40 1.10 kleink #endif 41 1.10 kleink 42 1.21 matt #if !defined(__mc68010__) && !defined(__mcoldfire__) 43 1.1 mycroft #define MCOUNT \ 44 1.19 tsutsui extern void mcount(void) __asm(MCOUNT_ENTRY) \ 45 1.14 chs __attribute__((__no_instrument_function__)); \ 46 1.20 he void mcount(void) { \ 47 1.1 mycroft int selfpc, frompcindex; \ 48 1.17 perry __asm("movl %%a6@(4),%0" : "=r" (selfpc)); \ 49 1.17 perry __asm("movl %%a6@(0)@(4),%0" : "=r" (frompcindex)); \ 50 1.1 mycroft _mcount(frompcindex, selfpc); \ 51 1.1 mycroft } 52 1.11 fredette #else /* __mc68010__ */ 53 1.11 fredette /* 54 1.11 fredette * The 68010 doesn't have the memory indirect addressing mode 55 1.11 fredette * that the above definition of mcount uses, so we're forced 56 1.11 fredette * to do something different. 57 1.11 fredette */ 58 1.11 fredette #define MCOUNT \ 59 1.20 he extern void mcount(void) __asm("mcount"); void mcount(void) { \ 60 1.11 fredette int selfpc, frompcindex; \ 61 1.17 perry __asm("movl %%a6@(4),%0" : "=r" (selfpc)); \ 62 1.17 perry __asm("movl %%a6@(0),%%a0 ; movl %%a0@(4),%0" : "=r" (frompcindex) : /* no inputs */ : "a0"); \ 63 1.11 fredette _mcount(frompcindex, selfpc); \ 64 1.11 fredette } 65 1.11 fredette #endif /* __mc68010__ */ 66 1.1 mycroft 67 1.3 briggs #ifdef _KERNEL 68 1.1 mycroft /* 69 1.1 mycroft * The following two macros do splhigh and splx respectively. 70 1.1 mycroft * They have to be defined this way because these are real 71 1.1 mycroft * functions on the HP, and we do not want to invoke mcount 72 1.1 mycroft * recursively. 73 1.1 mycroft */ 74 1.1 mycroft #define MCOUNT_ENTER \ 75 1.17 perry __asm("movw %%sr,%0" : "=g" (s)); \ 76 1.17 perry __asm("movw #0x2700,%sr") 77 1.1 mycroft 78 1.1 mycroft #define MCOUNT_EXIT \ 79 1.17 perry __asm("movw %0,%%sr" : : "g" (s)) 80 1.3 briggs #endif /* _KERNEL */ 81