Artifact a09d2ae714ba07ba8a3202181b6a83ab0596fac2:


0000: 2f 2a 20 76 61 63 61 6c 6c 20 66 75 6e 63 74 69  /* vacall functi
0010: 6f 6e 20 66 6f 72 20 6d 69 70 73 20 43 50 55 20  on for mips CPU 
0020: 2a 2f 0a 0a 2f 2a 0a 20 2a 20 43 6f 70 79 72 69  */../*. * Copyri
0030: 67 68 74 20 31 39 39 35 2d 32 30 30 34 20 42 72  ght 1995-2004 Br
0040: 75 6e 6f 20 48 61 69 62 6c 65 2c 20 3c 62 72 75  uno Haible, <bru
0050: 6e 6f 40 63 6c 69 73 70 2e 6f 72 67 3e 0a 20 2a  no@clisp.org>. *
0060: 0a 20 2a 20 54 68 69 73 20 69 73 20 66 72 65 65  . * This is free
0070: 20 73 6f 66 74 77 61 72 65 20 64 69 73 74 72 69   software distri
0080: 62 75 74 65 64 20 75 6e 64 65 72 20 74 68 65 20  buted under the 
0090: 47 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c  GNU General Publ
00a0: 69 63 20 4c 69 63 65 6e 63 65 0a 20 2a 20 64 65  ic Licence. * de
00b0: 73 63 72 69 62 65 64 20 69 6e 20 74 68 65 20 66  scribed in the f
00c0: 69 6c 65 20 43 4f 50 59 49 4e 47 2e 20 43 6f 6e  ile COPYING. Con
00d0: 74 61 63 74 20 74 68 65 20 61 75 74 68 6f 72 20  tact the author 
00e0: 69 66 20 79 6f 75 20 64 6f 6e 27 74 20 68 61 76  if you don't hav
00f0: 65 20 74 68 69 73 0a 20 2a 20 6f 72 20 63 61 6e  e this. * or can
0100: 27 74 20 6c 69 76 65 20 77 69 74 68 20 69 74 2e  't live with it.
0110: 20 54 68 65 72 65 20 69 73 20 41 42 53 4f 4c 55   There is ABSOLU
0120: 54 45 4c 59 20 4e 4f 20 57 41 52 52 41 4e 54 59  TELY NO WARRANTY
0130: 2c 20 65 78 70 6c 69 63 69 74 20 6f 72 20 69 6d  , explicit or im
0140: 70 6c 69 65 64 2c 0a 20 2a 20 6f 6e 20 74 68 69  plied,. * on thi
0150: 73 20 73 6f 66 74 77 61 72 65 2e 0a 20 2a 2f 0a  s software.. */.
0160: 0a 23 69 66 6e 64 65 66 20 52 45 45 4e 54 52 41  .#ifndef REENTRA
0170: 4e 54 0a 23 69 6e 63 6c 75 64 65 20 22 76 61 63  NT.#include "vac
0180: 61 6c 6c 2e 68 2e 69 6e 22 0a 23 65 6c 73 65 20  all.h.in".#else 
0190: 2f 2a 20 52 45 45 4e 54 52 41 4e 54 20 2a 2f 0a  /* REENTRANT */.
01a0: 23 69 6e 63 6c 75 64 65 20 22 76 61 63 61 6c 6c  #include "vacall
01b0: 5f 72 2e 68 2e 69 6e 22 0a 23 65 6e 64 69 66 0a  _r.h.in".#endif.
01c0: 0a 23 69 66 6e 64 65 66 20 52 45 45 4e 54 52 41  .#ifndef REENTRA
01d0: 4e 54 0a 74 79 70 65 64 65 66 20 76 6f 69 64 20  NT.typedef void 
01e0: 28 2a 66 75 6e 63 5f 70 6f 69 6e 74 65 72 29 28  (*func_pointer)(
01f0: 76 61 5f 61 6c 69 73 74 29 3b 0a 23 65 6c 73 65  va_alist);.#else
0200: 20 2f 2a 20 52 45 45 4e 54 52 41 4e 54 20 2a 2f   /* REENTRANT */
0210: 0a 23 64 65 66 69 6e 65 20 5f 5f 76 61 63 61 6c  .#define __vacal
0220: 6c 20 5f 5f 76 61 63 61 6c 6c 5f 72 0a 74 79 70  l __vacall_r.typ
0230: 65 64 65 66 20 76 6f 69 64 20 28 2a 66 75 6e 63  edef void (*func
0240: 5f 70 6f 69 6e 74 65 72 29 28 76 6f 69 64 2a 2c  _pointer)(void*,
0250: 76 61 5f 61 6c 69 73 74 29 3b 0a 72 65 67 69 73  va_alist);.regis
0260: 74 65 72 20 73 74 72 75 63 74 20 7b 20 66 75 6e  ter struct { fun
0270: 63 5f 70 6f 69 6e 74 65 72 20 76 61 63 61 6c 6c  c_pointer vacall
0280: 5f 66 75 6e 63 74 69 6f 6e 3b 20 76 6f 69 64 2a  _function; void*
0290: 20 61 72 67 3b 20 7d 0a 20 20 20 20 20 20 20 20   arg; }.        
02a0: 20 2a 09 65 6e 76 09 5f 5f 61 73 6d 5f 5f 28 22   *.env.__asm__("
02b0: 24 32 22 29 3b 0a 23 65 6e 64 69 66 0a 72 65 67  $2");.#endif.reg
02c0: 69 73 74 65 72 20 66 75 6e 63 5f 70 6f 69 6e 74  ister func_point
02d0: 65 72 20 74 39 20 5f 5f 61 73 6d 5f 5f 28 22 24  er t9 __asm__("$
02e0: 32 35 22 29 3b 0a 72 65 67 69 73 74 65 72 20 66  25");.register f
02f0: 6c 6f 61 74 09 66 61 72 67 31 09 5f 5f 61 73 6d  loat.farg1.__asm
0300: 5f 5f 28 22 24 66 31 32 22 29 3b 0a 72 65 67 69  __("$f12");.regi
0310: 73 74 65 72 20 66 6c 6f 61 74 09 66 61 72 67 32  ster float.farg2
0320: 09 5f 5f 61 73 6d 5f 5f 28 22 24 66 31 34 22 29  .__asm__("$f14")
0330: 3b 0a 72 65 67 69 73 74 65 72 20 64 6f 75 62 6c  ;.register doubl
0340: 65 09 64 61 72 67 31 09 5f 5f 61 73 6d 5f 5f 28  e.darg1.__asm__(
0350: 22 24 66 31 32 22 29 3b 0a 72 65 67 69 73 74 65  "$f12");.registe
0360: 72 20 64 6f 75 62 6c 65 09 64 61 72 67 32 09 5f  r double.darg2._
0370: 5f 61 73 6d 5f 5f 28 22 24 66 31 34 22 29 3b 0a  _asm__("$f14");.
0380: 72 65 67 69 73 74 65 72 20 69 6e 74 09 69 72 65  register int.ire
0390: 74 09 5f 5f 61 73 6d 5f 5f 28 22 24 32 22 29 3b  t.__asm__("$2");
03a0: 0a 72 65 67 69 73 74 65 72 20 69 6e 74 09 69 72  .register int.ir
03b0: 65 74 32 09 5f 5f 61 73 6d 5f 5f 28 22 24 33 22  et2.__asm__("$3"
03c0: 29 3b 0a 72 65 67 69 73 74 65 72 20 66 6c 6f 61  );.register floa
03d0: 74 09 66 72 65 74 09 5f 5f 61 73 6d 5f 5f 28 22  t.fret.__asm__("
03e0: 24 66 30 22 29 3b 0a 72 65 67 69 73 74 65 72 20  $f0");.register 
03f0: 64 6f 75 62 6c 65 09 64 72 65 74 09 5f 5f 61 73  double.dret.__as
0400: 6d 5f 5f 28 22 24 66 30 22 29 3b 0a 0a 76 6f 69  m__("$f0");..voi
0410: 64 20 2f 2a 20 74 68 65 20 72 65 74 75 72 6e 20  d /* the return 
0420: 74 79 70 65 20 69 73 20 76 61 72 69 61 62 6c 65  type is variable
0430: 2c 20 6e 6f 74 20 76 6f 69 64 21 20 2a 2f 0a 5f  , not void! */._
0440: 5f 76 61 63 61 6c 6c 20 28 5f 5f 76 61 77 6f 72  _vacall (__vawor
0450: 64 20 77 6f 72 64 31 2c 20 5f 5f 76 61 77 6f 72  d word1, __vawor
0460: 64 20 77 6f 72 64 32 2c 20 5f 5f 76 61 77 6f 72  d word2, __vawor
0470: 64 20 77 6f 72 64 33 2c 20 5f 5f 76 61 77 6f 72  d word3, __vawor
0480: 64 20 77 6f 72 64 34 2c 0a 20 20 20 20 20 20 20  d word4,.       
0490: 20 20 20 5f 5f 76 61 77 6f 72 64 20 66 69 72 73     __vaword firs
04a0: 74 77 6f 72 64 29 0a 7b 0a 20 20 5f 5f 76 61 5f  tword).{.  __va_
04b0: 61 6c 69 73 74 20 6c 69 73 74 3b 0a 20 20 2f 2a  alist list;.  /*
04c0: 20 67 63 63 2d 32 2e 36 2e 33 20 73 6f 75 72 63   gcc-2.6.3 sourc
04d0: 65 20 73 61 79 73 3a 20 57 68 65 6e 20 61 20 70  e says: When a p
04e0: 61 72 61 6d 65 74 65 72 20 69 73 20 70 61 73 73  arameter is pass
04f0: 65 64 20 69 6e 20 61 20 72 65 67 69 73 74 65 72  ed in a register
0500: 2c 0a 20 20 20 2a 20 73 74 61 63 6b 20 73 70 61  ,.   * stack spa
0510: 63 65 20 69 73 20 73 74 69 6c 6c 20 61 6c 6c 6f  ce is still allo
0520: 63 61 74 65 64 20 66 6f 72 20 69 74 2e 0a 20 20  cated for it..  
0530: 20 2a 2f 0a 20 20 2f 2a 20 4d 6f 76 65 20 74 68   */.  /* Move th
0540: 65 20 61 72 67 75 6d 65 6e 74 73 20 70 61 73 73  e arguments pass
0550: 65 64 20 69 6e 20 72 65 67 69 73 74 65 72 73 20  ed in registers 
0560: 74 6f 20 74 68 65 69 72 20 73 74 61 63 6b 20 6c  to their stack l
0570: 6f 63 61 74 69 6f 6e 73 2e 20 2a 2f 0a 20 20 28  ocations. */.  (
0580: 26 66 69 72 73 74 77 6f 72 64 29 5b 2d 34 5d 20  &firstword)[-4] 
0590: 3d 20 77 6f 72 64 31 3b 0a 20 20 28 26 66 69 72  = word1;.  (&fir
05a0: 73 74 77 6f 72 64 29 5b 2d 33 5d 20 3d 20 77 6f  stword)[-3] = wo
05b0: 72 64 32 3b 0a 20 20 28 26 66 69 72 73 74 77 6f  rd2;.  (&firstwo
05c0: 72 64 29 5b 2d 32 5d 20 3d 20 77 6f 72 64 33 3b  rd)[-2] = word3;
05d0: 0a 20 20 28 26 66 69 72 73 74 77 6f 72 64 29 5b  .  (&firstword)[
05e0: 2d 31 5d 20 3d 20 77 6f 72 64 34 3b 0a 20 20 6c  -1] = word4;.  l
05f0: 69 73 74 2e 64 61 72 67 5b 30 5d 20 3d 20 64 61  ist.darg[0] = da
0600: 72 67 31 3b 0a 20 20 6c 69 73 74 2e 64 61 72 67  rg1;.  list.darg
0610: 5b 31 5d 20 3d 20 64 61 72 67 32 3b 0a 20 20 6c  [1] = darg2;.  l
0620: 69 73 74 2e 66 61 72 67 5b 30 5d 20 3d 20 66 61  ist.farg[0] = fa
0630: 72 67 31 3b 0a 20 20 6c 69 73 74 2e 66 61 72 67  rg1;.  list.farg
0640: 5b 31 5d 20 3d 20 66 61 72 67 32 3b 0a 20 20 2f  [1] = farg2;.  /
0650: 2a 20 50 72 65 70 61 72 65 20 74 68 65 20 76 61  * Prepare the va
0660: 5f 61 6c 69 73 74 2e 20 2a 2f 0a 20 20 6c 69 73  _alist. */.  lis
0670: 74 2e 66 6c 61 67 73 20 3d 20 30 3b 0a 20 20 6c  t.flags = 0;.  l
0680: 69 73 74 2e 61 70 74 72 20 3d 20 28 6c 6f 6e 67  ist.aptr = (long
0690: 29 28 26 66 69 72 73 74 77 6f 72 64 20 2d 20 34  )(&firstword - 4
06a0: 29 3b 0a 20 20 6c 69 73 74 2e 72 61 64 64 72 20  );.  list.raddr 
06b0: 3d 20 28 76 6f 69 64 2a 29 30 3b 0a 20 20 6c 69  = (void*)0;.  li
06c0: 73 74 2e 72 74 79 70 65 20 3d 20 5f 5f 56 41 76  st.rtype = __VAv
06d0: 6f 69 64 3b 0a 20 20 6c 69 73 74 2e 6d 65 6d 61  oid;.  list.mema
06e0: 72 67 70 74 72 20 3d 20 28 6c 6f 6e 67 29 26 66  rgptr = (long)&f
06f0: 69 72 73 74 77 6f 72 64 3b 0a 20 20 6c 69 73 74  irstword;.  list
0700: 2e 61 6e 75 6d 20 3d 20 30 3b 0a 20 20 2f 2a 20  .anum = 0;.  /* 
0710: 43 61 6c 6c 20 76 61 63 61 6c 6c 5f 66 75 6e 63  Call vacall_func
0720: 74 69 6f 6e 2e 20 54 68 65 20 6d 61 63 72 6f 73  tion. The macros
0730: 20 64 6f 20 61 6c 6c 20 74 68 65 20 72 65 73 74   do all the rest
0740: 2e 20 2a 2f 0a 23 69 66 6e 64 65 66 20 52 45 45  . */.#ifndef REE
0750: 4e 54 52 41 4e 54 0a 20 20 28 2a 28 74 39 20 3d  NTRANT.  (*(t9 =
0760: 20 76 61 63 61 6c 6c 5f 66 75 6e 63 74 69 6f 6e   vacall_function
0770: 29 29 20 28 26 6c 69 73 74 29 3b 0a 23 65 6c 73  )) (&list);.#els
0780: 65 20 2f 2a 20 52 45 45 4e 54 52 41 4e 54 20 2a  e /* REENTRANT *
0790: 2f 0a 20 20 28 2a 28 74 39 20 3d 20 65 6e 76 2d  /.  (*(t9 = env-
07a0: 3e 76 61 63 61 6c 6c 5f 66 75 6e 63 74 69 6f 6e  >vacall_function
07b0: 29 29 20 28 65 6e 76 2d 3e 61 72 67 2c 26 6c 69  )) (env->arg,&li
07c0: 73 74 29 3b 0a 23 65 6e 64 69 66 0a 20 20 2f 2a  st);.#endif.  /*
07d0: 20 50 75 74 20 72 65 74 75 72 6e 20 76 61 6c 75   Put return valu
07e0: 65 20 69 6e 74 6f 20 70 72 6f 70 65 72 20 72 65  e into proper re
07f0: 67 69 73 74 65 72 2e 20 2a 2f 0a 20 20 69 66 20  gister. */.  if 
0800: 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f  (list.rtype == _
0810: 5f 56 41 76 6f 69 64 29 20 7b 0a 20 20 7d 20 65  _VAvoid) {.  } e
0820: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0830: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 63 68 61 72  type == __VAchar
0840: 29 20 7b 0a 20 20 20 20 69 72 65 74 20 3d 20 6c  ) {.    iret = l
0850: 69 73 74 2e 74 6d 70 2e 5f 63 68 61 72 3b 0a 20  ist.tmp._char;. 
0860: 20 7d 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69   } else.  if (li
0870: 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41  st.rtype == __VA
0880: 73 63 68 61 72 29 20 7b 0a 20 20 20 20 69 72 65  schar) {.    ire
0890: 74 20 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f 73 63  t = list.tmp._sc
08a0: 68 61 72 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20  har;.  } else.  
08b0: 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d  if (list.rtype =
08c0: 3d 20 5f 5f 56 41 75 63 68 61 72 29 20 7b 0a 20  = __VAuchar) {. 
08d0: 20 20 20 69 72 65 74 20 3d 20 6c 69 73 74 2e 74     iret = list.t
08e0: 6d 70 2e 5f 75 63 68 61 72 3b 0a 20 20 7d 20 65  mp._uchar;.  } e
08f0: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0900: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 73 68 6f 72  type == __VAshor
0910: 74 29 20 7b 0a 20 20 20 20 69 72 65 74 20 3d 20  t) {.    iret = 
0920: 6c 69 73 74 2e 74 6d 70 2e 5f 73 68 6f 72 74 3b  list.tmp._short;
0930: 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66 20 28  .  } else.  if (
0940: 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f  list.rtype == __
0950: 56 41 75 73 68 6f 72 74 29 20 7b 0a 20 20 20 20  VAushort) {.    
0960: 69 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d 70 2e  iret = list.tmp.
0970: 5f 75 73 68 6f 72 74 3b 0a 20 20 7d 20 65 6c 73  _ushort;.  } els
0980: 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72 74 79  e.  if (list.rty
0990: 70 65 20 3d 3d 20 5f 5f 56 41 69 6e 74 29 20 7b  pe == __VAint) {
09a0: 0a 20 20 20 20 69 72 65 74 20 3d 20 6c 69 73 74  .    iret = list
09b0: 2e 74 6d 70 2e 5f 69 6e 74 3b 0a 20 20 7d 20 65  .tmp._int;.  } e
09c0: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
09d0: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 75 69 6e 74  type == __VAuint
09e0: 29 20 7b 0a 20 20 20 20 69 72 65 74 20 3d 20 6c  ) {.    iret = l
09f0: 69 73 74 2e 74 6d 70 2e 5f 75 69 6e 74 3b 0a 20  ist.tmp._uint;. 
0a00: 20 7d 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69   } else.  if (li
0a10: 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41  st.rtype == __VA
0a20: 6c 6f 6e 67 29 20 7b 0a 20 20 20 20 69 72 65 74  long) {.    iret
0a30: 20 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f 6c 6f 6e   = list.tmp._lon
0a40: 67 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66  g;.  } else.  if
0a50: 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20   (list.rtype == 
0a60: 5f 5f 56 41 75 6c 6f 6e 67 29 20 7b 0a 20 20 20  __VAulong) {.   
0a70: 20 69 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d 70   iret = list.tmp
0a80: 2e 5f 75 6c 6f 6e 67 3b 0a 20 20 7d 20 65 6c 73  ._ulong;.  } els
0a90: 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72 74 79  e.  if (list.rty
0aa0: 70 65 20 3d 3d 20 5f 5f 56 41 6c 6f 6e 67 6c 6f  pe == __VAlonglo
0ab0: 6e 67 20 7c 7c 20 6c 69 73 74 2e 72 74 79 70 65  ng || list.rtype
0ac0: 20 3d 3d 20 5f 5f 56 41 75 6c 6f 6e 67 6c 6f 6e   == __VAulonglon
0ad0: 67 29 20 7b 0a 20 20 20 20 69 72 65 74 20 20 3d  g) {.    iret  =
0ae0: 20 28 28 5f 5f 76 61 77 6f 72 64 20 2a 29 20 26   ((__vaword *) &
0af0: 6c 69 73 74 2e 74 6d 70 2e 5f 6c 6f 6e 67 6c 6f  list.tmp._longlo
0b00: 6e 67 29 5b 30 5d 3b 0a 20 20 20 20 69 72 65 74  ng)[0];.    iret
0b10: 32 20 3d 20 28 28 5f 5f 76 61 77 6f 72 64 20 2a  2 = ((__vaword *
0b20: 29 20 26 6c 69 73 74 2e 74 6d 70 2e 5f 6c 6f 6e  ) &list.tmp._lon
0b30: 67 6c 6f 6e 67 29 5b 31 5d 3b 0a 20 20 7d 20 65  glong)[1];.  } e
0b40: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0b50: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 66 6c 6f 61  type == __VAfloa
0b60: 74 29 20 7b 0a 20 20 20 20 66 72 65 74 20 3d 20  t) {.    fret = 
0b70: 6c 69 73 74 2e 74 6d 70 2e 5f 66 6c 6f 61 74 3b  list.tmp._float;
0b80: 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66 20 28  .  } else.  if (
0b90: 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f  list.rtype == __
0ba0: 56 41 64 6f 75 62 6c 65 29 20 7b 0a 20 20 20 20  VAdouble) {.    
0bb0: 64 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d 70 2e  dret = list.tmp.
0bc0: 5f 64 6f 75 62 6c 65 3b 0a 20 20 7d 20 65 6c 73  _double;.  } els
0bd0: 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72 74 79  e.  if (list.rty
0be0: 70 65 20 3d 3d 20 5f 5f 56 41 76 6f 69 64 70 29  pe == __VAvoidp)
0bf0: 20 7b 0a 20 20 20 20 69 72 65 74 20 3d 20 28 6c   {.    iret = (l
0c00: 6f 6e 67 29 6c 69 73 74 2e 74 6d 70 2e 5f 70 74  ong)list.tmp._pt
0c10: 72 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66  r;.  } else.  if
0c20: 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20   (list.rtype == 
0c30: 5f 5f 56 41 73 74 72 75 63 74 29 20 7b 0a 20 20  __VAstruct) {.  
0c40: 20 20 69 66 20 28 6c 69 73 74 2e 66 6c 61 67 73    if (list.flags
0c50: 20 26 20 5f 5f 56 41 5f 50 43 43 5f 53 54 52 55   & __VA_PCC_STRU
0c60: 43 54 5f 52 45 54 55 52 4e 29 20 7b 0a 20 20 20  CT_RETURN) {.   
0c70: 20 20 20 2f 2a 20 70 63 63 20 73 74 72 75 63 74     /* pcc struct
0c80: 20 72 65 74 75 72 6e 20 63 6f 6e 76 65 6e 74 69   return conventi
0c90: 6f 6e 20 2a 2f 0a 20 20 20 20 20 20 69 72 65 74  on */.      iret
0ca0: 20 3d 20 28 6c 6f 6e 67 29 20 6c 69 73 74 2e 72   = (long) list.r
0cb0: 61 64 64 72 3b 0a 20 20 20 20 7d 20 65 6c 73 65  addr;.    } else
0cc0: 20 7b 0a 20 20 20 20 20 20 2f 2a 20 6e 6f 72 6d   {.      /* norm
0cd0: 61 6c 20 73 74 72 75 63 74 20 72 65 74 75 72 6e  al struct return
0ce0: 20 63 6f 6e 76 65 6e 74 69 6f 6e 20 2a 2f 0a 20   convention */. 
0cf0: 20 20 20 20 20 69 66 20 28 6c 69 73 74 2e 66 6c       if (list.fl
0d00: 61 67 73 20 26 20 5f 5f 56 41 5f 53 4d 41 4c 4c  ags & __VA_SMALL
0d10: 5f 53 54 52 55 43 54 5f 52 45 54 55 52 4e 29 20  _STRUCT_RETURN) 
0d20: 7b 0a 20 20 20 20 20 20 20 20 69 66 20 28 6c 69  {.        if (li
0d30: 73 74 2e 72 73 69 7a 65 20 3d 3d 20 73 69 7a 65  st.rsize == size
0d40: 6f 66 28 63 68 61 72 29 29 20 7b 0a 20 20 20 20  of(char)) {.    
0d50: 20 20 20 20 20 20 69 72 65 74 20 3d 20 2a 28 75        iret = *(u
0d60: 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a 29 20  nsigned char *) 
0d70: 6c 69 73 74 2e 72 61 64 64 72 3b 0a 20 20 20 20  list.raddr;.    
0d80: 20 20 20 20 7d 20 65 6c 73 65 0a 20 20 20 20 20      } else.     
0d90: 20 20 20 69 66 20 28 6c 69 73 74 2e 72 73 69 7a     if (list.rsiz
0da0: 65 20 3d 3d 20 73 69 7a 65 6f 66 28 73 68 6f 72  e == sizeof(shor
0db0: 74 29 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20  t)) {.          
0dc0: 69 72 65 74 20 3d 20 2a 28 75 6e 73 69 67 6e 65  iret = *(unsigne
0dd0: 64 20 73 68 6f 72 74 20 2a 29 20 6c 69 73 74 2e  d short *) list.
0de0: 72 61 64 64 72 3b 0a 20 20 20 20 20 20 20 20 7d  raddr;.        }
0df0: 20 65 6c 73 65 0a 20 20 20 20 20 20 20 20 69 66   else.        if
0e00: 20 28 6c 69 73 74 2e 72 73 69 7a 65 20 3d 3d 20   (list.rsize == 
0e10: 73 69 7a 65 6f 66 28 69 6e 74 29 29 20 7b 0a 20  sizeof(int)) {. 
0e20: 20 20 20 20 20 20 20 20 20 69 72 65 74 20 3d 20           iret = 
0e30: 2a 28 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 2a  *(unsigned int *
0e40: 29 20 6c 69 73 74 2e 72 61 64 64 72 3b 0a 20 20  ) list.raddr;.  
0e50: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
0e60: 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a                  }.  }.}.