]>
Commit | Line | Data |
---|---|---|
9dcafc55 UD |
1 | #include <dlfcn.h> |
2 | #include <stdint.h> | |
3 | #include <stdio.h> | |
4 | #include <stdlib.h> | |
5 | #include <string.h> | |
6 | #include <unistd.h> | |
82221992 | 7 | #include <bits/wordsize.h> |
9dcafc55 UD |
8 | #include <gnu/lib-names.h> |
9 | ||
10 | ||
11 | unsigned int | |
12 | la_version (unsigned int v) | |
13 | { | |
14 | setlinebuf (stdout); | |
15 | ||
16 | printf ("version: %u\n", v); | |
17 | ||
18 | char buf[20]; | |
19 | sprintf (buf, "%u", v); | |
20 | ||
21 | return v; | |
22 | } | |
23 | ||
24 | void | |
25 | la_activity (uintptr_t *cookie, unsigned int flag) | |
26 | { | |
27 | if (flag == LA_ACT_CONSISTENT) | |
28 | printf ("activity: consistent\n"); | |
29 | else if (flag == LA_ACT_ADD) | |
30 | printf ("activity: add\n"); | |
31 | else if (flag == LA_ACT_DELETE) | |
32 | printf ("activity: delete\n"); | |
33 | else | |
34 | printf ("activity: unknown activity %u\n", flag); | |
35 | } | |
36 | ||
37 | char * | |
38 | la_objsearch (const char *name, uintptr_t *cookie, unsigned int flag) | |
39 | { | |
40 | char buf[100]; | |
41 | const char *flagstr; | |
42 | if (flag == LA_SER_ORIG) | |
43 | flagstr = "LA_SET_ORIG"; | |
44 | else if (flag == LA_SER_LIBPATH) | |
45 | flagstr = "LA_SER_LIBPATH"; | |
46 | else if (flag == LA_SER_RUNPATH) | |
47 | flagstr = "LA_SER_RUNPATH"; | |
48 | else if (flag == LA_SER_CONFIG) | |
49 | flagstr = "LA_SER_CONFIG"; | |
50 | else if (flag == LA_SER_DEFAULT) | |
51 | flagstr = "LA_SER_DEFAULT"; | |
52 | else if (flag == LA_SER_SECURE) | |
53 | flagstr = "LA_SER_SECURE"; | |
54 | else | |
55 | { | |
56 | sprintf (buf, "unknown flag %d", flag); | |
57 | flagstr = buf; | |
58 | } | |
59 | printf ("objsearch: %s, %s\n", name, flagstr); | |
60 | ||
61 | return (char *) name; | |
62 | } | |
63 | ||
64 | unsigned int | |
65 | la_objopen (struct link_map *l, Lmid_t lmid, uintptr_t *cookie) | |
66 | { | |
67 | printf ("objopen: %ld, %s\n", lmid, l->l_name); | |
68 | ||
69 | return 3; | |
70 | } | |
71 | ||
72 | void | |
73 | la_preinit (uintptr_t *cookie) | |
74 | { | |
75 | printf ("preinit\n"); | |
76 | } | |
77 | ||
78 | unsigned int | |
79 | la_objclose (uintptr_t *cookie) | |
80 | { | |
81 | printf ("objclose\n"); | |
82 | return 0; | |
83 | } | |
84 | ||
85 | uintptr_t | |
86 | la_symbind32 (Elf32_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
87 | uintptr_t *defcook, unsigned int *flags, const char *symname) | |
88 | { | |
89 | printf ("symbind32: symname=%s, st_value=%#lx, ndx=%u, flags=%u\n", | |
90 | symname, (long int) sym->st_value, ndx, *flags); | |
91 | ||
92 | return sym->st_value; | |
93 | } | |
94 | ||
95 | uintptr_t | |
96 | la_symbind64 (Elf64_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
97 | uintptr_t *defcook, unsigned int *flags, const char *symname) | |
98 | { | |
99 | printf ("symbind64: symname=%s, st_value=%#lx, ndx=%u, flags=%u\n", | |
100 | symname, (long int) sym->st_value, ndx, *flags); | |
101 | ||
102 | return sym->st_value; | |
103 | } | |
104 | ||
105 | #ifdef __i386__ | |
106 | Elf32_Addr | |
107 | la_i86_gnu_pltenter (Elf32_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
108 | uintptr_t *defcook, La_i86_regs *regs, | |
109 | unsigned int *flags, const char *symname, | |
110 | long int *framesizep) | |
111 | { | |
112 | printf ("i86_pltenter: symname=%s, st_value=%#lx, ndx=%u, flags=%u\n", | |
113 | symname, (long int) sym->st_value, ndx, *flags); | |
114 | ||
115 | return sym->st_value; | |
116 | } | |
117 | ||
118 | unsigned int | |
119 | la_i86_gnu_pltexit (Elf32_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
120 | uintptr_t *defcook, const La_i86_regs *inregs, | |
121 | La_i86_retval *outregs, const char *symname) | |
122 | { | |
123 | printf ("i86_pltexit: symname=%s, st_value=%#lx, ndx=%u, retval=%tu\n", | |
124 | symname, (long int) sym->st_value, ndx, outregs->lrv_eax); | |
125 | ||
126 | return 0; | |
127 | } | |
369a06bd | 128 | #elif defined __x86_64__ |
2413fdba | 129 | Elf64_Addr |
9dcafc55 UD |
130 | la_x86_64_gnu_pltenter (Elf64_Sym *sym, unsigned int ndx, uintptr_t *refcook, |
131 | uintptr_t *defcook, La_x86_64_regs *regs, | |
132 | unsigned int *flags, const char *symname, | |
133 | long int *framesizep) | |
134 | { | |
135 | printf ("x86_64_pltenter: symname=%s, st_value=%#lx, ndx=%u, flags=%u\n", | |
136 | symname, (long int) sym->st_value, ndx, *flags); | |
137 | ||
138 | return sym->st_value; | |
139 | } | |
140 | ||
141 | unsigned int | |
142 | la_x86_64_gnu_pltexit (Elf64_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
143 | uintptr_t *defcook, const La_x86_64_regs *inregs, | |
144 | La_x86_64_retval *outregs, const char *symname) | |
145 | { | |
146 | printf ("x86_64_pltexit: symname=%s, st_value=%#lx, ndx=%u, retval=%tu\n", | |
147 | symname, (long int) sym->st_value, ndx, outregs->lrv_rax); | |
148 | ||
149 | return 0; | |
150 | } | |
2413fdba UD |
151 | #elif defined __powerpc__ && __WORDSIZE == 32 |
152 | Elf32_Addr | |
153 | la_ppc32_gnu_pltenter (Elf32_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
154 | uintptr_t *defcook, La_ppc32_regs *regs, | |
155 | unsigned int *flags, const char *symname, | |
156 | long int *framesizep) | |
157 | { | |
158 | printf ("ppc32_pltenter: symname=%s, st_value=%#lx, ndx=%u, flags=%u\n", | |
159 | symname, (long int) sym->st_value, ndx, *flags); | |
160 | ||
161 | return sym->st_value; | |
162 | } | |
163 | ||
164 | unsigned int | |
165 | la_ppc32_gnu_pltexit (Elf32_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
166 | uintptr_t *defcook, const La_ppc32_regs *inregs, | |
167 | La_ppc32_retval *outregs, const char *symname) | |
168 | { | |
169 | printf ("ppc32_pltexit: symname=%s, st_value=%#lx, ndx=%u, retval=%tu\n", | |
170 | symname, (long int) sym->st_value, ndx, outregs->lrv_r3); | |
171 | ||
172 | return 0; | |
173 | } | |
82221992 | 174 | #elif defined __powerpc__ && __WORDSIZE == 64 |
2413fdba | 175 | Elf64_Addr |
82221992 UD |
176 | la_ppc64_gnu_pltenter (Elf64_Sym *sym, unsigned int ndx, uintptr_t *refcook, |
177 | uintptr_t *defcook, La_ppc64_regs *regs, | |
178 | unsigned int *flags, const char *symname, | |
179 | long int *framesizep) | |
180 | { | |
181 | printf ("ppc64_pltenter: symname=%s, st_value=%#lx, ndx=%u, flags=%u\n", | |
182 | symname, (long int) sym->st_value, ndx, *flags); | |
183 | ||
184 | return sym->st_value; | |
185 | } | |
186 | ||
187 | unsigned int | |
188 | la_ppc64_gnu_pltexit (Elf64_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
189 | uintptr_t *defcook, const La_ppc64_regs *inregs, | |
190 | La_ppc64_retval *outregs, const char *symname) | |
191 | { | |
192 | printf ("ppc64_pltexit: symname=%s, st_value=%#lx, ndx=%u, retval=%tu\n", | |
193 | symname, (long int) sym->st_value, ndx, outregs->lrv_r3); | |
194 | ||
195 | return 0; | |
196 | } | |
537e7234 UD |
197 | #elif defined __sh__ |
198 | uintptr_t | |
199 | la_sh_gnu_pltenter (Elf32_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
200 | uintptr_t *defcook, La_sh_regs *regs, | |
201 | unsigned int *flags, const char *symname, | |
202 | long int *framesizep) | |
203 | { | |
204 | printf ("sh_pltenter: symname=%s, st_value=%#lx, ndx=%u, flags=%u\n", | |
205 | symname, (long int) sym->st_value, ndx, *flags); | |
206 | ||
207 | return sym->st_value; | |
208 | } | |
209 | ||
210 | unsigned int | |
211 | la_sh_gnu_pltexit (Elf32_Sym *sym, unsigned int ndx, uintptr_t *refcook, | |
212 | uintptr_t *defcook, const La_sh_regs *inregs, | |
213 | La_sh_retval *outregs, const char *symname) | |
214 | { | |
215 | printf ("sh_pltexit: symname=%s, st_value=%#lx, ndx=%u, retval=%tu\n", | |
216 | symname, (long int) sym->st_value, ndx, outregs->lrv_r0); | |
217 | ||
218 | return 0; | |
219 | } | |
369a06bd UD |
220 | #else |
221 | # error "architecture specific code needed" | |
9dcafc55 | 222 | #endif |