profile.h revision 1.14 1 1.14 chs /* $NetBSD: profile.h,v 1.14 2005/10/02 15:34:17 chs 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.6 thorpej #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.11 fredette #ifndef __mc68010__
43 1.1 mycroft #define MCOUNT \
44 1.14 chs extern void mcount __P((void)) __asm__(MCOUNT_ENTRY) \
45 1.14 chs __attribute__((__no_instrument_function__)); \
46 1.14 chs void mcount() { \
47 1.1 mycroft int selfpc, frompcindex; \
48 1.9 leo __asm__("movl %%a6@(4),%0" : "=r" (selfpc)); \
49 1.9 leo __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.11 fredette extern void mcount __P((void)) __asm__("mcount"); void mcount() { \
60 1.11 fredette int selfpc, frompcindex; \
61 1.11 fredette __asm__("movl %%a6@(4),%0" : "=r" (selfpc)); \
62 1.11 fredette __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.9 leo __asm__("movw %%sr,%0" : "=g" (s)); \
76 1.12 chs __asm__("movw #0x2700,%sr")
77 1.1 mycroft
78 1.1 mycroft #define MCOUNT_EXIT \
79 1.9 leo __asm__("movw %0,%%sr" : : "g" (s))
80 1.3 briggs #endif /* _KERNEL */
81