OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [config/] [rs6000/] [tramp.asm] - Blame information for rev 328

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 282 jeremybenn
/*  Special support for trampolines
2
 *
3
 *   Copyright (C) 1996, 1997, 2000, 2007, 2008, 2009 Free Software Foundation, Inc.
4
 *   Written By Michael Meissner
5
 *
6
 * This file is free software; you can redistribute it and/or modify it
7
 * under the terms of the GNU General Public License as published by the
8
 * Free Software Foundation; either version 3, or (at your option) any
9
 * later version.
10
 *
11
 * This file is distributed in the hope that it will be useful, but
12
 * WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14
 * General Public License for more details.
15
 *
16
 * Under Section 7 of GPL version 3, you are granted additional
17
 * permissions described in the GCC Runtime Library Exception, version
18
 * 3.1, as published by the Free Software Foundation.
19
 *
20
 * You should have received a copy of the GNU General Public License and
21
 * a copy of the GCC Runtime Library Exception along with this program;
22
 * see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
23
 * .
24
 */
25
 
26
/* Set up trampolines.  */
27
 
28
        .section ".text"
29
#include "ppc-asm.h"
30
#include "config.h"
31
 
32
#ifndef __powerpc64__
33
        .type   trampoline_initial,@object
34
        .align  2
35
trampoline_initial:
36
        mflr    r0
37
        bcl     20,31,1f
38
.Lfunc = .-trampoline_initial
39
        .long   0                        /* will be replaced with function address */
40
.Lchain = .-trampoline_initial
41
        .long   0                        /* will be replaced with static chain */
42
1:      mflr    r11
43
        mtlr    r0
44
        lwz     r0,0(r11)               /* function address */
45
        lwz     r11,4(r11)              /* static chain */
46
        mtctr   r0
47
        bctr
48
 
49
trampoline_size = .-trampoline_initial
50
        .size   trampoline_initial,trampoline_size
51
 
52
 
53
/* R3 = stack address to store trampoline */
54
/* R4 = length of trampoline area */
55
/* R5 = function address */
56
/* R6 = static chain */
57
 
58
FUNC_START(__trampoline_setup)
59
        mflr    r0              /* save return address */
60
        bcl     20,31,.LCF0     /* load up __trampoline_initial into r7 */
61
.LCF0:
62
        mflr    r11
63
        addi    r7,r11,trampoline_initial-4-.LCF0 /* trampoline address -4 */
64
 
65
        li      r8,trampoline_size      /* verify that the trampoline is big enough */
66
        cmpw    cr1,r8,r4
67
        srwi    r4,r4,2         /* # words to move */
68
        addi    r9,r3,-4        /* adjust pointer for lwzu */
69
        mtctr   r4
70
        blt     cr1,.Labort
71
 
72
        mtlr    r0
73
 
74
        /* Copy the instructions to the stack */
75
.Lmove:
76
        lwzu    r10,4(r7)
77
        stwu    r10,4(r9)
78
        bdnz    .Lmove
79
 
80
        /* Store correct function and static chain */
81
        stw     r5,.Lfunc(r3)
82
        stw     r6,.Lchain(r3)
83
 
84
        /* Now flush both caches */
85
        mtctr   r4
86
.Lcache:
87
        icbi    0,r3
88
        dcbf    0,r3
89
        addi    r3,r3,4
90
        bdnz    .Lcache
91
 
92
        /* Finally synchronize things & return */
93
        sync
94
        isync
95
        blr
96
 
97
.Labort:
98
#if (defined __PIC__ || defined __pic__) && defined HAVE_AS_REL16
99
        bcl     20,31,1f
100
1:      mflr    r30
101
        addis   r30,r30,_GLOBAL_OFFSET_TABLE_-1b@ha
102
        addi    r30,r30,_GLOBAL_OFFSET_TABLE_-1b@l
103
#endif
104
        bl      JUMP_TARGET(abort)
105
FUNC_END(__trampoline_setup)
106
 
107
#endif

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.