summaryrefslogtreecommitdiff
path: root/time/sunbird/patches/patch-bw
blob: 8766d233a0899a7ecf3f716ad750f9b2451262ce (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
$NetBSD: patch-bw,v 1.1.1.1 2006/02/05 21:56:26 ghen Exp $

--- xpcom/reflect/xptcall/src/md/unix/xptcstubs_linux_alpha.cpp.orig	2006-02-02 16:57:57.000000000 +0100
+++ xpcom/reflect/xptcall/src/md/unix/xptcstubs_linux_alpha.cpp
@@ -187,6 +187,50 @@ __asm__(
  * nsresult nsXPTCStubBase::Stub##n()
  *  Sets register $1 to "methodIndex" and jumps to SharedStub.
  */
+#if defined(__GXX_ABI_VERSION) && __GXX_ABI_VERSION >= 100 /* G++ V3 ABI */
+#define STUB_ENTRY(n)					\
+__asm__(						\
+"#### Stub"#n" ####\n"					\
+".text\n"						\
+"	.align 5\n"					\
+"	.if "#n" < 10 \n"				\
+"	.globl _ZN14nsXPTCStubBase5Stub"#n"Ev\n"	\
+"	.ent _ZN14nsXPTCStubBase5Stub"#n"Ev\n"		\
+"_ZN14nsXPTCStubBase5Stub"#n"Ev:\n"			\
+"	.frame $30,0,$26,0\n"				\
+"	ldgp $29,0($27)\n"				\
+"$_ZN14nsXPTCStubBase5Stub"#n"Ev..ng:\n"		\
+"	.prologue 1\n"					\
+"	lda $1,"#n"\n"					\
+"	br $31,$SharedStub..ng\n"			\
+"	.end _ZN14nsXPTCStubBase5Stub"#n"Ev\n"		\
+"	.elseif  "#n" < 100 \n"				\
+"	.globl _ZN14nsXPTCStubBase6Stub"#n"Ev\n"	\
+"	.ent _ZN14nsXPTCStubBase6Stub"#n"Ev\n"		\
+"_ZN14nsXPTCStubBase6Stub"#n"Ev:\n"			\
+"	.frame $30,0,$26,0\n"				\
+"	ldgp $29,0($27)\n"				\
+"$_ZN14nsXPTCStubBase6Stub"#n"Ev..ng:\n"		\
+"	.prologue 1\n"					\
+"	lda $1,"#n"\n"					\
+"	br $31,$SharedStub..ng\n"			\
+"	.end _ZN14nsXPTCStubBase6Stub"#n"Ev\n"		\
+"	.elseif "#n" < 1000 \n"				\
+"	.globl _ZN14nsXPTCStubBase7Stub"#n"Ev\n"	\
+"	.ent _ZN14nsXPTCStubBase7Stub"#n"Ev\n"		\
+"_ZN14nsXPTCStubBase7Stub"#n"Ev:\n"			\
+"	.frame $30,0,$26,0\n"				\
+"	ldgp $29,0($27)\n"				\
+"$_ZN14nsXPTCStubBase7Stub"#n"Ev..ng:\n"		\
+"	.prologue 1\n"					\
+"	lda $1,"#n"\n"					\
+"	br $31,$SharedStub..ng\n"			\
+"	.end _ZN14nsXPTCStubBase7Stub"#n"Ev\n"		\
+"	.else\n"					\
+"	.err \"stub number "#n"> 1000 not yet supported\"\n" \
+"	.endif\n"					\
+    );
+#else /* G++2.95 ABI */
 #define STUB_MANGLED_ENTRY(n, symbol) \
     "#### Stub"#n" ####"      "\n\t" \
     ".text"                   "\n\t" \
@@ -216,6 +260,7 @@ __asm__( \
     ".err \"Stub"#n" >= 1000 not yet supported.\""               "\n\t" \
     ".endif" \
     );
+#endif
 
 #else /* not G++ V3 ABI */