Artifact 4f668d66b54c8ba5f1f3fafefb7f37d7159d0d05:


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 53 2f 33 39 30 20 43 50 55  on for S/390 CPU
0020: 20 2a 2f 0a 0a 2f 2a 0a 20 2a 20 43 6f 70 79 72   */../*. * Copyr
0030: 69 67 68 74 20 31 39 39 35 2d 32 30 30 34 20 42  ight 1995-2004 B
0040: 72 75 6e 6f 20 48 61 69 62 6c 65 2c 20 3c 62 72  runo Haible, <br
0050: 75 6e 6f 40 63 6c 69 73 70 2e 6f 72 67 3e 0a 20  uno@clisp.org>. 
0060: 2a 20 43 6f 70 79 72 69 67 68 74 20 32 30 30 30  * Copyright 2000
0070: 20 41 64 61 6d 20 46 65 64 6f 72 2c 20 3c 66 65   Adam Fedor, <fe
0080: 64 6f 72 40 67 6e 75 2e 6f 72 67 3e 0a 20 2a 20  dor@gnu.org>. * 
0090: 43 6f 70 79 72 69 67 68 74 20 32 30 30 31 20 47  Copyright 2001 G
00a0: 65 72 68 61 72 64 20 54 6f 6e 6e 2c 20 3c 67 74  erhard Tonn, <gt
00b0: 40 64 65 62 69 61 6e 2e 6f 72 67 3e 0a 20 2a 0a  @debian.org>. *.
00c0: 20 2a 20 54 68 69 73 20 69 73 20 66 72 65 65 20   * This is free 
00d0: 73 6f 66 74 77 61 72 65 20 64 69 73 74 72 69 62  software distrib
00e0: 75 74 65 64 20 75 6e 64 65 72 20 74 68 65 20 47  uted under the G
00f0: 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69  NU General Publi
0100: 63 20 4c 69 63 65 6e 63 65 0a 20 2a 20 64 65 73  c Licence. * des
0110: 63 72 69 62 65 64 20 69 6e 20 74 68 65 20 66 69  cribed in the fi
0120: 6c 65 20 43 4f 50 59 49 4e 47 2e 20 43 6f 6e 74  le COPYING. Cont
0130: 61 63 74 20 74 68 65 20 61 75 74 68 6f 72 20 69  act the author i
0140: 66 20 79 6f 75 20 64 6f 6e 27 74 20 68 61 76 65  f you don't have
0150: 20 74 68 69 73 0a 20 2a 20 6f 72 20 63 61 6e 27   this. * or can'
0160: 74 20 6c 69 76 65 20 77 69 74 68 20 69 74 2e 20  t live with it. 
0170: 54 68 65 72 65 20 69 73 20 41 42 53 4f 4c 55 54  There is ABSOLUT
0180: 45 4c 59 20 4e 4f 20 57 41 52 52 41 4e 54 59 2c  ELY NO WARRANTY,
0190: 20 65 78 70 6c 69 63 69 74 20 6f 72 20 69 6d 70   explicit or imp
01a0: 6c 69 65 64 2c 0a 20 2a 20 6f 6e 20 74 68 69 73  lied,. * on this
01b0: 20 73 6f 66 74 77 61 72 65 2e 0a 20 2a 2f 0a 0a   software.. */..
01c0: 23 69 66 6e 64 65 66 20 52 45 45 4e 54 52 41 4e  #ifndef REENTRAN
01d0: 54 0a 23 69 6e 63 6c 75 64 65 20 22 76 61 63 61  T.#include "vaca
01e0: 6c 6c 2e 68 22 0a 23 65 6c 73 65 20 2f 2a 20 52  ll.h".#else /* R
01f0: 45 45 4e 54 52 41 4e 54 20 2a 2f 0a 23 69 6e 63  EENTRANT */.#inc
0200: 6c 75 64 65 20 22 76 61 63 61 6c 6c 5f 72 2e 68  lude "vacall_r.h
0210: 2e 69 6e 22 0a 23 65 6e 64 69 66 0a 0a 23 69 66  .in".#endif..#if
0220: 64 65 66 20 52 45 45 4e 54 52 41 4e 54 0a 23 64  def REENTRANT.#d
0230: 65 66 69 6e 65 20 5f 5f 76 61 63 61 6c 6c 20 5f  efine __vacall _
0240: 5f 76 61 63 61 6c 6c 5f 72 0a 72 65 67 69 73 74  _vacall_r.regist
0250: 65 72 20 73 74 72 75 63 74 20 7b 20 76 6f 69 64  er struct { void
0260: 20 28 2a 76 61 63 61 6c 6c 5f 66 75 6e 63 74 69   (*vacall_functi
0270: 6f 6e 29 20 28 76 6f 69 64 2a 2c 76 61 5f 61 6c  on) (void*,va_al
0280: 69 73 74 29 3b 20 76 6f 69 64 2a 20 61 72 67 3b  ist); void* arg;
0290: 20 7d 0a 20 20 20 20 20 20 20 20 20 2a 09 09 65   }.         *..e
02a0: 6e 76 09 5f 5f 61 73 6d 5f 5f 28 22 72 31 22 29  nv.__asm__("r1")
02b0: 3b 0a 23 65 6e 64 69 66 0a 72 65 67 69 73 74 65  ;.#endif.registe
02c0: 72 20 66 6c 6f 61 74 20 09 09 66 61 72 67 31 09  r float ..farg1.
02d0: 5f 5f 61 73 6d 5f 5f 28 22 66 30 22 29 3b 0a 72  __asm__("f0");.r
02e0: 65 67 69 73 74 65 72 20 66 6c 6f 61 74 09 09 66  egister float..f
02f0: 61 72 67 32 09 5f 5f 61 73 6d 5f 5f 28 22 66 32  arg2.__asm__("f2
0300: 22 29 3b 0a 72 65 67 69 73 74 65 72 20 64 6f 75  ");.register dou
0310: 62 6c 65 09 09 64 61 72 67 31 09 5f 5f 61 73 6d  ble..darg1.__asm
0320: 5f 5f 28 22 66 30 22 29 3b 0a 72 65 67 69 73 74  __("f0");.regist
0330: 65 72 20 64 6f 75 62 6c 65 09 09 64 61 72 67 32  er double..darg2
0340: 09 5f 5f 61 73 6d 5f 5f 28 22 66 32 22 29 3b 0a  .__asm__("f2");.
0350: 72 65 67 69 73 74 65 72 20 5f 5f 76 61 77 6f 72  register __vawor
0360: 64 09 69 72 65 74 09 5f 5f 61 73 6d 5f 5f 28 22  d.iret.__asm__("
0370: 25 72 32 22 29 3b 0a 72 65 67 69 73 74 65 72 20  %r2");.register 
0380: 5f 5f 76 61 77 6f 72 64 09 69 72 65 74 32 09 5f  __vaword.iret2._
0390: 5f 61 73 6d 5f 5f 28 22 25 72 33 22 29 3b 0a 72  _asm__("%r3");.r
03a0: 65 67 69 73 74 65 72 20 66 6c 6f 61 74 09 09 66  egister float..f
03b0: 72 65 74 09 5f 5f 61 73 6d 5f 5f 28 22 25 66 30  ret.__asm__("%f0
03c0: 22 29 3b 0a 72 65 67 69 73 74 65 72 20 64 6f 75  ");.register dou
03d0: 62 6c 65 09 09 64 72 65 74 09 5f 5f 61 73 6d 5f  ble..dret.__asm_
03e0: 5f 28 22 25 66 30 22 29 3b 0a 0a 76 6f 69 64 20  _("%f0");..void 
03f0: 2f 2a 20 74 68 65 20 72 65 74 75 72 6e 20 74 79  /* the return ty
0400: 70 65 20 69 73 20 76 61 72 69 61 62 6c 65 2c 20  pe is variable, 
0410: 6e 6f 74 20 76 6f 69 64 21 20 2a 2f 0a 5f 5f 76  not void! */.__v
0420: 61 63 61 6c 6c 20 28 5f 5f 76 61 77 6f 72 64 20  acall (__vaword 
0430: 77 6f 72 64 31 2c 20 5f 5f 76 61 77 6f 72 64 20  word1, __vaword 
0440: 77 6f 72 64 32 2c 20 5f 5f 76 61 77 6f 72 64 20  word2, __vaword 
0450: 77 6f 72 64 33 2c 20 5f 5f 76 61 77 6f 72 64 20  word3, __vaword 
0460: 77 6f 72 64 34 2c 0a 20 20 20 20 20 20 20 20 20  word4,.         
0470: 20 5f 5f 76 61 77 6f 72 64 20 77 6f 72 64 35 2c   __vaword word5,
0480: 0a 20 20 20 20 20 20 20 20 20 20 5f 5f 76 61 77  .          __vaw
0490: 6f 72 64 20 66 69 72 73 74 77 6f 72 64 29 0a 7b  ord firstword).{
04a0: 0a 20 20 5f 5f 76 61 5f 61 6c 69 73 74 20 6c 69  .  __va_alist li
04b0: 73 74 3b 0a 20 20 2f 2a 20 4d 6f 76 65 20 74 68  st;.  /* Move th
04c0: 65 20 61 72 67 75 6d 65 6e 74 73 20 70 61 73 73  e arguments pass
04d0: 65 64 20 69 6e 20 72 65 67 69 73 74 65 72 73 20  ed in registers 
04e0: 74 6f 20 74 65 6d 70 20 73 74 6f 72 61 67 65 2c  to temp storage,
04f0: 20 73 69 6e 63 65 0a 20 20 20 20 20 6d 6f 76 69   since.     movi
0500: 6e 67 20 74 68 65 6d 20 74 6f 20 74 68 65 20 73  ng them to the s
0510: 74 61 63 6b 20 77 6f 75 6c 64 20 6d 65 73 73 20  tack would mess 
0520: 75 70 20 74 68 65 20 73 74 61 63 6b 20 2a 2f 0a  up the stack */.
0530: 20 20 6c 69 73 74 2e 72 65 67 61 72 67 5b 30 5d    list.regarg[0]
0540: 20 3d 20 77 6f 72 64 31 3b 0a 20 20 6c 69 73 74   = word1;.  list
0550: 2e 72 65 67 61 72 67 5b 31 5d 20 3d 20 77 6f 72  .regarg[1] = wor
0560: 64 32 3b 0a 20 20 6c 69 73 74 2e 72 65 67 61 72  d2;.  list.regar
0570: 67 5b 32 5d 20 3d 20 77 6f 72 64 33 3b 0a 20 20  g[2] = word3;.  
0580: 6c 69 73 74 2e 72 65 67 61 72 67 5b 33 5d 20 3d  list.regarg[3] =
0590: 20 77 6f 72 64 34 3b 0a 20 20 6c 69 73 74 2e 72   word4;.  list.r
05a0: 65 67 61 72 67 5b 34 5d 20 3d 20 77 6f 72 64 35  egarg[4] = word5
05b0: 3b 0a 0a 20 20 6c 69 73 74 2e 64 61 72 67 5b 31  ;..  list.darg[1
05c0: 5d 20 3d 20 64 61 72 67 32 3b 0a 20 20 6c 69 73  ] = darg2;.  lis
05d0: 74 2e 64 61 72 67 5b 30 5d 20 3d 20 64 61 72 67  t.darg[0] = darg
05e0: 31 3b 0a 0a 20 20 6c 69 73 74 2e 66 61 72 67 5b  1;..  list.farg[
05f0: 31 5d 20 3d 20 66 61 72 67 32 3b 0a 20 20 6c 69  1] = farg2;.  li
0600: 73 74 2e 66 61 72 67 5b 30 5d 20 3d 20 66 61 72  st.farg[0] = far
0610: 67 31 3b 0a 0a 20 20 2f 2a 20 50 72 65 70 61 72  g1;..  /* Prepar
0620: 65 20 74 68 65 20 76 61 5f 61 6c 69 73 74 2e 20  e the va_alist. 
0630: 2a 2f 0a 20 20 6c 69 73 74 2e 66 6c 61 67 73 20  */.  list.flags 
0640: 3d 20 30 3b 0a 20 20 6c 69 73 74 2e 61 70 74 72  = 0;.  list.aptr
0650: 20 3d 20 28 6c 6f 6e 67 29 28 26 6c 69 73 74 2e   = (long)(&list.
0660: 72 65 67 61 72 67 5b 30 5d 29 3b 0a 20 20 6c 69  regarg[0]);.  li
0670: 73 74 2e 73 61 70 74 72 20 3d 20 28 6c 6f 6e 67  st.saptr = (long
0680: 29 28 26 66 69 72 73 74 77 6f 72 64 29 3b 0a 20  )(&firstword);. 
0690: 20 6c 69 73 74 2e 6f 6e 73 74 61 63 6b 20 3d 20   list.onstack = 
06a0: 30 3b 0a 20 20 6c 69 73 74 2e 72 61 64 64 72 20  0;.  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 66  oid;.  list.memf
06e0: 61 72 67 70 74 72 20 3d 20 26 6c 69 73 74 2e 66  argptr = &list.f
06f0: 61 72 67 5b 30 5d 3b 0a 20 20 6c 69 73 74 2e 6d  arg[0];.  list.m
0700: 65 6d 64 61 72 67 70 74 72 20 3d 20 26 6c 69 73  emdargptr = &lis
0710: 74 2e 64 61 72 67 5b 30 5d 3b 0a 20 20 2f 2a 20  t.darg[0];.  /* 
0720: 43 61 6c 6c 20 76 61 63 61 6c 6c 5f 66 75 6e 63  Call vacall_func
0730: 74 69 6f 6e 2e 20 54 68 65 20 6d 61 63 72 6f 73  tion. The macros
0740: 20 64 6f 20 61 6c 6c 20 74 68 65 20 72 65 73 74   do all the rest
0750: 2e 20 2a 2f 0a 23 69 66 6e 64 65 66 20 52 45 45  . */.#ifndef REE
0760: 4e 54 52 41 4e 54 0a 20 20 28 2a 76 61 63 61 6c  NTRANT.  (*vacal
0770: 6c 5f 66 75 6e 63 74 69 6f 6e 29 20 28 26 6c 69  l_function) (&li
0780: 73 74 29 3b 0a 23 65 6c 73 65 20 2f 2a 20 52 45  st);.#else /* RE
0790: 45 4e 54 52 41 4e 54 20 2a 2f 0a 20 20 28 2a 65  ENTRANT */.  (*e
07a0: 6e 76 2d 3e 76 61 63 61 6c 6c 5f 66 75 6e 63 74  nv->vacall_funct
07b0: 69 6f 6e 29 20 28 65 6e 76 2d 3e 61 72 67 2c 26  ion) (env->arg,&
07c0: 6c 69 73 74 29 3b 0a 23 65 6e 64 69 66 0a 20 20  list);.#endif.  
07d0: 2f 2a 20 50 75 74 20 72 65 74 75 72 6e 20 76 61  /* Put return va
07e0: 6c 75 65 20 69 6e 74 6f 20 70 72 6f 70 65 72 20  lue into proper 
07f0: 72 65 67 69 73 74 65 72 2e 20 2a 2f 0a 20 20 69  register. */.  i
0800: 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d  f (list.rtype ==
0810: 20 5f 5f 56 41 76 6f 69 64 29 20 7b 0a 20 20 7d   __VAvoid) {.  }
0820: 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74   else.  if (list
0830: 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41 63 68  .rtype == __VAch
0840: 61 72 29 20 7b 0a 20 20 20 20 69 72 65 74 20 3d  ar) {.    iret =
0850: 20 6c 69 73 74 2e 74 6d 70 2e 5f 63 68 61 72 3b   list.tmp._char;
0860: 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66 20 28  .  } else.  if (
0870: 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f  list.rtype == __
0880: 56 41 73 63 68 61 72 29 20 7b 0a 20 20 20 20 69  VAschar) {.    i
0890: 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f  ret = list.tmp._
08a0: 73 63 68 61 72 3b 0a 20 20 7d 20 65 6c 73 65 0a  schar;.  } else.
08b0: 20 20 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65    if (list.rtype
08c0: 20 3d 3d 20 5f 5f 56 41 75 63 68 61 72 29 20 7b   == __VAuchar) {
08d0: 0a 20 20 20 20 69 72 65 74 20 3d 20 6c 69 73 74  .    iret = list
08e0: 2e 74 6d 70 2e 5f 75 63 68 61 72 3b 0a 20 20 7d  .tmp._uchar;.  }
08f0: 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74   else.  if (list
0900: 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41 73 68  .rtype == __VAsh
0910: 6f 72 74 29 20 7b 0a 20 20 20 20 69 72 65 74 20  ort) {.    iret 
0920: 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f 73 68 6f 72  = list.tmp._shor
0930: 74 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66  t;.  } else.  if
0940: 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20   (list.rtype == 
0950: 5f 5f 56 41 75 73 68 6f 72 74 29 20 7b 0a 20 20  __VAushort) {.  
0960: 20 20 69 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d    iret = list.tm
0970: 70 2e 5f 75 73 68 6f 72 74 3b 0a 20 20 7d 20 65  p._ushort;.  } e
0980: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0990: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 69 6e 74 29  type == __VAint)
09a0: 20 7b 0a 20 20 20 20 69 72 65 74 20 3d 20 6c 69   {.    iret = li
09b0: 73 74 2e 74 6d 70 2e 5f 69 6e 74 3b 0a 20 20 7d  st.tmp._int;.  }
09c0: 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74   else.  if (list
09d0: 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41 75 69  .rtype == __VAui
09e0: 6e 74 29 20 7b 0a 20 20 20 20 69 72 65 74 20 3d  nt) {.    iret =
09f0: 20 6c 69 73 74 2e 74 6d 70 2e 5f 75 69 6e 74 3b   list.tmp._uint;
0a00: 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66 20 28  .  } else.  if (
0a10: 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f  list.rtype == __
0a20: 56 41 6c 6f 6e 67 29 20 7b 0a 20 20 20 20 69 72  VAlong) {.    ir
0a30: 65 74 20 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f 6c  et = list.tmp._l
0a40: 6f 6e 67 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20  ong;.  } else.  
0a50: 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d  if (list.rtype =
0a60: 3d 20 5f 5f 56 41 75 6c 6f 6e 67 29 20 7b 0a 20  = __VAulong) {. 
0a70: 20 20 20 69 72 65 74 20 3d 20 6c 69 73 74 2e 74     iret = list.t
0a80: 6d 70 2e 5f 75 6c 6f 6e 67 3b 0a 20 20 7d 20 65  mp._ulong;.  } e
0a90: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0aa0: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 6c 6f 6e 67  type == __VAlong
0ab0: 6c 6f 6e 67 20 7c 7c 20 6c 69 73 74 2e 72 74 79  long || list.rty
0ac0: 70 65 20 3d 3d 20 5f 5f 56 41 75 6c 6f 6e 67 6c  pe == __VAulongl
0ad0: 6f 6e 67 29 20 7b 0a 20 20 20 20 69 72 65 74 20  ong) {.    iret 
0ae0: 20 3d 20 28 28 5f 5f 76 61 77 6f 72 64 20 2a 29   = ((__vaword *)
0af0: 20 26 6c 69 73 74 2e 74 6d 70 2e 5f 6c 6f 6e 67   &list.tmp._long
0b00: 6c 6f 6e 67 29 5b 30 5d 3b 0a 20 20 20 20 69 72  long)[0];.    ir
0b10: 65 74 32 20 3d 20 28 28 5f 5f 76 61 77 6f 72 64  et2 = ((__vaword
0b20: 20 2a 29 20 26 6c 69 73 74 2e 74 6d 70 2e 5f 6c   *) &list.tmp._l
0b30: 6f 6e 67 6c 6f 6e 67 29 5b 31 5d 3b 0a 20 20 7d  onglong)[1];.  }
0b40: 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74   else.  if (list
0b50: 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41 66 6c  .rtype == __VAfl
0b60: 6f 61 74 29 20 7b 0a 20 20 20 20 66 72 65 74 20  oat) {.    fret 
0b70: 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f 66 6c 6f 61  = list.tmp._floa
0b80: 74 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66  t;.  } else.  if
0b90: 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20   (list.rtype == 
0ba0: 5f 5f 56 41 64 6f 75 62 6c 65 29 20 7b 0a 20 20  __VAdouble) {.  
0bb0: 20 20 64 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d    dret = list.tm
0bc0: 70 2e 5f 64 6f 75 62 6c 65 3b 0a 20 20 7d 20 65  p._double;.  } e
0bd0: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0be0: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 76 6f 69 64  type == __VAvoid
0bf0: 70 29 20 7b 0a 20 20 20 20 69 72 65 74 20 3d 20  p) {.    iret = 
0c00: 28 6c 6f 6e 67 29 6c 69 73 74 2e 74 6d 70 2e 5f  (long)list.tmp._
0c10: 70 74 72 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20  ptr;.  } else.  
0c20: 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d  if (list.rtype =
0c30: 3d 20 5f 5f 56 41 73 74 72 75 63 74 29 20 7b 0a  = __VAstruct) {.
0c40: 20 20 20 20 69 66 20 28 6c 69 73 74 2e 66 6c 61      if (list.fla
0c50: 67 73 20 26 20 5f 5f 56 41 5f 50 43 43 5f 53 54  gs & __VA_PCC_ST
0c60: 52 55 43 54 5f 52 45 54 55 52 4e 29 20 7b 0a 20  RUCT_RETURN) {. 
0c70: 20 20 20 20 20 2f 2a 20 70 63 63 20 73 74 72 75       /* pcc stru
0c80: 63 74 20 72 65 74 75 72 6e 20 63 6f 6e 76 65 6e  ct return conven
0c90: 74 69 6f 6e 20 2a 2f 0a 20 20 20 20 20 20 69 72  tion */.      ir
0ca0: 65 74 20 3d 20 28 6c 6f 6e 67 29 20 6c 69 73 74  et = (long) list
0cb0: 2e 72 61 64 64 72 3b 0a 20 20 20 20 7d 20 65 6c  .raddr;.    } el
0cc0: 73 65 20 7b 0a 20 20 20 20 20 20 2f 2a 20 6e 6f  se {.      /* no
0cd0: 72 6d 61 6c 20 73 74 72 75 63 74 20 72 65 74 75  rmal struct retu
0ce0: 72 6e 20 63 6f 6e 76 65 6e 74 69 6f 6e 20 2a 2f  rn convention */
0cf0: 0a 20 20 20 20 20 20 69 66 20 28 6c 69 73 74 2e  .      if (list.
0d00: 66 6c 61 67 73 20 26 20 5f 5f 56 41 5f 52 45 47  flags & __VA_REG
0d10: 49 53 54 45 52 5f 53 54 52 55 43 54 5f 52 45 54  ISTER_STRUCT_RET
0d20: 55 52 4e 29 20 7b 0a 20 20 20 20 20 20 20 20 69  URN) {.        i
0d30: 66 20 28 6c 69 73 74 2e 72 73 69 7a 65 20 3d 3d  f (list.rsize ==
0d40: 20 73 69 7a 65 6f 66 28 63 68 61 72 29 29 20 7b   sizeof(char)) {
0d50: 0a 20 20 20 20 20 20 20 20 20 20 69 72 65 74 20  .          iret 
0d60: 3d 20 2a 28 75 6e 73 69 67 6e 65 64 20 63 68 61  = *(unsigned cha
0d70: 72 20 2a 29 20 6c 69 73 74 2e 72 61 64 64 72 3b  r *) list.raddr;
0d80: 0a 20 20 20 20 20 20 20 20 7d 20 65 6c 73 65 0a  .        } else.
0d90: 20 20 20 20 20 20 20 20 69 66 20 28 6c 69 73 74          if (list
0da0: 2e 72 73 69 7a 65 20 3d 3d 20 73 69 7a 65 6f 66  .rsize == sizeof
0db0: 28 73 68 6f 72 74 29 29 20 7b 0a 20 20 20 20 20  (short)) {.     
0dc0: 20 20 20 20 20 69 72 65 74 20 3d 20 2a 28 75 6e       iret = *(un
0dd0: 73 69 67 6e 65 64 20 73 68 6f 72 74 20 2a 29 20  signed short *) 
0de0: 6c 69 73 74 2e 72 61 64 64 72 3b 0a 20 20 20 20  list.raddr;.    
0df0: 20 20 20 20 7d 20 65 6c 73 65 0a 20 20 20 20 20      } else.     
0e00: 20 20 20 69 66 20 28 6c 69 73 74 2e 72 73 69 7a     if (list.rsiz
0e10: 65 20 3d 3d 20 73 69 7a 65 6f 66 28 69 6e 74 29  e == sizeof(int)
0e20: 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 69 72  ) {.          ir
0e30: 65 74 20 3d 20 2a 28 75 6e 73 69 67 6e 65 64 20  et = *(unsigned 
0e40: 69 6e 74 20 2a 29 20 6c 69 73 74 2e 72 61 64 64  int *) list.radd
0e50: 72 3b 0a 20 20 20 20 20 20 20 20 7d 20 65 6c 73  r;.        } els
0e60: 65 0a 20 20 20 20 20 20 20 20 69 66 20 28 6c 69  e.        if (li
0e70: 73 74 2e 72 73 69 7a 65 20 3d 3d 20 32 2a 73 69  st.rsize == 2*si
0e80: 7a 65 6f 66 28 5f 5f 76 61 77 6f 72 64 29 29 20  zeof(__vaword)) 
0e90: 7b 0a 20 20 20 20 20 20 20 20 20 20 69 72 65 74  {.          iret
0ea0: 20 20 3d 20 28 28 5f 5f 76 61 77 6f 72 64 20 2a    = ((__vaword *
0eb0: 29 20 6c 69 73 74 2e 72 61 64 64 72 29 5b 30 5d  ) list.raddr)[0]
0ec0: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 72 65 74  ;.          iret
0ed0: 32 20 3d 20 28 28 5f 5f 76 61 77 6f 72 64 20 2a  2 = ((__vaword *
0ee0: 29 20 6c 69 73 74 2e 72 61 64 64 72 29 5b 31 5d  ) list.raddr)[1]
0ef0: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
0f00: 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a    }.    }.  }.}.