ccfdcdf98bc1e528cd768efaaaffaa3405708f71
[deliverable/binutils-gdb.git] / gdb / mips-linux-tdep.c
1 /* Target-dependent code for GNU/Linux on MIPS processors.
2
3 Copyright (C) 2001-2017 Free Software Foundation, Inc.
4
5 This file is part of GDB.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
20 #include "defs.h"
21 #include "gdbcore.h"
22 #include "target.h"
23 #include "solib-svr4.h"
24 #include "osabi.h"
25 #include "mips-tdep.h"
26 #include "frame.h"
27 #include "regcache.h"
28 #include "trad-frame.h"
29 #include "tramp-frame.h"
30 #include "gdbtypes.h"
31 #include "objfiles.h"
32 #include "solib.h"
33 #include "solist.h"
34 #include "symtab.h"
35 #include "target-descriptions.h"
36 #include "regset.h"
37 #include "mips-linux-tdep.h"
38 #include "glibc-tdep.h"
39 #include "linux-tdep.h"
40 #include "xml-syscall.h"
41 #include "gdb_signals.h"
42
43 static struct target_so_ops mips_svr4_so_ops;
44
45 /* This enum represents the signals' numbers on the MIPS
46 architecture. It just contains the signal definitions which are
47 different from the generic implementation.
48
49 It is derived from the file <arch/mips/include/uapi/asm/signal.h>,
50 from the Linux kernel tree. */
51
52 enum
53 {
54 MIPS_LINUX_SIGEMT = 7,
55 MIPS_LINUX_SIGBUS = 10,
56 MIPS_LINUX_SIGSYS = 12,
57 MIPS_LINUX_SIGUSR1 = 16,
58 MIPS_LINUX_SIGUSR2 = 17,
59 MIPS_LINUX_SIGCHLD = 18,
60 MIPS_LINUX_SIGCLD = MIPS_LINUX_SIGCHLD,
61 MIPS_LINUX_SIGPWR = 19,
62 MIPS_LINUX_SIGWINCH = 20,
63 MIPS_LINUX_SIGURG = 21,
64 MIPS_LINUX_SIGIO = 22,
65 MIPS_LINUX_SIGPOLL = MIPS_LINUX_SIGIO,
66 MIPS_LINUX_SIGSTOP = 23,
67 MIPS_LINUX_SIGTSTP = 24,
68 MIPS_LINUX_SIGCONT = 25,
69 MIPS_LINUX_SIGTTIN = 26,
70 MIPS_LINUX_SIGTTOU = 27,
71 MIPS_LINUX_SIGVTALRM = 28,
72 MIPS_LINUX_SIGPROF = 29,
73 MIPS_LINUX_SIGXCPU = 30,
74 MIPS_LINUX_SIGXFSZ = 31,
75
76 MIPS_LINUX_SIGRTMIN = 32,
77 MIPS_LINUX_SIGRT64 = 64,
78 MIPS_LINUX_SIGRTMAX = 127,
79 };
80
81 /* Figure out where the longjmp will land.
82 We expect the first arg to be a pointer to the jmp_buf structure
83 from which we extract the pc (MIPS_LINUX_JB_PC) that we will land
84 at. The pc is copied into PC. This routine returns 1 on
85 success. */
86
87 #define MIPS_LINUX_JB_ELEMENT_SIZE 4
88 #define MIPS_LINUX_JB_PC 0
89
90 static int
91 mips_linux_get_longjmp_target (struct frame_info *frame, CORE_ADDR *pc)
92 {
93 CORE_ADDR jb_addr;
94 struct gdbarch *gdbarch = get_frame_arch (frame);
95 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
96 gdb_byte buf[gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT];
97
98 jb_addr = get_frame_register_unsigned (frame, MIPS_A0_REGNUM);
99
100 if (target_read_memory ((jb_addr
101 + MIPS_LINUX_JB_PC * MIPS_LINUX_JB_ELEMENT_SIZE),
102 buf, gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT))
103 return 0;
104
105 *pc = extract_unsigned_integer (buf,
106 gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT,
107 byte_order);
108
109 return 1;
110 }
111
112 /* Transform the bits comprising a 32-bit register to the right size
113 for regcache_raw_supply(). This is needed when mips_isa_regsize()
114 is 8. */
115
116 static void
117 supply_32bit_reg (struct regcache *regcache, int regnum, const void *addr)
118 {
119 regcache->raw_supply_integer (regnum, (const gdb_byte *) addr, 4, true);
120 }
121
122 /* Unpack an elf_gregset_t into GDB's register cache. */
123
124 void
125 mips_supply_gregset (struct regcache *regcache,
126 const mips_elf_gregset_t *gregsetp)
127 {
128 int regi;
129 const mips_elf_greg_t *regp = *gregsetp;
130 struct gdbarch *gdbarch = get_regcache_arch (regcache);
131
132 for (regi = EF_REG0 + 1; regi <= EF_REG31; regi++)
133 supply_32bit_reg (regcache, regi - EF_REG0, regp + regi);
134
135 if (mips_linux_restart_reg_p (gdbarch))
136 supply_32bit_reg (regcache, MIPS_RESTART_REGNUM, regp + EF_REG0);
137
138 supply_32bit_reg (regcache, mips_regnum (gdbarch)->lo, regp + EF_LO);
139 supply_32bit_reg (regcache, mips_regnum (gdbarch)->hi, regp + EF_HI);
140
141 supply_32bit_reg (regcache, mips_regnum (gdbarch)->pc,
142 regp + EF_CP0_EPC);
143 supply_32bit_reg (regcache, mips_regnum (gdbarch)->badvaddr,
144 regp + EF_CP0_BADVADDR);
145 supply_32bit_reg (regcache, MIPS_PS_REGNUM, regp + EF_CP0_STATUS);
146 supply_32bit_reg (regcache, mips_regnum (gdbarch)->cause,
147 regp + EF_CP0_CAUSE);
148
149 /* Fill the inaccessible zero register with zero. */
150 regcache->raw_supply_zeroed (MIPS_ZERO_REGNUM);
151 }
152
153 static void
154 mips_supply_gregset_wrapper (const struct regset *regset,
155 struct regcache *regcache,
156 int regnum, const void *gregs, size_t len)
157 {
158 gdb_assert (len >= sizeof (mips_elf_gregset_t));
159
160 mips_supply_gregset (regcache, (const mips_elf_gregset_t *)gregs);
161 }
162
163 /* Pack our registers (or one register) into an elf_gregset_t. */
164
165 void
166 mips_fill_gregset (const struct regcache *regcache,
167 mips_elf_gregset_t *gregsetp, int regno)
168 {
169 struct gdbarch *gdbarch = get_regcache_arch (regcache);
170 int regaddr, regi;
171 mips_elf_greg_t *regp = *gregsetp;
172 void *dst;
173
174 if (regno == -1)
175 {
176 memset (regp, 0, sizeof (mips_elf_gregset_t));
177 for (regi = 1; regi < 32; regi++)
178 mips_fill_gregset (regcache, gregsetp, regi);
179 mips_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->lo);
180 mips_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->hi);
181 mips_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->pc);
182 mips_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->badvaddr);
183 mips_fill_gregset (regcache, gregsetp, MIPS_PS_REGNUM);
184 mips_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->cause);
185 mips_fill_gregset (regcache, gregsetp, MIPS_RESTART_REGNUM);
186 return;
187 }
188
189 if (regno > 0 && regno < 32)
190 {
191 dst = regp + regno + EF_REG0;
192 regcache_raw_collect (regcache, regno, dst);
193 return;
194 }
195
196 if (regno == mips_regnum (gdbarch)->lo)
197 regaddr = EF_LO;
198 else if (regno == mips_regnum (gdbarch)->hi)
199 regaddr = EF_HI;
200 else if (regno == mips_regnum (gdbarch)->pc)
201 regaddr = EF_CP0_EPC;
202 else if (regno == mips_regnum (gdbarch)->badvaddr)
203 regaddr = EF_CP0_BADVADDR;
204 else if (regno == MIPS_PS_REGNUM)
205 regaddr = EF_CP0_STATUS;
206 else if (regno == mips_regnum (gdbarch)->cause)
207 regaddr = EF_CP0_CAUSE;
208 else if (mips_linux_restart_reg_p (gdbarch)
209 && regno == MIPS_RESTART_REGNUM)
210 regaddr = EF_REG0;
211 else
212 regaddr = -1;
213
214 if (regaddr != -1)
215 {
216 dst = regp + regaddr;
217 regcache_raw_collect (regcache, regno, dst);
218 }
219 }
220
221 static void
222 mips_fill_gregset_wrapper (const struct regset *regset,
223 const struct regcache *regcache,
224 int regnum, void *gregs, size_t len)
225 {
226 gdb_assert (len >= sizeof (mips_elf_gregset_t));
227
228 mips_fill_gregset (regcache, (mips_elf_gregset_t *)gregs, regnum);
229 }
230
231 /* Likewise, unpack an elf_fpregset_t. */
232
233 void
234 mips_supply_fpregset (struct regcache *regcache,
235 const mips_elf_fpregset_t *fpregsetp)
236 {
237 struct gdbarch *gdbarch = get_regcache_arch (regcache);
238 int regi;
239
240 for (regi = 0; regi < 32; regi++)
241 regcache_raw_supply (regcache,
242 gdbarch_fp0_regnum (gdbarch) + regi,
243 *fpregsetp + regi);
244
245 regcache_raw_supply (regcache,
246 mips_regnum (gdbarch)->fp_control_status,
247 *fpregsetp + 32);
248
249 /* FIXME: how can we supply FCRIR? The ABI doesn't tell us. */
250 regcache->raw_supply_zeroed
251 (mips_regnum (gdbarch)->fp_implementation_revision);
252 }
253
254 static void
255 mips_supply_fpregset_wrapper (const struct regset *regset,
256 struct regcache *regcache,
257 int regnum, const void *gregs, size_t len)
258 {
259 gdb_assert (len >= sizeof (mips_elf_fpregset_t));
260
261 mips_supply_fpregset (regcache, (const mips_elf_fpregset_t *)gregs);
262 }
263
264 /* Likewise, pack one or all floating point registers into an
265 elf_fpregset_t. */
266
267 void
268 mips_fill_fpregset (const struct regcache *regcache,
269 mips_elf_fpregset_t *fpregsetp, int regno)
270 {
271 struct gdbarch *gdbarch = get_regcache_arch (regcache);
272 char *to;
273
274 if ((regno >= gdbarch_fp0_regnum (gdbarch))
275 && (regno < gdbarch_fp0_regnum (gdbarch) + 32))
276 {
277 to = (char *) (*fpregsetp + regno - gdbarch_fp0_regnum (gdbarch));
278 regcache_raw_collect (regcache, regno, to);
279 }
280 else if (regno == mips_regnum (gdbarch)->fp_control_status)
281 {
282 to = (char *) (*fpregsetp + 32);
283 regcache_raw_collect (regcache, regno, to);
284 }
285 else if (regno == -1)
286 {
287 int regi;
288
289 for (regi = 0; regi < 32; regi++)
290 mips_fill_fpregset (regcache, fpregsetp,
291 gdbarch_fp0_regnum (gdbarch) + regi);
292 mips_fill_fpregset (regcache, fpregsetp,
293 mips_regnum (gdbarch)->fp_control_status);
294 }
295 }
296
297 static void
298 mips_fill_fpregset_wrapper (const struct regset *regset,
299 const struct regcache *regcache,
300 int regnum, void *gregs, size_t len)
301 {
302 gdb_assert (len >= sizeof (mips_elf_fpregset_t));
303
304 mips_fill_fpregset (regcache, (mips_elf_fpregset_t *)gregs, regnum);
305 }
306
307 /* Support for 64-bit ABIs. */
308
309 /* Figure out where the longjmp will land.
310 We expect the first arg to be a pointer to the jmp_buf structure
311 from which we extract the pc (MIPS_LINUX_JB_PC) that we will land
312 at. The pc is copied into PC. This routine returns 1 on
313 success. */
314
315 /* Details about jmp_buf. */
316
317 #define MIPS64_LINUX_JB_PC 0
318
319 static int
320 mips64_linux_get_longjmp_target (struct frame_info *frame, CORE_ADDR *pc)
321 {
322 CORE_ADDR jb_addr;
323 struct gdbarch *gdbarch = get_frame_arch (frame);
324 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
325 gdb_byte *buf
326 = (gdb_byte *) alloca (gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT);
327 int element_size = gdbarch_ptr_bit (gdbarch) == 32 ? 4 : 8;
328
329 jb_addr = get_frame_register_unsigned (frame, MIPS_A0_REGNUM);
330
331 if (target_read_memory (jb_addr + MIPS64_LINUX_JB_PC * element_size,
332 buf,
333 gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT))
334 return 0;
335
336 *pc = extract_unsigned_integer (buf,
337 gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT,
338 byte_order);
339
340 return 1;
341 }
342
343 /* Register set support functions. These operate on standard 64-bit
344 regsets, but work whether the target is 32-bit or 64-bit. A 32-bit
345 target will still use the 64-bit format for PTRACE_GETREGS. */
346
347 /* Supply a 64-bit register. */
348
349 static void
350 supply_64bit_reg (struct regcache *regcache, int regnum,
351 const gdb_byte *buf)
352 {
353 struct gdbarch *gdbarch = get_regcache_arch (regcache);
354 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG
355 && register_size (gdbarch, regnum) == 4)
356 regcache_raw_supply (regcache, regnum, buf + 4);
357 else
358 regcache_raw_supply (regcache, regnum, buf);
359 }
360
361 /* Unpack a 64-bit elf_gregset_t into GDB's register cache. */
362
363 void
364 mips64_supply_gregset (struct regcache *regcache,
365 const mips64_elf_gregset_t *gregsetp)
366 {
367 int regi;
368 const mips64_elf_greg_t *regp = *gregsetp;
369 struct gdbarch *gdbarch = get_regcache_arch (regcache);
370
371 for (regi = MIPS64_EF_REG0 + 1; regi <= MIPS64_EF_REG31; regi++)
372 supply_64bit_reg (regcache, regi - MIPS64_EF_REG0,
373 (const gdb_byte *) (regp + regi));
374
375 if (mips_linux_restart_reg_p (gdbarch))
376 supply_64bit_reg (regcache, MIPS_RESTART_REGNUM,
377 (const gdb_byte *) (regp + MIPS64_EF_REG0));
378
379 supply_64bit_reg (regcache, mips_regnum (gdbarch)->lo,
380 (const gdb_byte *) (regp + MIPS64_EF_LO));
381 supply_64bit_reg (regcache, mips_regnum (gdbarch)->hi,
382 (const gdb_byte *) (regp + MIPS64_EF_HI));
383
384 supply_64bit_reg (regcache, mips_regnum (gdbarch)->pc,
385 (const gdb_byte *) (regp + MIPS64_EF_CP0_EPC));
386 supply_64bit_reg (regcache, mips_regnum (gdbarch)->badvaddr,
387 (const gdb_byte *) (regp + MIPS64_EF_CP0_BADVADDR));
388 supply_64bit_reg (regcache, MIPS_PS_REGNUM,
389 (const gdb_byte *) (regp + MIPS64_EF_CP0_STATUS));
390 supply_64bit_reg (regcache, mips_regnum (gdbarch)->cause,
391 (const gdb_byte *) (regp + MIPS64_EF_CP0_CAUSE));
392
393 /* Fill the inaccessible zero register with zero. */
394 regcache->raw_supply_zeroed (MIPS_ZERO_REGNUM);
395 }
396
397 static void
398 mips64_supply_gregset_wrapper (const struct regset *regset,
399 struct regcache *regcache,
400 int regnum, const void *gregs, size_t len)
401 {
402 gdb_assert (len >= sizeof (mips64_elf_gregset_t));
403
404 mips64_supply_gregset (regcache, (const mips64_elf_gregset_t *)gregs);
405 }
406
407 /* Pack our registers (or one register) into a 64-bit elf_gregset_t. */
408
409 void
410 mips64_fill_gregset (const struct regcache *regcache,
411 mips64_elf_gregset_t *gregsetp, int regno)
412 {
413 struct gdbarch *gdbarch = get_regcache_arch (regcache);
414 int regaddr, regi;
415 mips64_elf_greg_t *regp = *gregsetp;
416 void *dst;
417
418 if (regno == -1)
419 {
420 memset (regp, 0, sizeof (mips64_elf_gregset_t));
421 for (regi = 1; regi < 32; regi++)
422 mips64_fill_gregset (regcache, gregsetp, regi);
423 mips64_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->lo);
424 mips64_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->hi);
425 mips64_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->pc);
426 mips64_fill_gregset (regcache, gregsetp,
427 mips_regnum (gdbarch)->badvaddr);
428 mips64_fill_gregset (regcache, gregsetp, MIPS_PS_REGNUM);
429 mips64_fill_gregset (regcache, gregsetp, mips_regnum (gdbarch)->cause);
430 mips64_fill_gregset (regcache, gregsetp, MIPS_RESTART_REGNUM);
431 return;
432 }
433
434 if (regno > 0 && regno < 32)
435 regaddr = regno + MIPS64_EF_REG0;
436 else if (regno == mips_regnum (gdbarch)->lo)
437 regaddr = MIPS64_EF_LO;
438 else if (regno == mips_regnum (gdbarch)->hi)
439 regaddr = MIPS64_EF_HI;
440 else if (regno == mips_regnum (gdbarch)->pc)
441 regaddr = MIPS64_EF_CP0_EPC;
442 else if (regno == mips_regnum (gdbarch)->badvaddr)
443 regaddr = MIPS64_EF_CP0_BADVADDR;
444 else if (regno == MIPS_PS_REGNUM)
445 regaddr = MIPS64_EF_CP0_STATUS;
446 else if (regno == mips_regnum (gdbarch)->cause)
447 regaddr = MIPS64_EF_CP0_CAUSE;
448 else if (mips_linux_restart_reg_p (gdbarch)
449 && regno == MIPS_RESTART_REGNUM)
450 regaddr = MIPS64_EF_REG0;
451 else
452 regaddr = -1;
453
454 if (regaddr != -1)
455 {
456 dst = regp + regaddr;
457 regcache->raw_collect_integer (regno, (gdb_byte *) dst, 8, true);
458 }
459 }
460
461 static void
462 mips64_fill_gregset_wrapper (const struct regset *regset,
463 const struct regcache *regcache,
464 int regnum, void *gregs, size_t len)
465 {
466 gdb_assert (len >= sizeof (mips64_elf_gregset_t));
467
468 mips64_fill_gregset (regcache, (mips64_elf_gregset_t *)gregs, regnum);
469 }
470
471 /* Likewise, unpack an elf_fpregset_t. */
472
473 void
474 mips64_supply_fpregset (struct regcache *regcache,
475 const mips64_elf_fpregset_t *fpregsetp)
476 {
477 struct gdbarch *gdbarch = get_regcache_arch (regcache);
478 int regi;
479
480 /* See mips_linux_o32_sigframe_init for a description of the
481 peculiar FP register layout. */
482 if (register_size (gdbarch, gdbarch_fp0_regnum (gdbarch)) == 4)
483 for (regi = 0; regi < 32; regi++)
484 {
485 const gdb_byte *reg_ptr
486 = (const gdb_byte *) (*fpregsetp + (regi & ~1));
487 if ((gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG) != (regi & 1))
488 reg_ptr += 4;
489 regcache_raw_supply (regcache,
490 gdbarch_fp0_regnum (gdbarch) + regi,
491 reg_ptr);
492 }
493 else
494 for (regi = 0; regi < 32; regi++)
495 regcache_raw_supply (regcache,
496 gdbarch_fp0_regnum (gdbarch) + regi,
497 (const char *) (*fpregsetp + regi));
498
499 supply_32bit_reg (regcache, mips_regnum (gdbarch)->fp_control_status,
500 (const gdb_byte *) (*fpregsetp + 32));
501
502 /* The ABI doesn't tell us how to supply FCRIR, and core dumps don't
503 include it - but the result of PTRACE_GETFPREGS does. The best we
504 can do is to assume that its value is present. */
505 supply_32bit_reg (regcache,
506 mips_regnum (gdbarch)->fp_implementation_revision,
507 (const gdb_byte *) (*fpregsetp + 32) + 4);
508 }
509
510 static void
511 mips64_supply_fpregset_wrapper (const struct regset *regset,
512 struct regcache *regcache,
513 int regnum, const void *gregs, size_t len)
514 {
515 gdb_assert (len >= sizeof (mips64_elf_fpregset_t));
516
517 mips64_supply_fpregset (regcache, (const mips64_elf_fpregset_t *)gregs);
518 }
519
520 /* Likewise, pack one or all floating point registers into an
521 elf_fpregset_t. */
522
523 void
524 mips64_fill_fpregset (const struct regcache *regcache,
525 mips64_elf_fpregset_t *fpregsetp, int regno)
526 {
527 struct gdbarch *gdbarch = get_regcache_arch (regcache);
528 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
529 gdb_byte *to;
530
531 if ((regno >= gdbarch_fp0_regnum (gdbarch))
532 && (regno < gdbarch_fp0_regnum (gdbarch) + 32))
533 {
534 /* See mips_linux_o32_sigframe_init for a description of the
535 peculiar FP register layout. */
536 if (register_size (gdbarch, regno) == 4)
537 {
538 int regi = regno - gdbarch_fp0_regnum (gdbarch);
539
540 to = (gdb_byte *) (*fpregsetp + (regi & ~1));
541 if ((gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG) != (regi & 1))
542 to += 4;
543 regcache_raw_collect (regcache, regno, to);
544 }
545 else
546 {
547 to = (gdb_byte *) (*fpregsetp + regno
548 - gdbarch_fp0_regnum (gdbarch));
549 regcache_raw_collect (regcache, regno, to);
550 }
551 }
552 else if (regno == mips_regnum (gdbarch)->fp_control_status)
553 {
554 to = (gdb_byte *) (*fpregsetp + 32);
555 regcache->raw_collect_integer (regno, to, 4, true);
556 }
557 else if (regno == mips_regnum (gdbarch)->fp_implementation_revision)
558 {
559 to = (gdb_byte *) (*fpregsetp + 32) + 4;
560 regcache->raw_collect_integer (regno, to, 4, true);
561 }
562 else if (regno == -1)
563 {
564 int regi;
565
566 for (regi = 0; regi < 32; regi++)
567 mips64_fill_fpregset (regcache, fpregsetp,
568 gdbarch_fp0_regnum (gdbarch) + regi);
569 mips64_fill_fpregset (regcache, fpregsetp,
570 mips_regnum (gdbarch)->fp_control_status);
571 mips64_fill_fpregset (regcache, fpregsetp,
572 mips_regnum (gdbarch)->fp_implementation_revision);
573 }
574 }
575
576 static void
577 mips64_fill_fpregset_wrapper (const struct regset *regset,
578 const struct regcache *regcache,
579 int regnum, void *gregs, size_t len)
580 {
581 gdb_assert (len >= sizeof (mips64_elf_fpregset_t));
582
583 mips64_fill_fpregset (regcache, (mips64_elf_fpregset_t *)gregs, regnum);
584 }
585
586 static const struct regset mips_linux_gregset =
587 {
588 NULL, mips_supply_gregset_wrapper, mips_fill_gregset_wrapper
589 };
590
591 static const struct regset mips64_linux_gregset =
592 {
593 NULL, mips64_supply_gregset_wrapper, mips64_fill_gregset_wrapper
594 };
595
596 static const struct regset mips_linux_fpregset =
597 {
598 NULL, mips_supply_fpregset_wrapper, mips_fill_fpregset_wrapper
599 };
600
601 static const struct regset mips64_linux_fpregset =
602 {
603 NULL, mips64_supply_fpregset_wrapper, mips64_fill_fpregset_wrapper
604 };
605
606 static void
607 mips_linux_iterate_over_regset_sections (struct gdbarch *gdbarch,
608 iterate_over_regset_sections_cb *cb,
609 void *cb_data,
610 const struct regcache *regcache)
611 {
612 if (register_size (gdbarch, MIPS_ZERO_REGNUM) == 4)
613 {
614 cb (".reg", sizeof (mips_elf_gregset_t), &mips_linux_gregset,
615 NULL, cb_data);
616 cb (".reg2", sizeof (mips_elf_fpregset_t), &mips_linux_fpregset,
617 NULL, cb_data);
618 }
619 else
620 {
621 cb (".reg", sizeof (mips64_elf_gregset_t), &mips64_linux_gregset,
622 NULL, cb_data);
623 cb (".reg2", sizeof (mips64_elf_fpregset_t), &mips64_linux_fpregset,
624 NULL, cb_data);
625 }
626 }
627
628 static const struct target_desc *
629 mips_linux_core_read_description (struct gdbarch *gdbarch,
630 struct target_ops *target,
631 bfd *abfd)
632 {
633 asection *section = bfd_get_section_by_name (abfd, ".reg");
634 if (! section)
635 return NULL;
636
637 switch (bfd_section_size (abfd, section))
638 {
639 case sizeof (mips_elf_gregset_t):
640 return mips_tdesc_gp32;
641
642 case sizeof (mips64_elf_gregset_t):
643 return mips_tdesc_gp64;
644
645 default:
646 return NULL;
647 }
648 }
649
650
651 /* Check the code at PC for a dynamic linker lazy resolution stub.
652 GNU ld for MIPS has put lazy resolution stubs into a ".MIPS.stubs"
653 section uniformly since version 2.15. If the pc is in that section,
654 then we are in such a stub. Before that ".stub" was used in 32-bit
655 ELF binaries, however we do not bother checking for that since we
656 have never had and that case should be extremely rare these days.
657 Instead we pattern-match on the code generated by GNU ld. They look
658 like this:
659
660 lw t9,0x8010(gp)
661 addu t7,ra
662 jalr t9,ra
663 addiu t8,zero,INDEX
664
665 (with the appropriate doubleword instructions for N64). As any lazy
666 resolution stubs in microMIPS binaries will always be in a
667 ".MIPS.stubs" section we only ever verify standard MIPS patterns. */
668
669 static int
670 mips_linux_in_dynsym_stub (CORE_ADDR pc)
671 {
672 gdb_byte buf[28], *p;
673 ULONGEST insn, insn1;
674 int n64 = (mips_abi (target_gdbarch ()) == MIPS_ABI_N64);
675 enum bfd_endian byte_order = gdbarch_byte_order (target_gdbarch ());
676
677 if (in_mips_stubs_section (pc))
678 return 1;
679
680 read_memory (pc - 12, buf, 28);
681
682 if (n64)
683 {
684 /* ld t9,0x8010(gp) */
685 insn1 = 0xdf998010;
686 }
687 else
688 {
689 /* lw t9,0x8010(gp) */
690 insn1 = 0x8f998010;
691 }
692
693 p = buf + 12;
694 while (p >= buf)
695 {
696 insn = extract_unsigned_integer (p, 4, byte_order);
697 if (insn == insn1)
698 break;
699 p -= 4;
700 }
701 if (p < buf)
702 return 0;
703
704 insn = extract_unsigned_integer (p + 4, 4, byte_order);
705 if (n64)
706 {
707 /* 'daddu t7,ra' or 'or t7, ra, zero'*/
708 if (insn != 0x03e0782d || insn != 0x03e07825)
709 return 0;
710
711 }
712 else
713 {
714 /* 'addu t7,ra' or 'or t7, ra, zero'*/
715 if (insn != 0x03e07821 || insn != 0x03e07825)
716 return 0;
717
718 }
719
720 insn = extract_unsigned_integer (p + 8, 4, byte_order);
721 /* jalr t9,ra */
722 if (insn != 0x0320f809)
723 return 0;
724
725 insn = extract_unsigned_integer (p + 12, 4, byte_order);
726 if (n64)
727 {
728 /* daddiu t8,zero,0 */
729 if ((insn & 0xffff0000) != 0x64180000)
730 return 0;
731 }
732 else
733 {
734 /* addiu t8,zero,0 */
735 if ((insn & 0xffff0000) != 0x24180000)
736 return 0;
737 }
738
739 return 1;
740 }
741
742 /* Return non-zero iff PC belongs to the dynamic linker resolution
743 code, a PLT entry, or a lazy binding stub. */
744
745 static int
746 mips_linux_in_dynsym_resolve_code (CORE_ADDR pc)
747 {
748 /* Check whether PC is in the dynamic linker. This also checks
749 whether it is in the .plt section, used by non-PIC executables. */
750 if (svr4_in_dynsym_resolve_code (pc))
751 return 1;
752
753 /* Likewise for the stubs. They live in the .MIPS.stubs section these
754 days, so we check if the PC is within, than fall back to a pattern
755 match. */
756 if (mips_linux_in_dynsym_stub (pc))
757 return 1;
758
759 return 0;
760 }
761
762 /* See the comments for SKIP_SOLIB_RESOLVER at the top of infrun.c,
763 and glibc_skip_solib_resolver in glibc-tdep.c. The normal glibc
764 implementation of this triggers at "fixup" from the same objfile as
765 "_dl_runtime_resolve"; MIPS GNU/Linux can trigger at
766 "__dl_runtime_resolve" directly. An unresolved lazy binding
767 stub will point to _dl_runtime_resolve, which will first call
768 __dl_runtime_resolve, and then pass control to the resolved
769 function. */
770
771 static CORE_ADDR
772 mips_linux_skip_resolver (struct gdbarch *gdbarch, CORE_ADDR pc)
773 {
774 struct bound_minimal_symbol resolver;
775
776 resolver = lookup_minimal_symbol ("__dl_runtime_resolve", NULL, NULL);
777
778 if (resolver.minsym && BMSYMBOL_VALUE_ADDRESS (resolver) == pc)
779 return frame_unwind_caller_pc (get_current_frame ());
780
781 return glibc_skip_solib_resolver (gdbarch, pc);
782 }
783
784 /* Signal trampoline support. There are four supported layouts for a
785 signal frame: o32 sigframe, o32 rt_sigframe, n32 rt_sigframe, and
786 n64 rt_sigframe. We handle them all independently; not the most
787 efficient way, but simplest. First, declare all the unwinders. */
788
789 static void mips_linux_o32_sigframe_init (const struct tramp_frame *self,
790 struct frame_info *this_frame,
791 struct trad_frame_cache *this_cache,
792 CORE_ADDR func);
793
794 static void mips_linux_n32n64_sigframe_init (const struct tramp_frame *self,
795 struct frame_info *this_frame,
796 struct trad_frame_cache *this_cache,
797 CORE_ADDR func);
798
799 static int mips_linux_sigframe_validate (const struct tramp_frame *self,
800 struct frame_info *this_frame,
801 CORE_ADDR *pc);
802
803 static int micromips_linux_sigframe_validate (const struct tramp_frame *self,
804 struct frame_info *this_frame,
805 CORE_ADDR *pc);
806
807 #define MIPS_NR_LINUX 4000
808 #define MIPS_NR_N64_LINUX 5000
809 #define MIPS_NR_N32_LINUX 6000
810
811 #define MIPS_NR_sigreturn MIPS_NR_LINUX + 119
812 #define MIPS_NR_rt_sigreturn MIPS_NR_LINUX + 193
813 #define MIPS_NR_N64_rt_sigreturn MIPS_NR_N64_LINUX + 211
814 #define MIPS_NR_N32_rt_sigreturn MIPS_NR_N32_LINUX + 211
815
816 #define MIPS_INST_LI_V0_SIGRETURN 0x24020000 + MIPS_NR_sigreturn
817 #define MIPS_INST_LI_V0_RT_SIGRETURN 0x24020000 + MIPS_NR_rt_sigreturn
818 #define MIPS_INST_LI_V0_N64_RT_SIGRETURN 0x24020000 + MIPS_NR_N64_rt_sigreturn
819 #define MIPS_INST_LI_V0_N32_RT_SIGRETURN 0x24020000 + MIPS_NR_N32_rt_sigreturn
820 #define MIPS_INST_SYSCALL 0x0000000c
821
822 #define MICROMIPS_INST_LI_V0 0x3040
823 #define MICROMIPS_INST_POOL32A 0x0000
824 #define MICROMIPS_INST_SYSCALL 0x8b7c
825
826 static const struct tramp_frame mips_linux_o32_sigframe = {
827 SIGTRAMP_FRAME,
828 4,
829 {
830 { MIPS_INST_LI_V0_SIGRETURN, -1 },
831 { MIPS_INST_SYSCALL, -1 },
832 { TRAMP_SENTINEL_INSN, -1 }
833 },
834 mips_linux_o32_sigframe_init,
835 mips_linux_sigframe_validate
836 };
837
838 static const struct tramp_frame mips_linux_o32_rt_sigframe = {
839 SIGTRAMP_FRAME,
840 4,
841 {
842 { MIPS_INST_LI_V0_RT_SIGRETURN, -1 },
843 { MIPS_INST_SYSCALL, -1 },
844 { TRAMP_SENTINEL_INSN, -1 } },
845 mips_linux_o32_sigframe_init,
846 mips_linux_sigframe_validate
847 };
848
849 static const struct tramp_frame mips_linux_n32_rt_sigframe = {
850 SIGTRAMP_FRAME,
851 4,
852 {
853 { MIPS_INST_LI_V0_N32_RT_SIGRETURN, -1 },
854 { MIPS_INST_SYSCALL, -1 },
855 { TRAMP_SENTINEL_INSN, -1 }
856 },
857 mips_linux_n32n64_sigframe_init,
858 mips_linux_sigframe_validate
859 };
860
861 static const struct tramp_frame mips_linux_n64_rt_sigframe = {
862 SIGTRAMP_FRAME,
863 4,
864 {
865 { MIPS_INST_LI_V0_N64_RT_SIGRETURN, -1 },
866 { MIPS_INST_SYSCALL, -1 },
867 { TRAMP_SENTINEL_INSN, -1 }
868 },
869 mips_linux_n32n64_sigframe_init,
870 mips_linux_sigframe_validate
871 };
872
873 static const struct tramp_frame micromips_linux_o32_sigframe = {
874 SIGTRAMP_FRAME,
875 2,
876 {
877 { MICROMIPS_INST_LI_V0, -1 },
878 { MIPS_NR_sigreturn, -1 },
879 { MICROMIPS_INST_POOL32A, -1 },
880 { MICROMIPS_INST_SYSCALL, -1 },
881 { TRAMP_SENTINEL_INSN, -1 }
882 },
883 mips_linux_o32_sigframe_init,
884 micromips_linux_sigframe_validate
885 };
886
887 static const struct tramp_frame micromips_linux_o32_rt_sigframe = {
888 SIGTRAMP_FRAME,
889 2,
890 {
891 { MICROMIPS_INST_LI_V0, -1 },
892 { MIPS_NR_rt_sigreturn, -1 },
893 { MICROMIPS_INST_POOL32A, -1 },
894 { MICROMIPS_INST_SYSCALL, -1 },
895 { TRAMP_SENTINEL_INSN, -1 }
896 },
897 mips_linux_o32_sigframe_init,
898 micromips_linux_sigframe_validate
899 };
900
901 static const struct tramp_frame micromips_linux_n32_rt_sigframe = {
902 SIGTRAMP_FRAME,
903 2,
904 {
905 { MICROMIPS_INST_LI_V0, -1 },
906 { MIPS_NR_N32_rt_sigreturn, -1 },
907 { MICROMIPS_INST_POOL32A, -1 },
908 { MICROMIPS_INST_SYSCALL, -1 },
909 { TRAMP_SENTINEL_INSN, -1 }
910 },
911 mips_linux_n32n64_sigframe_init,
912 micromips_linux_sigframe_validate
913 };
914
915 static const struct tramp_frame micromips_linux_n64_rt_sigframe = {
916 SIGTRAMP_FRAME,
917 2,
918 {
919 { MICROMIPS_INST_LI_V0, -1 },
920 { MIPS_NR_N64_rt_sigreturn, -1 },
921 { MICROMIPS_INST_POOL32A, -1 },
922 { MICROMIPS_INST_SYSCALL, -1 },
923 { TRAMP_SENTINEL_INSN, -1 }
924 },
925 mips_linux_n32n64_sigframe_init,
926 micromips_linux_sigframe_validate
927 };
928
929 /* *INDENT-OFF* */
930 /* The unwinder for o32 signal frames. The legacy structures look
931 like this:
932
933 struct sigframe {
934 u32 sf_ass[4]; [argument save space for o32]
935 u32 sf_code[2]; [signal trampoline or fill]
936 struct sigcontext sf_sc;
937 sigset_t sf_mask;
938 };
939
940 Pre-2.6.12 sigcontext:
941
942 struct sigcontext {
943 unsigned int sc_regmask; [Unused]
944 unsigned int sc_status;
945 unsigned long long sc_pc;
946 unsigned long long sc_regs[32];
947 unsigned long long sc_fpregs[32];
948 unsigned int sc_ownedfp;
949 unsigned int sc_fpc_csr;
950 unsigned int sc_fpc_eir; [Unused]
951 unsigned int sc_used_math;
952 unsigned int sc_ssflags; [Unused]
953 [Alignment hole of four bytes]
954 unsigned long long sc_mdhi;
955 unsigned long long sc_mdlo;
956
957 unsigned int sc_cause; [Unused]
958 unsigned int sc_badvaddr; [Unused]
959
960 unsigned long sc_sigset[4]; [kernel's sigset_t]
961 };
962
963 Post-2.6.12 sigcontext (SmartMIPS/DSP support added):
964
965 struct sigcontext {
966 unsigned int sc_regmask; [Unused]
967 unsigned int sc_status; [Unused]
968 unsigned long long sc_pc;
969 unsigned long long sc_regs[32];
970 unsigned long long sc_fpregs[32];
971 unsigned int sc_acx;
972 unsigned int sc_fpc_csr;
973 unsigned int sc_fpc_eir; [Unused]
974 unsigned int sc_used_math;
975 unsigned int sc_dsp;
976 [Alignment hole of four bytes]
977 unsigned long long sc_mdhi;
978 unsigned long long sc_mdlo;
979 unsigned long sc_hi1;
980 unsigned long sc_lo1;
981 unsigned long sc_hi2;
982 unsigned long sc_lo2;
983 unsigned long sc_hi3;
984 unsigned long sc_lo3;
985 };
986
987 The RT signal frames look like this:
988
989 struct rt_sigframe {
990 u32 rs_ass[4]; [argument save space for o32]
991 u32 rs_code[2] [signal trampoline or fill]
992 struct siginfo rs_info;
993 struct ucontext rs_uc;
994 };
995
996 struct ucontext {
997 unsigned long uc_flags;
998 struct ucontext *uc_link;
999 stack_t uc_stack;
1000 [Alignment hole of four bytes]
1001 struct sigcontext uc_mcontext;
1002 sigset_t uc_sigmask;
1003 }; */
1004 /* *INDENT-ON* */
1005
1006 #define SIGFRAME_SIGCONTEXT_OFFSET (6 * 4)
1007
1008 #define RTSIGFRAME_SIGINFO_SIZE 128
1009 #define STACK_T_SIZE (3 * 4)
1010 #define UCONTEXT_SIGCONTEXT_OFFSET (2 * 4 + STACK_T_SIZE + 4)
1011 #define RTSIGFRAME_SIGCONTEXT_OFFSET (SIGFRAME_SIGCONTEXT_OFFSET \
1012 + RTSIGFRAME_SIGINFO_SIZE \
1013 + UCONTEXT_SIGCONTEXT_OFFSET)
1014
1015 #define SIGCONTEXT_PC (1 * 8)
1016 #define SIGCONTEXT_REGS (2 * 8)
1017 #define SIGCONTEXT_FPREGS (34 * 8)
1018 #define SIGCONTEXT_FPCSR (66 * 8 + 4)
1019 #define SIGCONTEXT_DSPCTL (68 * 8 + 0)
1020 #define SIGCONTEXT_HI (69 * 8)
1021 #define SIGCONTEXT_LO (70 * 8)
1022 #define SIGCONTEXT_CAUSE (71 * 8 + 0)
1023 #define SIGCONTEXT_BADVADDR (71 * 8 + 4)
1024 #define SIGCONTEXT_HI1 (71 * 8 + 0)
1025 #define SIGCONTEXT_LO1 (71 * 8 + 4)
1026 #define SIGCONTEXT_HI2 (72 * 8 + 0)
1027 #define SIGCONTEXT_LO2 (72 * 8 + 4)
1028 #define SIGCONTEXT_HI3 (73 * 8 + 0)
1029 #define SIGCONTEXT_LO3 (73 * 8 + 4)
1030
1031 #define SIGCONTEXT_REG_SIZE 8
1032
1033 static void
1034 mips_linux_o32_sigframe_init (const struct tramp_frame *self,
1035 struct frame_info *this_frame,
1036 struct trad_frame_cache *this_cache,
1037 CORE_ADDR func)
1038 {
1039 struct gdbarch *gdbarch = get_frame_arch (this_frame);
1040 int ireg;
1041 CORE_ADDR frame_sp = get_frame_sp (this_frame);
1042 CORE_ADDR sigcontext_base;
1043 const struct mips_regnum *regs = mips_regnum (gdbarch);
1044 CORE_ADDR regs_base;
1045
1046 if (self == &mips_linux_o32_sigframe
1047 || self == &micromips_linux_o32_sigframe)
1048 sigcontext_base = frame_sp + SIGFRAME_SIGCONTEXT_OFFSET;
1049 else
1050 sigcontext_base = frame_sp + RTSIGFRAME_SIGCONTEXT_OFFSET;
1051
1052 /* I'm not proud of this hack. Eventually we will have the
1053 infrastructure to indicate the size of saved registers on a
1054 per-frame basis, but right now we don't; the kernel saves eight
1055 bytes but we only want four. Use regs_base to access any
1056 64-bit fields. */
1057 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
1058 regs_base = sigcontext_base + 4;
1059 else
1060 regs_base = sigcontext_base;
1061
1062 if (mips_linux_restart_reg_p (gdbarch))
1063 trad_frame_set_reg_addr (this_cache,
1064 (MIPS_RESTART_REGNUM
1065 + gdbarch_num_regs (gdbarch)),
1066 regs_base + SIGCONTEXT_REGS);
1067
1068 for (ireg = 1; ireg < 32; ireg++)
1069 trad_frame_set_reg_addr (this_cache,
1070 (ireg + MIPS_ZERO_REGNUM
1071 + gdbarch_num_regs (gdbarch)),
1072 (regs_base + SIGCONTEXT_REGS
1073 + ireg * SIGCONTEXT_REG_SIZE));
1074
1075 /* The way that floating point registers are saved, unfortunately,
1076 depends on the architecture the kernel is built for. For the r3000 and
1077 tx39, four bytes of each register are at the beginning of each of the
1078 32 eight byte slots. For everything else, the registers are saved
1079 using double precision; only the even-numbered slots are initialized,
1080 and the high bits are the odd-numbered register. Assume the latter
1081 layout, since we can't tell, and it's much more common. Which bits are
1082 the "high" bits depends on endianness. */
1083 for (ireg = 0; ireg < 32; ireg++)
1084 if ((gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG) != (ireg & 1))
1085 trad_frame_set_reg_addr (this_cache,
1086 ireg + regs->fp0 + gdbarch_num_regs (gdbarch),
1087 (sigcontext_base + SIGCONTEXT_FPREGS + 4
1088 + (ireg & ~1) * SIGCONTEXT_REG_SIZE));
1089 else
1090 trad_frame_set_reg_addr (this_cache,
1091 ireg + regs->fp0 + gdbarch_num_regs (gdbarch),
1092 (sigcontext_base + SIGCONTEXT_FPREGS
1093 + (ireg & ~1) * SIGCONTEXT_REG_SIZE));
1094
1095 trad_frame_set_reg_addr (this_cache,
1096 regs->pc + gdbarch_num_regs (gdbarch),
1097 regs_base + SIGCONTEXT_PC);
1098
1099 trad_frame_set_reg_addr (this_cache,
1100 (regs->fp_control_status
1101 + gdbarch_num_regs (gdbarch)),
1102 sigcontext_base + SIGCONTEXT_FPCSR);
1103
1104 if (regs->dspctl != -1)
1105 trad_frame_set_reg_addr (this_cache,
1106 regs->dspctl + gdbarch_num_regs (gdbarch),
1107 sigcontext_base + SIGCONTEXT_DSPCTL);
1108
1109 trad_frame_set_reg_addr (this_cache,
1110 regs->hi + gdbarch_num_regs (gdbarch),
1111 regs_base + SIGCONTEXT_HI);
1112 trad_frame_set_reg_addr (this_cache,
1113 regs->lo + gdbarch_num_regs (gdbarch),
1114 regs_base + SIGCONTEXT_LO);
1115
1116 if (regs->dspacc != -1)
1117 {
1118 trad_frame_set_reg_addr (this_cache,
1119 regs->dspacc + 0 + gdbarch_num_regs (gdbarch),
1120 sigcontext_base + SIGCONTEXT_HI1);
1121 trad_frame_set_reg_addr (this_cache,
1122 regs->dspacc + 1 + gdbarch_num_regs (gdbarch),
1123 sigcontext_base + SIGCONTEXT_LO1);
1124 trad_frame_set_reg_addr (this_cache,
1125 regs->dspacc + 2 + gdbarch_num_regs (gdbarch),
1126 sigcontext_base + SIGCONTEXT_HI2);
1127 trad_frame_set_reg_addr (this_cache,
1128 regs->dspacc + 3 + gdbarch_num_regs (gdbarch),
1129 sigcontext_base + SIGCONTEXT_LO2);
1130 trad_frame_set_reg_addr (this_cache,
1131 regs->dspacc + 4 + gdbarch_num_regs (gdbarch),
1132 sigcontext_base + SIGCONTEXT_HI3);
1133 trad_frame_set_reg_addr (this_cache,
1134 regs->dspacc + 5 + gdbarch_num_regs (gdbarch),
1135 sigcontext_base + SIGCONTEXT_LO3);
1136 }
1137 else
1138 {
1139 trad_frame_set_reg_addr (this_cache,
1140 regs->cause + gdbarch_num_regs (gdbarch),
1141 sigcontext_base + SIGCONTEXT_CAUSE);
1142 trad_frame_set_reg_addr (this_cache,
1143 regs->badvaddr + gdbarch_num_regs (gdbarch),
1144 sigcontext_base + SIGCONTEXT_BADVADDR);
1145 }
1146
1147 /* Choice of the bottom of the sigframe is somewhat arbitrary. */
1148 trad_frame_set_id (this_cache, frame_id_build (frame_sp, func));
1149 }
1150
1151 /* *INDENT-OFF* */
1152 /* For N32/N64 things look different. There is no non-rt signal frame.
1153
1154 struct rt_sigframe_n32 {
1155 u32 rs_ass[4]; [ argument save space for o32 ]
1156 u32 rs_code[2]; [ signal trampoline or fill ]
1157 struct siginfo rs_info;
1158 struct ucontextn32 rs_uc;
1159 };
1160
1161 struct ucontextn32 {
1162 u32 uc_flags;
1163 s32 uc_link;
1164 stack32_t uc_stack;
1165 struct sigcontext uc_mcontext;
1166 sigset_t uc_sigmask; [ mask last for extensibility ]
1167 };
1168
1169 struct rt_sigframe {
1170 u32 rs_ass[4]; [ argument save space for o32 ]
1171 u32 rs_code[2]; [ signal trampoline ]
1172 struct siginfo rs_info;
1173 struct ucontext rs_uc;
1174 };
1175
1176 struct ucontext {
1177 unsigned long uc_flags;
1178 struct ucontext *uc_link;
1179 stack_t uc_stack;
1180 struct sigcontext uc_mcontext;
1181 sigset_t uc_sigmask; [ mask last for extensibility ]
1182 };
1183
1184 And the sigcontext is different (this is for both n32 and n64):
1185
1186 struct sigcontext {
1187 unsigned long long sc_regs[32];
1188 unsigned long long sc_fpregs[32];
1189 unsigned long long sc_mdhi;
1190 unsigned long long sc_hi1;
1191 unsigned long long sc_hi2;
1192 unsigned long long sc_hi3;
1193 unsigned long long sc_mdlo;
1194 unsigned long long sc_lo1;
1195 unsigned long long sc_lo2;
1196 unsigned long long sc_lo3;
1197 unsigned long long sc_pc;
1198 unsigned int sc_fpc_csr;
1199 unsigned int sc_used_math;
1200 unsigned int sc_dsp;
1201 unsigned int sc_reserved;
1202 };
1203
1204 That is the post-2.6.12 definition of the 64-bit sigcontext; before
1205 then, there were no hi1-hi3 or lo1-lo3. Cause and badvaddr were
1206 included too. */
1207 /* *INDENT-ON* */
1208
1209 #define N32_STACK_T_SIZE STACK_T_SIZE
1210 #define N64_STACK_T_SIZE (2 * 8 + 4)
1211 #define N32_UCONTEXT_SIGCONTEXT_OFFSET (2 * 4 + N32_STACK_T_SIZE + 4)
1212 #define N64_UCONTEXT_SIGCONTEXT_OFFSET (2 * 8 + N64_STACK_T_SIZE + 4)
1213 #define N32_SIGFRAME_SIGCONTEXT_OFFSET (SIGFRAME_SIGCONTEXT_OFFSET \
1214 + RTSIGFRAME_SIGINFO_SIZE \
1215 + N32_UCONTEXT_SIGCONTEXT_OFFSET)
1216 #define N64_SIGFRAME_SIGCONTEXT_OFFSET (SIGFRAME_SIGCONTEXT_OFFSET \
1217 + RTSIGFRAME_SIGINFO_SIZE \
1218 + N64_UCONTEXT_SIGCONTEXT_OFFSET)
1219
1220 #define N64_SIGCONTEXT_REGS (0 * 8)
1221 #define N64_SIGCONTEXT_FPREGS (32 * 8)
1222 #define N64_SIGCONTEXT_HI (64 * 8)
1223 #define N64_SIGCONTEXT_HI1 (65 * 8)
1224 #define N64_SIGCONTEXT_HI2 (66 * 8)
1225 #define N64_SIGCONTEXT_HI3 (67 * 8)
1226 #define N64_SIGCONTEXT_LO (68 * 8)
1227 #define N64_SIGCONTEXT_LO1 (69 * 8)
1228 #define N64_SIGCONTEXT_LO2 (70 * 8)
1229 #define N64_SIGCONTEXT_LO3 (71 * 8)
1230 #define N64_SIGCONTEXT_PC (72 * 8)
1231 #define N64_SIGCONTEXT_FPCSR (73 * 8 + 0)
1232 #define N64_SIGCONTEXT_DSPCTL (74 * 8 + 0)
1233
1234 #define N64_SIGCONTEXT_REG_SIZE 8
1235
1236 static void
1237 mips_linux_n32n64_sigframe_init (const struct tramp_frame *self,
1238 struct frame_info *this_frame,
1239 struct trad_frame_cache *this_cache,
1240 CORE_ADDR func)
1241 {
1242 struct gdbarch *gdbarch = get_frame_arch (this_frame);
1243 int ireg;
1244 CORE_ADDR frame_sp = get_frame_sp (this_frame);
1245 CORE_ADDR sigcontext_base;
1246 const struct mips_regnum *regs = mips_regnum (gdbarch);
1247
1248 if (self == &mips_linux_n32_rt_sigframe
1249 || self == &micromips_linux_n32_rt_sigframe)
1250 sigcontext_base = frame_sp + N32_SIGFRAME_SIGCONTEXT_OFFSET;
1251 else
1252 sigcontext_base = frame_sp + N64_SIGFRAME_SIGCONTEXT_OFFSET;
1253
1254 if (mips_linux_restart_reg_p (gdbarch))
1255 trad_frame_set_reg_addr (this_cache,
1256 (MIPS_RESTART_REGNUM
1257 + gdbarch_num_regs (gdbarch)),
1258 sigcontext_base + N64_SIGCONTEXT_REGS);
1259
1260 for (ireg = 1; ireg < 32; ireg++)
1261 trad_frame_set_reg_addr (this_cache,
1262 (ireg + MIPS_ZERO_REGNUM
1263 + gdbarch_num_regs (gdbarch)),
1264 (sigcontext_base + N64_SIGCONTEXT_REGS
1265 + ireg * N64_SIGCONTEXT_REG_SIZE));
1266
1267 for (ireg = 0; ireg < 32; ireg++)
1268 trad_frame_set_reg_addr (this_cache,
1269 ireg + regs->fp0 + gdbarch_num_regs (gdbarch),
1270 (sigcontext_base + N64_SIGCONTEXT_FPREGS
1271 + ireg * N64_SIGCONTEXT_REG_SIZE));
1272
1273 trad_frame_set_reg_addr (this_cache,
1274 regs->pc + gdbarch_num_regs (gdbarch),
1275 sigcontext_base + N64_SIGCONTEXT_PC);
1276
1277 trad_frame_set_reg_addr (this_cache,
1278 (regs->fp_control_status
1279 + gdbarch_num_regs (gdbarch)),
1280 sigcontext_base + N64_SIGCONTEXT_FPCSR);
1281
1282 trad_frame_set_reg_addr (this_cache,
1283 regs->hi + gdbarch_num_regs (gdbarch),
1284 sigcontext_base + N64_SIGCONTEXT_HI);
1285 trad_frame_set_reg_addr (this_cache,
1286 regs->lo + gdbarch_num_regs (gdbarch),
1287 sigcontext_base + N64_SIGCONTEXT_LO);
1288
1289 if (regs->dspacc != -1)
1290 {
1291 trad_frame_set_reg_addr (this_cache,
1292 regs->dspacc + 0 + gdbarch_num_regs (gdbarch),
1293 sigcontext_base + N64_SIGCONTEXT_HI1);
1294 trad_frame_set_reg_addr (this_cache,
1295 regs->dspacc + 1 + gdbarch_num_regs (gdbarch),
1296 sigcontext_base + N64_SIGCONTEXT_LO1);
1297 trad_frame_set_reg_addr (this_cache,
1298 regs->dspacc + 2 + gdbarch_num_regs (gdbarch),
1299 sigcontext_base + N64_SIGCONTEXT_HI2);
1300 trad_frame_set_reg_addr (this_cache,
1301 regs->dspacc + 3 + gdbarch_num_regs (gdbarch),
1302 sigcontext_base + N64_SIGCONTEXT_LO2);
1303 trad_frame_set_reg_addr (this_cache,
1304 regs->dspacc + 4 + gdbarch_num_regs (gdbarch),
1305 sigcontext_base + N64_SIGCONTEXT_HI3);
1306 trad_frame_set_reg_addr (this_cache,
1307 regs->dspacc + 5 + gdbarch_num_regs (gdbarch),
1308 sigcontext_base + N64_SIGCONTEXT_LO3);
1309 }
1310 if (regs->dspctl != -1)
1311 trad_frame_set_reg_addr (this_cache,
1312 regs->dspctl + gdbarch_num_regs (gdbarch),
1313 sigcontext_base + N64_SIGCONTEXT_DSPCTL);
1314
1315 /* Choice of the bottom of the sigframe is somewhat arbitrary. */
1316 trad_frame_set_id (this_cache, frame_id_build (frame_sp, func));
1317 }
1318
1319 /* Implement struct tramp_frame's "validate" method for standard MIPS code. */
1320
1321 static int
1322 mips_linux_sigframe_validate (const struct tramp_frame *self,
1323 struct frame_info *this_frame,
1324 CORE_ADDR *pc)
1325 {
1326 return mips_pc_is_mips (*pc);
1327 }
1328
1329 /* Implement struct tramp_frame's "validate" method for microMIPS code. */
1330
1331 static int
1332 micromips_linux_sigframe_validate (const struct tramp_frame *self,
1333 struct frame_info *this_frame,
1334 CORE_ADDR *pc)
1335 {
1336 if (mips_pc_is_micromips (get_frame_arch (this_frame), *pc))
1337 {
1338 *pc = mips_unmake_compact_addr (*pc);
1339 return 1;
1340 }
1341 else
1342 return 0;
1343 }
1344
1345 /* Implement the "write_pc" gdbarch method. */
1346
1347 static void
1348 mips_linux_write_pc (struct regcache *regcache, CORE_ADDR pc)
1349 {
1350 struct gdbarch *gdbarch = get_regcache_arch (regcache);
1351
1352 mips_write_pc (regcache, pc);
1353
1354 /* Clear the syscall restart flag. */
1355 if (mips_linux_restart_reg_p (gdbarch))
1356 regcache_cooked_write_unsigned (regcache, MIPS_RESTART_REGNUM, 0);
1357 }
1358
1359 /* Return 1 if MIPS_RESTART_REGNUM is usable. */
1360
1361 int
1362 mips_linux_restart_reg_p (struct gdbarch *gdbarch)
1363 {
1364 /* If we do not have a target description with registers, then
1365 MIPS_RESTART_REGNUM will not be included in the register set. */
1366 if (!tdesc_has_registers (gdbarch_target_desc (gdbarch)))
1367 return 0;
1368
1369 /* If we do, then MIPS_RESTART_REGNUM is safe to check; it will
1370 either be GPR-sized or missing. */
1371 return register_size (gdbarch, MIPS_RESTART_REGNUM) > 0;
1372 }
1373
1374 /* When FRAME is at a syscall instruction, return the PC of the next
1375 instruction to be executed. */
1376
1377 static CORE_ADDR
1378 mips_linux_syscall_next_pc (struct frame_info *frame)
1379 {
1380 CORE_ADDR pc = get_frame_pc (frame);
1381 ULONGEST v0 = get_frame_register_unsigned (frame, MIPS_V0_REGNUM);
1382
1383 /* If we are about to make a sigreturn syscall, use the unwinder to
1384 decode the signal frame. */
1385 if (v0 == MIPS_NR_sigreturn
1386 || v0 == MIPS_NR_rt_sigreturn
1387 || v0 == MIPS_NR_N64_rt_sigreturn
1388 || v0 == MIPS_NR_N32_rt_sigreturn)
1389 return frame_unwind_caller_pc (get_current_frame ());
1390
1391 return pc + 4;
1392 }
1393
1394 /* Return the current system call's number present in the
1395 v0 register. When the function fails, it returns -1. */
1396
1397 static LONGEST
1398 mips_linux_get_syscall_number (struct gdbarch *gdbarch,
1399 ptid_t ptid)
1400 {
1401 struct regcache *regcache = get_thread_regcache (ptid);
1402 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
1403 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
1404 int regsize = register_size (gdbarch, MIPS_V0_REGNUM);
1405 /* The content of a register */
1406 gdb_byte buf[8];
1407 /* The result */
1408 LONGEST ret;
1409
1410 /* Make sure we're in a known ABI */
1411 gdb_assert (tdep->mips_abi == MIPS_ABI_O32
1412 || tdep->mips_abi == MIPS_ABI_N32
1413 || tdep->mips_abi == MIPS_ABI_N64);
1414
1415 gdb_assert (regsize <= sizeof (buf));
1416
1417 /* Getting the system call number from the register.
1418 syscall number is in v0 or $2. */
1419 regcache_cooked_read (regcache, MIPS_V0_REGNUM, buf);
1420
1421 ret = extract_signed_integer (buf, regsize, byte_order);
1422
1423 return ret;
1424 }
1425
1426 /* Implementation of `gdbarch_gdb_signal_to_target', as defined in
1427 gdbarch.h. */
1428
1429 static int
1430 mips_gdb_signal_to_target (struct gdbarch *gdbarch,
1431 enum gdb_signal signal)
1432 {
1433 switch (signal)
1434 {
1435 case GDB_SIGNAL_EMT:
1436 return MIPS_LINUX_SIGEMT;
1437
1438 case GDB_SIGNAL_BUS:
1439 return MIPS_LINUX_SIGBUS;
1440
1441 case GDB_SIGNAL_SYS:
1442 return MIPS_LINUX_SIGSYS;
1443
1444 case GDB_SIGNAL_USR1:
1445 return MIPS_LINUX_SIGUSR1;
1446
1447 case GDB_SIGNAL_USR2:
1448 return MIPS_LINUX_SIGUSR2;
1449
1450 case GDB_SIGNAL_CHLD:
1451 return MIPS_LINUX_SIGCHLD;
1452
1453 case GDB_SIGNAL_PWR:
1454 return MIPS_LINUX_SIGPWR;
1455
1456 case GDB_SIGNAL_WINCH:
1457 return MIPS_LINUX_SIGWINCH;
1458
1459 case GDB_SIGNAL_URG:
1460 return MIPS_LINUX_SIGURG;
1461
1462 case GDB_SIGNAL_IO:
1463 return MIPS_LINUX_SIGIO;
1464
1465 case GDB_SIGNAL_POLL:
1466 return MIPS_LINUX_SIGPOLL;
1467
1468 case GDB_SIGNAL_STOP:
1469 return MIPS_LINUX_SIGSTOP;
1470
1471 case GDB_SIGNAL_TSTP:
1472 return MIPS_LINUX_SIGTSTP;
1473
1474 case GDB_SIGNAL_CONT:
1475 return MIPS_LINUX_SIGCONT;
1476
1477 case GDB_SIGNAL_TTIN:
1478 return MIPS_LINUX_SIGTTIN;
1479
1480 case GDB_SIGNAL_TTOU:
1481 return MIPS_LINUX_SIGTTOU;
1482
1483 case GDB_SIGNAL_VTALRM:
1484 return MIPS_LINUX_SIGVTALRM;
1485
1486 case GDB_SIGNAL_PROF:
1487 return MIPS_LINUX_SIGPROF;
1488
1489 case GDB_SIGNAL_XCPU:
1490 return MIPS_LINUX_SIGXCPU;
1491
1492 case GDB_SIGNAL_XFSZ:
1493 return MIPS_LINUX_SIGXFSZ;
1494
1495 /* GDB_SIGNAL_REALTIME_32 is not continuous in <gdb/signals.def>,
1496 therefore we have to handle it here. */
1497 case GDB_SIGNAL_REALTIME_32:
1498 return MIPS_LINUX_SIGRTMIN;
1499 }
1500
1501 if (signal >= GDB_SIGNAL_REALTIME_33
1502 && signal <= GDB_SIGNAL_REALTIME_63)
1503 {
1504 int offset = signal - GDB_SIGNAL_REALTIME_33;
1505
1506 return MIPS_LINUX_SIGRTMIN + 1 + offset;
1507 }
1508 else if (signal >= GDB_SIGNAL_REALTIME_64
1509 && signal <= GDB_SIGNAL_REALTIME_127)
1510 {
1511 int offset = signal - GDB_SIGNAL_REALTIME_64;
1512
1513 return MIPS_LINUX_SIGRT64 + offset;
1514 }
1515
1516 return linux_gdb_signal_to_target (gdbarch, signal);
1517 }
1518
1519 /* Translate signals based on MIPS signal values.
1520 Adapted from gdb/common/signals.c. */
1521
1522 static enum gdb_signal
1523 mips_gdb_signal_from_target (struct gdbarch *gdbarch, int signal)
1524 {
1525 switch (signal)
1526 {
1527 case MIPS_LINUX_SIGEMT:
1528 return GDB_SIGNAL_EMT;
1529
1530 case MIPS_LINUX_SIGBUS:
1531 return GDB_SIGNAL_BUS;
1532
1533 case MIPS_LINUX_SIGSYS:
1534 return GDB_SIGNAL_SYS;
1535
1536 case MIPS_LINUX_SIGUSR1:
1537 return GDB_SIGNAL_USR1;
1538
1539 case MIPS_LINUX_SIGUSR2:
1540 return GDB_SIGNAL_USR2;
1541
1542 case MIPS_LINUX_SIGCHLD:
1543 return GDB_SIGNAL_CHLD;
1544
1545 case MIPS_LINUX_SIGPWR:
1546 return GDB_SIGNAL_PWR;
1547
1548 case MIPS_LINUX_SIGWINCH:
1549 return GDB_SIGNAL_WINCH;
1550
1551 case MIPS_LINUX_SIGURG:
1552 return GDB_SIGNAL_URG;
1553
1554 /* No way to differentiate between SIGIO and SIGPOLL.
1555 Therefore, we just handle the first one. */
1556 case MIPS_LINUX_SIGIO:
1557 return GDB_SIGNAL_IO;
1558
1559 case MIPS_LINUX_SIGSTOP:
1560 return GDB_SIGNAL_STOP;
1561
1562 case MIPS_LINUX_SIGTSTP:
1563 return GDB_SIGNAL_TSTP;
1564
1565 case MIPS_LINUX_SIGCONT:
1566 return GDB_SIGNAL_CONT;
1567
1568 case MIPS_LINUX_SIGTTIN:
1569 return GDB_SIGNAL_TTIN;
1570
1571 case MIPS_LINUX_SIGTTOU:
1572 return GDB_SIGNAL_TTOU;
1573
1574 case MIPS_LINUX_SIGVTALRM:
1575 return GDB_SIGNAL_VTALRM;
1576
1577 case MIPS_LINUX_SIGPROF:
1578 return GDB_SIGNAL_PROF;
1579
1580 case MIPS_LINUX_SIGXCPU:
1581 return GDB_SIGNAL_XCPU;
1582
1583 case MIPS_LINUX_SIGXFSZ:
1584 return GDB_SIGNAL_XFSZ;
1585 }
1586
1587 if (signal >= MIPS_LINUX_SIGRTMIN && signal <= MIPS_LINUX_SIGRTMAX)
1588 {
1589 /* GDB_SIGNAL_REALTIME values are not contiguous, map parts of
1590 the MIPS block to the respective GDB_SIGNAL_REALTIME blocks. */
1591 int offset = signal - MIPS_LINUX_SIGRTMIN;
1592
1593 if (offset == 0)
1594 return GDB_SIGNAL_REALTIME_32;
1595 else if (offset < 32)
1596 return (enum gdb_signal) (offset - 1
1597 + (int) GDB_SIGNAL_REALTIME_33);
1598 else
1599 return (enum gdb_signal) (offset - 32
1600 + (int) GDB_SIGNAL_REALTIME_64);
1601 }
1602
1603 return linux_gdb_signal_from_target (gdbarch, signal);
1604 }
1605
1606 /* Initialize one of the GNU/Linux OS ABIs. */
1607
1608 static void
1609 mips_linux_init_abi (struct gdbarch_info info,
1610 struct gdbarch *gdbarch)
1611 {
1612 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
1613 enum mips_abi abi = mips_abi (gdbarch);
1614 struct tdesc_arch_data *tdesc_data
1615 = (struct tdesc_arch_data *) info.tdep_info;
1616
1617 linux_init_abi (info, gdbarch);
1618
1619 /* Get the syscall number from the arch's register. */
1620 set_gdbarch_get_syscall_number (gdbarch, mips_linux_get_syscall_number);
1621
1622 switch (abi)
1623 {
1624 case MIPS_ABI_O32:
1625 set_gdbarch_get_longjmp_target (gdbarch,
1626 mips_linux_get_longjmp_target);
1627 set_solib_svr4_fetch_link_map_offsets
1628 (gdbarch, svr4_ilp32_fetch_link_map_offsets);
1629 tramp_frame_prepend_unwinder (gdbarch, &micromips_linux_o32_sigframe);
1630 tramp_frame_prepend_unwinder (gdbarch,
1631 &micromips_linux_o32_rt_sigframe);
1632 tramp_frame_prepend_unwinder (gdbarch, &mips_linux_o32_sigframe);
1633 tramp_frame_prepend_unwinder (gdbarch, &mips_linux_o32_rt_sigframe);
1634 set_xml_syscall_file_name (gdbarch, "syscalls/mips-o32-linux.xml");
1635 break;
1636 case MIPS_ABI_N32:
1637 set_gdbarch_get_longjmp_target (gdbarch,
1638 mips_linux_get_longjmp_target);
1639 set_solib_svr4_fetch_link_map_offsets
1640 (gdbarch, svr4_ilp32_fetch_link_map_offsets);
1641 set_gdbarch_long_double_bit (gdbarch, 128);
1642 /* These floatformats should probably be renamed. MIPS uses
1643 the same 128-bit IEEE floating point format that IA-64 uses,
1644 except that the quiet/signalling NaN bit is reversed (GDB
1645 does not distinguish between quiet and signalling NaNs). */
1646 set_gdbarch_long_double_format (gdbarch, floatformats_ia64_quad);
1647 tramp_frame_prepend_unwinder (gdbarch,
1648 &micromips_linux_n32_rt_sigframe);
1649 tramp_frame_prepend_unwinder (gdbarch, &mips_linux_n32_rt_sigframe);
1650 set_xml_syscall_file_name (gdbarch, "syscalls/mips-n32-linux.xml");
1651 break;
1652 case MIPS_ABI_N64:
1653 set_gdbarch_get_longjmp_target (gdbarch,
1654 mips64_linux_get_longjmp_target);
1655 set_solib_svr4_fetch_link_map_offsets
1656 (gdbarch, svr4_lp64_fetch_link_map_offsets);
1657 set_gdbarch_long_double_bit (gdbarch, 128);
1658 /* These floatformats should probably be renamed. MIPS uses
1659 the same 128-bit IEEE floating point format that IA-64 uses,
1660 except that the quiet/signalling NaN bit is reversed (GDB
1661 does not distinguish between quiet and signalling NaNs). */
1662 set_gdbarch_long_double_format (gdbarch, floatformats_ia64_quad);
1663 tramp_frame_prepend_unwinder (gdbarch,
1664 &micromips_linux_n64_rt_sigframe);
1665 tramp_frame_prepend_unwinder (gdbarch, &mips_linux_n64_rt_sigframe);
1666 set_xml_syscall_file_name (gdbarch, "syscalls/mips-n64-linux.xml");
1667 break;
1668 default:
1669 break;
1670 }
1671
1672 set_gdbarch_skip_solib_resolver (gdbarch, mips_linux_skip_resolver);
1673
1674 set_gdbarch_software_single_step (gdbarch, mips_software_single_step);
1675
1676 /* Enable TLS support. */
1677 set_gdbarch_fetch_tls_load_module_address (gdbarch,
1678 svr4_fetch_objfile_link_map);
1679
1680 /* Initialize this lazily, to avoid an initialization order
1681 dependency on solib-svr4.c's _initialize routine. */
1682 if (mips_svr4_so_ops.in_dynsym_resolve_code == NULL)
1683 {
1684 mips_svr4_so_ops = svr4_so_ops;
1685 mips_svr4_so_ops.in_dynsym_resolve_code
1686 = mips_linux_in_dynsym_resolve_code;
1687 }
1688 set_solib_ops (gdbarch, &mips_svr4_so_ops);
1689
1690 set_gdbarch_write_pc (gdbarch, mips_linux_write_pc);
1691
1692 set_gdbarch_core_read_description (gdbarch,
1693 mips_linux_core_read_description);
1694
1695 set_gdbarch_iterate_over_regset_sections
1696 (gdbarch, mips_linux_iterate_over_regset_sections);
1697
1698 set_gdbarch_gdb_signal_from_target (gdbarch,
1699 mips_gdb_signal_from_target);
1700
1701 set_gdbarch_gdb_signal_to_target (gdbarch,
1702 mips_gdb_signal_to_target);
1703
1704 tdep->syscall_next_pc = mips_linux_syscall_next_pc;
1705
1706 if (tdesc_data)
1707 {
1708 const struct tdesc_feature *feature;
1709
1710 /* If we have target-described registers, then we can safely
1711 reserve a number for MIPS_RESTART_REGNUM (whether it is
1712 described or not). */
1713 gdb_assert (gdbarch_num_regs (gdbarch) <= MIPS_RESTART_REGNUM);
1714 set_gdbarch_num_regs (gdbarch, MIPS_RESTART_REGNUM + 1);
1715 set_gdbarch_num_pseudo_regs (gdbarch, MIPS_RESTART_REGNUM + 1);
1716
1717 /* If it's present, then assign it to the reserved number. */
1718 feature = tdesc_find_feature (info.target_desc,
1719 "org.gnu.gdb.mips.linux");
1720 if (feature != NULL)
1721 tdesc_numbered_register (feature, tdesc_data, MIPS_RESTART_REGNUM,
1722 "restart");
1723 }
1724 }
1725
1726 /* Provide a prototype to silence -Wmissing-prototypes. */
1727 extern initialize_file_ftype _initialize_mips_linux_tdep;
1728
1729 void
1730 _initialize_mips_linux_tdep (void)
1731 {
1732 const struct bfd_arch_info *arch_info;
1733
1734 for (arch_info = bfd_lookup_arch (bfd_arch_mips, 0);
1735 arch_info != NULL;
1736 arch_info = arch_info->next)
1737 {
1738 gdbarch_register_osabi (bfd_arch_mips, arch_info->mach,
1739 GDB_OSABI_LINUX,
1740 mips_linux_init_abi);
1741 }
1742 }
This page took 0.069485 seconds and 4 git commands to generate.