profile.h revision 1.11 1 1.11 fredette /* $NetBSD: profile.h,v 1.11 2001/05/18 15:33:03 fredette 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.1 mycroft * 3. All advertising materials mentioning features or use of this software
16 1.1 mycroft * must display the following acknowledgement:
17 1.1 mycroft * This product includes software developed by the University of
18 1.1 mycroft * California, Berkeley and its contributors.
19 1.1 mycroft * 4. Neither the name of the University nor the names of its contributors
20 1.1 mycroft * may be used to endorse or promote products derived from this software
21 1.1 mycroft * without specific prior written permission.
22 1.1 mycroft *
23 1.1 mycroft * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.1 mycroft * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.1 mycroft * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.1 mycroft * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.1 mycroft * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.1 mycroft * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.1 mycroft * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 mycroft * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.1 mycroft * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.1 mycroft * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.1 mycroft * SUCH DAMAGE.
34 1.1 mycroft *
35 1.2 cgd * @(#)profile.h 8.1 (Berkeley) 6/10/93
36 1.1 mycroft */
37 1.1 mycroft
38 1.6 thorpej #define _MCOUNT_DECL static __inline void _mcount
39 1.1 mycroft
40 1.10 kleink #ifdef __ELF__
41 1.10 kleink #define MCOUNT_ENTRY "__mcount"
42 1.10 kleink #else
43 1.10 kleink #define MCOUNT_ENTRY "mcount"
44 1.10 kleink #endif
45 1.10 kleink
46 1.11 fredette #ifndef __mc68010__
47 1.1 mycroft #define MCOUNT \
48 1.10 kleink extern void mcount __P((void)) __asm__(MCOUNT_ENTRY); void mcount() { \
49 1.1 mycroft int selfpc, frompcindex; \
50 1.9 leo __asm__("movl %%a6@(4),%0" : "=r" (selfpc)); \
51 1.9 leo __asm__("movl %%a6@(0)@(4),%0" : "=r" (frompcindex)); \
52 1.1 mycroft _mcount(frompcindex, selfpc); \
53 1.1 mycroft }
54 1.11 fredette #else /* __mc68010__ */
55 1.11 fredette /*
56 1.11 fredette * The 68010 doesn't have the memory indirect addressing mode
57 1.11 fredette * that the above definition of mcount uses, so we're forced
58 1.11 fredette * to do something different.
59 1.11 fredette */
60 1.11 fredette #define MCOUNT \
61 1.11 fredette extern void mcount __P((void)) __asm__("mcount"); void mcount() { \
62 1.11 fredette int selfpc, frompcindex; \
63 1.11 fredette __asm__("movl %%a6@(4),%0" : "=r" (selfpc)); \
64 1.11 fredette __asm__("movl %%a6@(0),%%a0 ; movl %%a0@(4),%0" : "=r" (frompcindex) : /* no inputs */ : "a0"); \
65 1.11 fredette _mcount(frompcindex, selfpc); \
66 1.11 fredette }
67 1.11 fredette #endif /* __mc68010__ */
68 1.1 mycroft
69 1.3 briggs #ifdef _KERNEL
70 1.1 mycroft /*
71 1.1 mycroft * The following two macros do splhigh and splx respectively.
72 1.1 mycroft * They have to be defined this way because these are real
73 1.1 mycroft * functions on the HP, and we do not want to invoke mcount
74 1.1 mycroft * recursively.
75 1.1 mycroft */
76 1.1 mycroft #define MCOUNT_ENTER \
77 1.9 leo __asm__("movw %%sr,%0" : "=g" (s)); \
78 1.9 leo __asm__("movw #0x2700,%%sr")
79 1.1 mycroft
80 1.1 mycroft #define MCOUNT_EXIT \
81 1.9 leo __asm__("movw %0,%%sr" : : "g" (s))
82 1.3 briggs #endif /* _KERNEL */
83