]> CyberLeo.Net >> Repos - FreeBSD/releng/10.0.git/blob - contrib/gdb/gdb/ppc-sysv-tdep.c
- Copy stable/10 (r259064) to releng/10.0 as part of the
[FreeBSD/releng/10.0.git] / contrib / gdb / gdb / ppc-sysv-tdep.c
1 /* Target-dependent code for PowerPC systems using the SVR4 ABI
2    for GDB, the GNU debugger.
3
4    Copyright 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
5
6    This file is part of GDB.
7
8    This program is free software; you can redistribute it and/or modify
9    it under the terms of the GNU General Public License as published by
10    the Free Software Foundation; either version 2 of the License, or
11    (at your option) any later version.
12
13    This program is distributed in the hope that it will be useful,
14    but WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16    GNU General Public License for more details.
17
18    You should have received a copy of the GNU General Public License
19    along with this program; if not, write to the Free Software
20    Foundation, Inc., 59 Temple Place - Suite 330,
21    Boston, MA 02111-1307, USA.  */
22
23 #include "defs.h"
24 #include "gdbcore.h"
25 #include "inferior.h"
26 #include "regcache.h"
27 #include "value.h"
28 #include "gdb_string.h"
29 #include "gdb_assert.h"
30 #include "ppc-tdep.h"
31 #include "target.h"
32 #include "objfiles.h"
33
34 /* Pass the arguments in either registers, or in the stack. Using the
35    ppc sysv ABI, the first eight words of the argument list (that might
36    be less than eight parameters if some parameters occupy more than one
37    word) are passed in r3..r10 registers.  float and double parameters are
38    passed in fpr's, in addition to that. Rest of the parameters if any
39    are passed in user stack. 
40
41    If the function is returning a structure, then the return address is passed
42    in r3, then the first 7 words of the parametes can be passed in registers,
43    starting from r4. */
44
45 CORE_ADDR
46 ppc_sysv_abi_push_dummy_call (struct gdbarch *gdbarch, CORE_ADDR func_addr,
47                               struct regcache *regcache, CORE_ADDR bp_addr,
48                               int nargs, struct value **args, CORE_ADDR sp,
49                               int struct_return, CORE_ADDR struct_addr)
50 {
51   struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
52   const CORE_ADDR saved_sp = read_sp ();
53   int argspace = 0;             /* 0 is an initial wrong guess.  */
54   int write_pass;
55
56   /* Go through the argument list twice.
57
58      Pass 1: Figure out how much new stack space is required for
59      arguments and pushed values.  Unlike the PowerOpen ABI, the SysV
60      ABI doesn't reserve any extra space for parameters which are put
61      in registers, but does always push structures and then pass their
62      address.
63
64      Pass 2: Replay the same computation but this time also write the
65      values out to the target.  */
66
67   for (write_pass = 0; write_pass < 2; write_pass++)
68     {
69       int argno;
70       /* Next available floating point register for float and double
71          arguments.  */
72       int freg = 1;
73       /* Next available general register for non-float, non-vector
74          arguments.  */
75       int greg = 3;
76       /* Next available vector register for vector arguments.  */
77       int vreg = 2;
78       /* Arguments start above the "LR save word" and "Back chain".  */
79       int argoffset = 2 * tdep->wordsize;
80       /* Structures start after the arguments.  */
81       int structoffset = argoffset + argspace;
82
83       /* If the function is returning a `struct', then the first word
84          (which will be passed in r3) is used for struct return
85          address.  In that case we should advance one word and start
86          from r4 register to copy parameters.  */
87       if (struct_return)
88         {
89           if (write_pass)
90             regcache_cooked_write_signed (regcache,
91                                           tdep->ppc_gp0_regnum + greg,
92                                           struct_addr);
93           greg++;
94         }
95
96       for (argno = 0; argno < nargs; argno++)
97         {
98           struct value *arg = args[argno];
99           struct type *type = check_typedef (VALUE_TYPE (arg));
100           int len = TYPE_LENGTH (type);
101           char *val = VALUE_CONTENTS (arg);
102
103           if (TYPE_CODE (type) == TYPE_CODE_FLT
104               && ppc_floating_point_unit_p (current_gdbarch) && len <= 8)
105             {
106               /* Floating point value converted to "double" then
107                  passed in an FP register, when the registers run out,
108                  8 byte aligned stack is used.  */
109               if (freg <= 8)
110                 {
111                   if (write_pass)
112                     {
113                       /* Always store the floating point value using
114                          the register's floating-point format.  */
115                       char regval[MAX_REGISTER_SIZE];
116                       struct type *regtype
117                         = register_type (gdbarch, FP0_REGNUM + freg);
118                       convert_typed_floating (val, type, regval, regtype);
119                       regcache_cooked_write (regcache, FP0_REGNUM + freg,
120                                              regval);
121                     }
122                   freg++;
123                 }
124               else
125                 {
126                   /* SysV ABI converts floats to doubles before
127                      writing them to an 8 byte aligned stack location.  */
128                   argoffset = align_up (argoffset, 8);
129                   if (write_pass)
130                     {
131                       char memval[8];
132                       struct type *memtype;
133                       switch (TARGET_BYTE_ORDER)
134                         {
135                         case BFD_ENDIAN_BIG:
136                           memtype = builtin_type_ieee_double_big;
137                           break;
138                         case BFD_ENDIAN_LITTLE:
139                           memtype = builtin_type_ieee_double_little;
140                           break;
141                         default:
142                           internal_error (__FILE__, __LINE__, "bad switch");
143                         }
144                       convert_typed_floating (val, type, memval, memtype);
145                       write_memory (sp + argoffset, val, len);
146                     }
147                   argoffset += 8;
148                 }
149             }
150           else if (len == 8 && (TYPE_CODE (type) == TYPE_CODE_INT       /* long long */
151                                 || (!ppc_floating_point_unit_p (current_gdbarch) && TYPE_CODE (type) == TYPE_CODE_FLT)))        /* double */
152             {
153               /* "long long" or "double" passed in an odd/even
154                  register pair with the low addressed word in the odd
155                  register and the high addressed word in the even
156                  register, or when the registers run out an 8 byte
157                  aligned stack location.  */
158               if (greg > 9)
159                 {
160                   /* Just in case GREG was 10.  */
161                   greg = 11;
162                   argoffset = align_up (argoffset, 8);
163                   if (write_pass)
164                     write_memory (sp + argoffset, val, len);
165                   argoffset += 8;
166                 }
167               else if (tdep->wordsize == 8)
168                 {
169                   if (write_pass)
170                     regcache_cooked_write (regcache,
171                                            tdep->ppc_gp0_regnum + greg, val);
172                   greg += 1;
173                 }
174               else
175                 {
176                   /* Must start on an odd register - r3/r4 etc.  */
177                   if ((greg & 1) == 0)
178                     greg++;
179                   if (write_pass)
180                     {
181                       regcache_cooked_write (regcache,
182                                              tdep->ppc_gp0_regnum + greg + 0,
183                                              val + 0);
184                       regcache_cooked_write (regcache,
185                                              tdep->ppc_gp0_regnum + greg + 1,
186                                              val + 4);
187                     }
188                   greg += 2;
189                 }
190             }
191           else if (len == 16
192                    && TYPE_CODE (type) == TYPE_CODE_ARRAY
193                    && TYPE_VECTOR (type) && tdep->ppc_vr0_regnum >= 0)
194             {
195               /* Vector parameter passed in an Altivec register, or
196                  when that runs out, 16 byte aligned stack location.  */
197               if (vreg <= 13)
198                 {
199                   if (write_pass)
200                     regcache_cooked_write (current_regcache,
201                                            tdep->ppc_vr0_regnum + vreg, val);
202                   vreg++;
203                 }
204               else
205                 {
206                   argoffset = align_up (argoffset, 16);
207                   if (write_pass)
208                     write_memory (sp + argoffset, val, 16);
209                   argoffset += 16;
210                 }
211             }
212           else if (len == 8
213                    && TYPE_CODE (type) == TYPE_CODE_ARRAY
214                    && TYPE_VECTOR (type) && tdep->ppc_ev0_regnum >= 0)
215             {
216               /* Vector parameter passed in an e500 register, or when
217                  that runs out, 8 byte aligned stack location.  Note
218                  that since e500 vector and general purpose registers
219                  both map onto the same underlying register set, a
220                  "greg" and not a "vreg" is consumed here.  A cooked
221                  write stores the value in the correct locations
222                  within the raw register cache.  */
223               if (greg <= 10)
224                 {
225                   if (write_pass)
226                     regcache_cooked_write (current_regcache,
227                                            tdep->ppc_ev0_regnum + greg, val);
228                   greg++;
229                 }
230               else
231                 {
232                   argoffset = align_up (argoffset, 8);
233                   if (write_pass)
234                     write_memory (sp + argoffset, val, 8);
235                   argoffset += 8;
236                 }
237             }
238           else
239             {
240               /* Reduce the parameter down to something that fits in a
241                  "word".  */
242               char word[MAX_REGISTER_SIZE];
243               memset (word, 0, MAX_REGISTER_SIZE);
244               if (len > tdep->wordsize
245                   || TYPE_CODE (type) == TYPE_CODE_STRUCT
246                   || TYPE_CODE (type) == TYPE_CODE_UNION)
247                 {
248                   /* Structs and large values are put on an 8 byte
249                      aligned stack ... */
250                   structoffset = align_up (structoffset, 8);
251                   if (write_pass)
252                     write_memory (sp + structoffset, val, len);
253                   /* ... and then a "word" pointing to that address is
254                      passed as the parameter.  */
255                   store_unsigned_integer (word, tdep->wordsize,
256                                           sp + structoffset);
257                   structoffset += len;
258                 }
259               else if (TYPE_CODE (type) == TYPE_CODE_INT)
260                 /* Sign or zero extend the "int" into a "word".  */
261                 store_unsigned_integer (word, tdep->wordsize,
262                                         unpack_long (type, val));
263               else
264                 /* Always goes in the low address.  */
265                 memcpy (word, val, len);
266               /* Store that "word" in a register, or on the stack.
267                  The words have "4" byte alignment.  */
268               if (greg <= 10)
269                 {
270                   if (write_pass)
271                     regcache_cooked_write (regcache,
272                                            tdep->ppc_gp0_regnum + greg, word);
273                   greg++;
274                 }
275               else
276                 {
277                   argoffset = align_up (argoffset, tdep->wordsize);
278                   if (write_pass)
279                     write_memory (sp + argoffset, word, tdep->wordsize);
280                   argoffset += tdep->wordsize;
281                 }
282             }
283         }
284
285       /* Compute the actual stack space requirements.  */
286       if (!write_pass)
287         {
288           /* Remember the amount of space needed by the arguments.  */
289           argspace = argoffset;
290           /* Allocate space for both the arguments and the structures.  */
291           sp -= (argoffset + structoffset);
292           /* Ensure that the stack is still 16 byte aligned.  */
293           sp = align_down (sp, 16);
294         }
295     }
296
297   /* Update %sp.   */
298   regcache_cooked_write_signed (regcache, SP_REGNUM, sp);
299
300   /* Write the backchain (it occupies WORDSIZED bytes).  */
301   write_memory_signed_integer (sp, tdep->wordsize, saved_sp);
302
303   /* Point the inferior function call's return address at the dummy's
304      breakpoint.  */
305   regcache_cooked_write_signed (regcache, tdep->ppc_lr_regnum, bp_addr);
306
307   return sp;
308 }
309
310 /* Handle the return-value conventions specified by the SysV 32-bit
311    PowerPC ABI (including all the supplements):
312
313    no floating-point: floating-point values returned using 32-bit
314    general-purpose registers.
315
316    Altivec: 128-bit vectors returned using vector registers.
317
318    e500: 64-bit vectors returned using the full full 64 bit EV
319    register, floating-point values returned using 32-bit
320    general-purpose registers.
321
322    GCC (broken): Small struct values right (instead of left) aligned
323    when returned in general-purpose registers.  */
324
325 static enum return_value_convention
326 do_ppc_sysv_return_value (struct gdbarch *gdbarch, struct type *type,
327                           struct regcache *regcache, void *readbuf,
328                           const void *writebuf, int broken_gcc)
329 {
330   struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
331   gdb_assert (tdep->wordsize == 4);
332   if (TYPE_CODE (type) == TYPE_CODE_FLT
333       && TYPE_LENGTH (type) <= 8
334       && ppc_floating_point_unit_p (gdbarch))
335     {
336       if (readbuf)
337         {
338           /* Floats and doubles stored in "f1".  Convert the value to
339              the required type.  */
340           char regval[MAX_REGISTER_SIZE];
341           struct type *regtype = register_type (gdbarch, FP0_REGNUM + 1);
342           regcache_cooked_read (regcache, FP0_REGNUM + 1, regval);
343           convert_typed_floating (regval, regtype, readbuf, type);
344         }
345       if (writebuf)
346         {
347           /* Floats and doubles stored in "f1".  Convert the value to
348              the register's "double" type.  */
349           char regval[MAX_REGISTER_SIZE];
350           struct type *regtype = register_type (gdbarch, FP0_REGNUM);
351           convert_typed_floating (writebuf, type, regval, regtype);
352           regcache_cooked_write (regcache, FP0_REGNUM + 1, regval);
353         }
354       return RETURN_VALUE_REGISTER_CONVENTION;
355     }
356   if ((TYPE_CODE (type) == TYPE_CODE_INT && TYPE_LENGTH (type) == 8)
357       || (TYPE_CODE (type) == TYPE_CODE_FLT && TYPE_LENGTH (type) == 8))
358     {
359       if (readbuf)
360         {
361           /* A long long, or a double stored in the 32 bit r3/r4.  */
362           regcache_cooked_read (regcache, tdep->ppc_gp0_regnum + 3,
363                                 (bfd_byte *) readbuf + 0);
364           regcache_cooked_read (regcache, tdep->ppc_gp0_regnum + 4,
365                                 (bfd_byte *) readbuf + 4);
366         }
367       if (writebuf)
368         {
369           /* A long long, or a double stored in the 32 bit r3/r4.  */
370           regcache_cooked_write (regcache, tdep->ppc_gp0_regnum + 3,
371                                  (const bfd_byte *) writebuf + 0);
372           regcache_cooked_write (regcache, tdep->ppc_gp0_regnum + 4,
373                                  (const bfd_byte *) writebuf + 4);
374         }
375       return RETURN_VALUE_REGISTER_CONVENTION;
376     }
377   if (TYPE_CODE (type) == TYPE_CODE_INT
378       && TYPE_LENGTH (type) <= tdep->wordsize)
379     {
380       if (readbuf)
381         {
382           /* Some sort of integer stored in r3.  Since TYPE isn't
383              bigger than the register, sign extension isn't a problem
384              - just do everything unsigned.  */
385           ULONGEST regval;
386           regcache_cooked_read_unsigned (regcache, tdep->ppc_gp0_regnum + 3,
387                                          &regval);
388           store_unsigned_integer (readbuf, TYPE_LENGTH (type), regval);
389         }
390       if (writebuf)
391         {
392           /* Some sort of integer stored in r3.  Use unpack_long since
393              that should handle any required sign extension.  */
394           regcache_cooked_write_unsigned (regcache, tdep->ppc_gp0_regnum + 3,
395                                           unpack_long (type, writebuf));
396         }
397       return RETURN_VALUE_REGISTER_CONVENTION;
398     }
399   if (TYPE_LENGTH (type) == 16
400       && TYPE_CODE (type) == TYPE_CODE_ARRAY
401       && TYPE_VECTOR (type) && tdep->ppc_vr0_regnum >= 0)
402     {
403       if (readbuf)
404         {
405           /* Altivec places the return value in "v2".  */
406           regcache_cooked_read (regcache, tdep->ppc_vr0_regnum + 2, readbuf);
407         }
408       if (writebuf)
409         {
410           /* Altivec places the return value in "v2".  */
411           regcache_cooked_write (regcache, tdep->ppc_vr0_regnum + 2, writebuf);
412         }
413       return RETURN_VALUE_REGISTER_CONVENTION;
414     }
415   if (TYPE_LENGTH (type) == 8
416       && TYPE_CODE (type) == TYPE_CODE_ARRAY
417       && TYPE_VECTOR (type) && tdep->ppc_ev0_regnum >= 0)
418     {
419       /* The e500 ABI places return values for the 64-bit DSP types
420          (__ev64_opaque__) in r3.  However, in GDB-speak, ev3
421          corresponds to the entire r3 value for e500, whereas GDB's r3
422          only corresponds to the least significant 32-bits.  So place
423          the 64-bit DSP type's value in ev3.  */
424       if (readbuf)
425         regcache_cooked_read (regcache, tdep->ppc_ev0_regnum + 3, readbuf);
426       if (writebuf)
427         regcache_cooked_write (regcache, tdep->ppc_ev0_regnum + 3, writebuf);
428       return RETURN_VALUE_REGISTER_CONVENTION;
429     }
430   if (broken_gcc && TYPE_LENGTH (type) <= 8)
431     {
432       if (readbuf)
433         {
434           /* GCC screwed up.  The last register isn't "left" aligned.
435              Need to extract the least significant part of each
436              register and then store that.  */
437           /* Transfer any full words.  */
438           int word = 0;
439           while (1)
440             {
441               ULONGEST reg;
442               int len = TYPE_LENGTH (type) - word * tdep->wordsize;
443               if (len <= 0)
444                 break;
445               if (len > tdep->wordsize)
446                 len = tdep->wordsize;
447               regcache_cooked_read_unsigned (regcache,
448                                              tdep->ppc_gp0_regnum + 3 + word,
449                                              &reg);
450               store_unsigned_integer (((bfd_byte *) readbuf
451                                        + word * tdep->wordsize), len, reg);
452               word++;
453             }
454         }
455       if (writebuf)
456         {
457           /* GCC screwed up.  The last register isn't "left" aligned.
458              Need to extract the least significant part of each
459              register and then store that.  */
460           /* Transfer any full words.  */
461           int word = 0;
462           while (1)
463             {
464               ULONGEST reg;
465               int len = TYPE_LENGTH (type) - word * tdep->wordsize;
466               if (len <= 0)
467                 break;
468               if (len > tdep->wordsize)
469                 len = tdep->wordsize;
470               reg = extract_unsigned_integer (((const bfd_byte *) writebuf
471                                                + word * tdep->wordsize), len);
472               regcache_cooked_write_unsigned (regcache,
473                                               tdep->ppc_gp0_regnum + 3 + word,
474                                               reg);
475               word++;
476             }
477         }
478       return RETURN_VALUE_REGISTER_CONVENTION;
479     }
480   if (TYPE_LENGTH (type) <= 8)
481     {
482       if (readbuf)
483         {
484           /* This matches SVr4 PPC, it does not match GCC.  */
485           /* The value is right-padded to 8 bytes and then loaded, as
486              two "words", into r3/r4.  */
487           char regvals[MAX_REGISTER_SIZE * 2];
488           regcache_cooked_read (regcache, tdep->ppc_gp0_regnum + 3,
489                                 regvals + 0 * tdep->wordsize);
490           if (TYPE_LENGTH (type) > tdep->wordsize)
491             regcache_cooked_read (regcache, tdep->ppc_gp0_regnum + 4,
492                                   regvals + 1 * tdep->wordsize);
493           memcpy (readbuf, regvals, TYPE_LENGTH (type));
494         }
495       if (writebuf)
496         {
497           /* This matches SVr4 PPC, it does not match GCC.  */
498           /* The value is padded out to 8 bytes and then loaded, as
499              two "words" into r3/r4.  */
500           char regvals[MAX_REGISTER_SIZE * 2];
501           memset (regvals, 0, sizeof regvals);
502           memcpy (regvals, writebuf, TYPE_LENGTH (type));
503           regcache_cooked_write (regcache, tdep->ppc_gp0_regnum + 3,
504                                  regvals + 0 * tdep->wordsize);
505           if (TYPE_LENGTH (type) > tdep->wordsize)
506             regcache_cooked_write (regcache, tdep->ppc_gp0_regnum + 4,
507                                    regvals + 1 * tdep->wordsize);
508         }
509       return RETURN_VALUE_REGISTER_CONVENTION;
510     }
511   return RETURN_VALUE_STRUCT_CONVENTION;
512 }
513
514 enum return_value_convention
515 ppc_sysv_abi_return_value (struct gdbarch *gdbarch, struct type *valtype,
516                            struct regcache *regcache, void *readbuf,
517                            const void *writebuf)
518 {
519   return do_ppc_sysv_return_value (gdbarch, valtype, regcache, readbuf,
520                                    writebuf, 0);
521 }
522
523 enum return_value_convention
524 ppc_sysv_abi_broken_return_value (struct gdbarch *gdbarch,
525                                   struct type *valtype,
526                                   struct regcache *regcache,
527                                   void *readbuf, const void *writebuf)
528 {
529   return do_ppc_sysv_return_value (gdbarch, valtype, regcache, readbuf,
530                                    writebuf, 1);
531 }
532
533 /* Pass the arguments in either registers, or in the stack. Using the
534    ppc 64 bit SysV ABI.
535
536    This implements a dumbed down version of the ABI.  It always writes
537    values to memory, GPR and FPR, even when not necessary.  Doing this
538    greatly simplifies the logic. */
539
540 CORE_ADDR
541 ppc64_sysv_abi_push_dummy_call (struct gdbarch *gdbarch, CORE_ADDR func_addr,
542                                 struct regcache *regcache, CORE_ADDR bp_addr,
543                                 int nargs, struct value **args, CORE_ADDR sp,
544                                 int struct_return, CORE_ADDR struct_addr)
545 {
546   struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
547   /* By this stage in the proceedings, SP has been decremented by "red
548      zone size" + "struct return size".  Fetch the stack-pointer from
549      before this and use that as the BACK_CHAIN.  */
550   const CORE_ADDR back_chain = read_sp ();
551   /* See for-loop comment below.  */
552   int write_pass;
553   /* Size of the Altivec's vector parameter region, the final value is
554      computed in the for-loop below.  */
555   LONGEST vparam_size = 0;
556   /* Size of the general parameter region, the final value is computed
557      in the for-loop below.  */
558   LONGEST gparam_size = 0;
559   /* Kevin writes ... I don't mind seeing tdep->wordsize used in the
560      calls to align_up(), align_down(), etc.  because this makes it
561      easier to reuse this code (in a copy/paste sense) in the future,
562      but it is a 64-bit ABI and asserting that the wordsize is 8 bytes
563      at some point makes it easier to verify that this function is
564      correct without having to do a non-local analysis to figure out
565      the possible values of tdep->wordsize.  */
566   gdb_assert (tdep->wordsize == 8);
567
568   /* Go through the argument list twice.
569
570      Pass 1: Compute the function call's stack space and register
571      requirements.
572
573      Pass 2: Replay the same computation but this time also write the
574      values out to the target.  */
575
576   for (write_pass = 0; write_pass < 2; write_pass++)
577     {
578       int argno;
579       /* Next available floating point register for float and double
580          arguments.  */
581       int freg = 1;
582       /* Next available general register for non-vector (but possibly
583          float) arguments.  */
584       int greg = 3;
585       /* Next available vector register for vector arguments.  */
586       int vreg = 2;
587       /* The address, at which the next general purpose parameter
588          (integer, struct, float, ...) should be saved.  */
589       CORE_ADDR gparam;
590       /* Address, at which the next Altivec vector parameter should be
591          saved.  */
592       CORE_ADDR vparam;
593
594       if (!write_pass)
595         {
596           /* During the first pass, GPARAM and VPARAM are more like
597              offsets (start address zero) than addresses.  That way
598              the accumulate the total stack space each region
599              requires.  */
600           gparam = 0;
601           vparam = 0;
602         }
603       else
604         {
605           /* Decrement the stack pointer making space for the Altivec
606              and general on-stack parameters.  Set vparam and gparam
607              to their corresponding regions.  */
608           vparam = align_down (sp - vparam_size, 16);
609           gparam = align_down (vparam - gparam_size, 16);
610           /* Add in space for the TOC, link editor double word,
611              compiler double word, LR save area, CR save area.  */
612           sp = align_down (gparam - 48, 16);
613         }
614
615       /* If the function is returning a `struct', then there is an
616          extra hidden parameter (which will be passed in r3)
617          containing the address of that struct..  In that case we
618          should advance one word and start from r4 register to copy
619          parameters.  This also consumes one on-stack parameter slot.  */
620       if (struct_return)
621         {
622           if (write_pass)
623             regcache_cooked_write_signed (regcache,
624                                           tdep->ppc_gp0_regnum + greg,
625                                           struct_addr);
626           greg++;
627           gparam = align_up (gparam + tdep->wordsize, tdep->wordsize);
628         }
629
630       for (argno = 0; argno < nargs; argno++)
631         {
632           struct value *arg = args[argno];
633           struct type *type = check_typedef (VALUE_TYPE (arg));
634           char *val = VALUE_CONTENTS (arg);
635           if (TYPE_CODE (type) == TYPE_CODE_FLT && TYPE_LENGTH (type) <= 8)
636             {
637               /* Floats and Doubles go in f1 .. f13.  They also
638                  consume a left aligned GREG,, and can end up in
639                  memory.  */
640               if (write_pass)
641                 {
642                   if (ppc_floating_point_unit_p (current_gdbarch)
643                       && freg <= 13)
644                     {
645                       char regval[MAX_REGISTER_SIZE];
646                       struct type *regtype = register_type (gdbarch,
647                                                             FP0_REGNUM);
648                       convert_typed_floating (val, type, regval, regtype);
649                       regcache_cooked_write (regcache, FP0_REGNUM + freg,
650                                              regval);
651                     }
652                   if (greg <= 10)
653                     {
654                       /* The ABI states "Single precision floating
655                          point values are mapped to the first word in
656                          a single doubleword" and "... floating point
657                          values mapped to the first eight doublewords
658                          of the parameter save area are also passed in
659                          general registers").
660
661                          This code interprets that to mean: store it,
662                          left aligned, in the general register.  */
663                       char regval[MAX_REGISTER_SIZE];
664                       memset (regval, 0, sizeof regval);
665                       memcpy (regval, val, TYPE_LENGTH (type));
666                       regcache_cooked_write (regcache,
667                                              tdep->ppc_gp0_regnum + greg,
668                                              regval);
669                     }
670                   write_memory (gparam, val, TYPE_LENGTH (type));
671                 }
672               /* Always consume parameter stack space.  */
673               freg++;
674               greg++;
675               gparam = align_up (gparam + TYPE_LENGTH (type), tdep->wordsize);
676             }
677           else if (TYPE_LENGTH (type) == 16 && TYPE_VECTOR (type)
678                    && TYPE_CODE (type) == TYPE_CODE_ARRAY
679                    && tdep->ppc_vr0_regnum >= 0)
680             {
681               /* In the Altivec ABI, vectors go in the vector
682                  registers v2 .. v13, or when that runs out, a vector
683                  annex which goes above all the normal parameters.
684                  NOTE: cagney/2003-09-21: This is a guess based on the
685                  PowerOpen Altivec ABI.  */
686               if (vreg <= 13)
687                 {
688                   if (write_pass)
689                     regcache_cooked_write (regcache,
690                                            tdep->ppc_vr0_regnum + vreg, val);
691                   vreg++;
692                 }
693               else
694                 {
695                   if (write_pass)
696                     write_memory (vparam, val, TYPE_LENGTH (type));
697                   vparam = align_up (vparam + TYPE_LENGTH (type), 16);
698                 }
699             }
700           else if ((TYPE_CODE (type) == TYPE_CODE_INT
701                     || TYPE_CODE (type) == TYPE_CODE_ENUM)
702                    && TYPE_LENGTH (type) <= 8)
703             {
704               /* Scalars get sign[un]extended and go in gpr3 .. gpr10.
705                  They can also end up in memory.  */
706               if (write_pass)
707                 {
708                   /* Sign extend the value, then store it unsigned.  */
709                   ULONGEST word = unpack_long (type, val);
710                   if (greg <= 10)
711                     regcache_cooked_write_unsigned (regcache,
712                                                     tdep->ppc_gp0_regnum +
713                                                     greg, word);
714                   write_memory_unsigned_integer (gparam, tdep->wordsize,
715                                                  word);
716                 }
717               greg++;
718               gparam = align_up (gparam + TYPE_LENGTH (type), tdep->wordsize);
719             }
720           else
721             {
722               int byte;
723               for (byte = 0; byte < TYPE_LENGTH (type);
724                    byte += tdep->wordsize)
725                 {
726                   if (write_pass && greg <= 10)
727                     {
728                       char regval[MAX_REGISTER_SIZE];
729                       int len = TYPE_LENGTH (type) - byte;
730                       if (len > tdep->wordsize)
731                         len = tdep->wordsize;
732                       memset (regval, 0, sizeof regval);
733                       /* WARNING: cagney/2003-09-21: As best I can
734                          tell, the ABI specifies that the value should
735                          be left aligned.  Unfortunately, GCC doesn't
736                          do this - it instead right aligns even sized
737                          values and puts odd sized values on the
738                          stack.  Work around that by putting both a
739                          left and right aligned value into the
740                          register (hopefully no one notices :-^).
741                          Arrrgh!  */
742                       /* Left aligned (8 byte values such as pointers
743                          fill the buffer).  */
744                       memcpy (regval, val + byte, len);
745                       /* Right aligned (but only if even).  */
746                       if (len == 1 || len == 2 || len == 4)
747                         memcpy (regval + tdep->wordsize - len,
748                                 val + byte, len);
749                       regcache_cooked_write (regcache, greg, regval);
750                     }
751                   greg++;
752                 }
753               if (write_pass)
754                 /* WARNING: cagney/2003-09-21: Strictly speaking, this
755                    isn't necessary, unfortunately, GCC appears to get
756                    "struct convention" parameter passing wrong putting
757                    odd sized structures in memory instead of in a
758                    register.  Work around this by always writing the
759                    value to memory.  Fortunately, doing this
760                    simplifies the code.  */
761                 write_memory (gparam, val, TYPE_LENGTH (type));
762               /* Always consume parameter stack space.  */
763               gparam = align_up (gparam + TYPE_LENGTH (type), tdep->wordsize);
764             }
765         }
766
767       if (!write_pass)
768         {
769           /* Save the true region sizes ready for the second pass.  */
770           vparam_size = vparam;
771           /* Make certain that the general parameter save area is at
772              least the minimum 8 registers (or doublewords) in size.  */
773           if (greg < 8)
774             gparam_size = 8 * tdep->wordsize;
775           else
776             gparam_size = gparam;
777         }
778     }
779
780   /* Update %sp.   */
781   regcache_cooked_write_signed (regcache, SP_REGNUM, sp);
782
783   /* Write the backchain (it occupies WORDSIZED bytes).  */
784   write_memory_signed_integer (sp, tdep->wordsize, back_chain);
785
786   /* Point the inferior function call's return address at the dummy's
787      breakpoint.  */
788   regcache_cooked_write_signed (regcache, tdep->ppc_lr_regnum, bp_addr);
789
790   /* Find a value for the TOC register.  Every symbol should have both
791      ".FN" and "FN" in the minimal symbol table.  "FN" points at the
792      FN's descriptor, while ".FN" points at the entry point (which
793      matches FUNC_ADDR).  Need to reverse from FUNC_ADDR back to the
794      FN's descriptor address (while at the same time being careful to
795      find "FN" in the same object file as ".FN").  */
796   {
797     /* Find the minimal symbol that corresponds to FUNC_ADDR (should
798        have the name ".FN").  */
799     struct minimal_symbol *dot_fn = lookup_minimal_symbol_by_pc (func_addr);
800     if (dot_fn != NULL && SYMBOL_LINKAGE_NAME (dot_fn)[0] == '.')
801       {
802         /* Get the section that contains FUNC_ADR.  Need this for the
803            "objfile" that it contains.  */
804         struct obj_section *dot_fn_section = find_pc_section (func_addr);
805         if (dot_fn_section != NULL && dot_fn_section->objfile != NULL)
806           {
807             /* Now find the corresponding "FN" (dropping ".") minimal
808                symbol's address.  Only look for the minimal symbol in
809                ".FN"'s object file - avoids problems when two object
810                files (i.e., shared libraries) contain a minimal symbol
811                with the same name.  */
812             struct minimal_symbol *fn =
813               lookup_minimal_symbol (SYMBOL_LINKAGE_NAME (dot_fn) + 1, NULL,
814                                      dot_fn_section->objfile);
815             if (fn != NULL)
816               {
817                 /* Got the address of that descriptor.  The TOC is the
818                    second double word.  */
819                 CORE_ADDR toc =
820                   read_memory_unsigned_integer (SYMBOL_VALUE_ADDRESS (fn)
821                                                 + tdep->wordsize,
822                                                 tdep->wordsize);
823                 regcache_cooked_write_unsigned (regcache,
824                                                 tdep->ppc_gp0_regnum + 2, toc);
825               }
826           }
827       }
828   }
829
830   return sp;
831 }
832
833
834 /* The 64 bit ABI retun value convention.
835
836    Return non-zero if the return-value is stored in a register, return
837    0 if the return-value is instead stored on the stack (a.k.a.,
838    struct return convention).
839
840    For a return-value stored in a register: when WRITEBUF is non-NULL,
841    copy the buffer to the corresponding register return-value location
842    location; when READBUF is non-NULL, fill the buffer from the
843    corresponding register return-value location.  */
844 enum return_value_convention
845 ppc64_sysv_abi_return_value (struct gdbarch *gdbarch, struct type *valtype,
846                              struct regcache *regcache, void *readbuf,
847                              const void *writebuf)
848 {
849   struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
850   /* Floats and doubles in F1.  */
851   if (TYPE_CODE (valtype) == TYPE_CODE_FLT && TYPE_LENGTH (valtype) <= 8)
852     {
853       char regval[MAX_REGISTER_SIZE];
854       struct type *regtype = register_type (gdbarch, FP0_REGNUM);
855       if (writebuf != NULL)
856         {
857           convert_typed_floating (writebuf, valtype, regval, regtype);
858           regcache_cooked_write (regcache, FP0_REGNUM + 1, regval);
859         }
860       if (readbuf != NULL)
861         {
862           regcache_cooked_read (regcache, FP0_REGNUM + 1, regval);
863           convert_typed_floating (regval, regtype, readbuf, valtype);
864         }
865       return RETURN_VALUE_REGISTER_CONVENTION;
866     }
867   if (TYPE_CODE (valtype) == TYPE_CODE_INT && TYPE_LENGTH (valtype) <= 8)
868     {
869       /* Integers in r3.  */
870       if (writebuf != NULL)
871         {
872           /* Be careful to sign extend the value.  */
873           regcache_cooked_write_unsigned (regcache, tdep->ppc_gp0_regnum + 3,
874                                           unpack_long (valtype, writebuf));
875         }
876       if (readbuf != NULL)
877         {
878           /* Extract the integer from r3.  Since this is truncating the
879              value, there isn't a sign extension problem.  */
880           ULONGEST regval;
881           regcache_cooked_read_unsigned (regcache, tdep->ppc_gp0_regnum + 3,
882                                          &regval);
883           store_unsigned_integer (readbuf, TYPE_LENGTH (valtype), regval);
884         }
885       return RETURN_VALUE_REGISTER_CONVENTION;
886     }
887   /* All pointers live in r3.  */
888   if (TYPE_CODE (valtype) == TYPE_CODE_PTR)
889     {
890       /* All pointers live in r3.  */
891       if (writebuf != NULL)
892         regcache_cooked_write (regcache, tdep->ppc_gp0_regnum + 3, writebuf);
893       if (readbuf != NULL)
894         regcache_cooked_read (regcache, tdep->ppc_gp0_regnum + 3, readbuf);
895       return RETURN_VALUE_REGISTER_CONVENTION;
896     }
897   if (TYPE_CODE (valtype) == TYPE_CODE_ARRAY
898       && TYPE_LENGTH (valtype) <= 8
899       && TYPE_CODE (TYPE_TARGET_TYPE (valtype)) == TYPE_CODE_INT
900       && TYPE_LENGTH (TYPE_TARGET_TYPE (valtype)) == 1)
901     {
902       /* Small character arrays are returned, right justified, in r3.  */
903       int offset = (register_size (gdbarch, tdep->ppc_gp0_regnum + 3)
904                     - TYPE_LENGTH (valtype));
905       if (writebuf != NULL)
906         regcache_cooked_write_part (regcache, tdep->ppc_gp0_regnum + 3,
907                                     offset, TYPE_LENGTH (valtype), writebuf);
908       if (readbuf != NULL)
909         regcache_cooked_read_part (regcache, tdep->ppc_gp0_regnum + 3,
910                                    offset, TYPE_LENGTH (valtype), readbuf);
911       return RETURN_VALUE_REGISTER_CONVENTION;
912     }
913   /* Big floating point values get stored in adjacent floating
914      point registers.  */
915   if (TYPE_CODE (valtype) == TYPE_CODE_FLT
916       && (TYPE_LENGTH (valtype) == 16 || TYPE_LENGTH (valtype) == 32))
917     {
918       if (writebuf || readbuf != NULL)
919         {
920           int i;
921           for (i = 0; i < TYPE_LENGTH (valtype) / 8; i++)
922             {
923               if (writebuf != NULL)
924                 regcache_cooked_write (regcache, FP0_REGNUM + 1 + i,
925                                        (const bfd_byte *) writebuf + i * 8);
926               if (readbuf != NULL)
927                 regcache_cooked_read (regcache, FP0_REGNUM + 1 + i,
928                                       (bfd_byte *) readbuf + i * 8);
929             }
930         }
931       return RETURN_VALUE_REGISTER_CONVENTION;
932     }
933   /* Complex values get returned in f1:f2, need to convert.  */
934   if (TYPE_CODE (valtype) == TYPE_CODE_COMPLEX
935       && (TYPE_LENGTH (valtype) == 8 || TYPE_LENGTH (valtype) == 16))
936     {
937       if (regcache != NULL)
938         {
939           int i;
940           for (i = 0; i < 2; i++)
941             {
942               char regval[MAX_REGISTER_SIZE];
943               struct type *regtype =
944                 register_type (current_gdbarch, FP0_REGNUM);
945               if (writebuf != NULL)
946                 {
947                   convert_typed_floating ((const bfd_byte *) writebuf +
948                                           i * (TYPE_LENGTH (valtype) / 2),
949                                           valtype, regval, regtype);
950                   regcache_cooked_write (regcache, FP0_REGNUM + 1 + i,
951                                          regval);
952                 }
953               if (readbuf != NULL)
954                 {
955                   regcache_cooked_read (regcache, FP0_REGNUM + 1 + i, regval);
956                   convert_typed_floating (regval, regtype,
957                                           (bfd_byte *) readbuf +
958                                           i * (TYPE_LENGTH (valtype) / 2),
959                                           valtype);
960                 }
961             }
962         }
963       return RETURN_VALUE_REGISTER_CONVENTION;
964     }
965   /* Big complex values get stored in f1:f4.  */
966   if (TYPE_CODE (valtype) == TYPE_CODE_COMPLEX && TYPE_LENGTH (valtype) == 32)
967     {
968       if (regcache != NULL)
969         {
970           int i;
971           for (i = 0; i < 4; i++)
972             {
973               if (writebuf != NULL)
974                 regcache_cooked_write (regcache, FP0_REGNUM + 1 + i,
975                                        (const bfd_byte *) writebuf + i * 8);
976               if (readbuf != NULL)
977                 regcache_cooked_read (regcache, FP0_REGNUM + 1 + i,
978                                       (bfd_byte *) readbuf + i * 8);
979             }
980         }
981       return RETURN_VALUE_REGISTER_CONVENTION;
982     }
983   return RETURN_VALUE_STRUCT_CONVENTION;
984 }
985
986 CORE_ADDR
987 ppc64_sysv_abi_adjust_breakpoint_address (struct gdbarch *gdbarch,
988                                           CORE_ADDR bpaddr)
989 {
990   /* PPC64 SYSV specifies that the minimal-symbol "FN" should point at
991      a function-descriptor while the corresponding minimal-symbol
992      ".FN" should point at the entry point.  Consequently, a command
993      like "break FN" applied to an object file with only minimal
994      symbols, will insert the breakpoint into the descriptor at "FN"
995      and not the function at ".FN".  Avoid this confusion by adjusting
996      any attempt to set a descriptor breakpoint into a corresponding
997      function breakpoint.  Note that GDB warns the user when this
998      adjustment is applied - that's ok as otherwise the user will have
999      no way of knowing why their breakpoint at "FN" resulted in the
1000      program stopping at ".FN".  */
1001   return gdbarch_convert_from_func_ptr_addr (gdbarch, bpaddr, &current_target);
1002 }