Artifact 6130164ebc094964d35df61ef4b73929a2240fad:


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 61 72 6d 20 43 50 55 20 2a  on for arm CPU *
0020: 2f 0a 0a 2f 2a 0a 20 2a 20 43 6f 70 79 72 69 67  /../*. * Copyrig
0030: 68 74 20 31 39 39 35 2d 32 30 30 34 20 42 72 75  ht 1995-2004 Bru
0040: 6e 6f 20 48 61 69 62 6c 65 2c 20 3c 62 72 75 6e  no Haible, <brun
0050: 6f 40 63 6c 69 73 70 2e 6f 72 67 3e 0a 20 2a 0a  o@clisp.org>. *.
0060: 20 2a 20 54 68 69 73 20 69 73 20 66 72 65 65 20   * This is free 
0070: 73 6f 66 74 77 61 72 65 20 64 69 73 74 72 69 62  software distrib
0080: 75 74 65 64 20 75 6e 64 65 72 20 74 68 65 20 47  uted under the G
0090: 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69  NU General Publi
00a0: 63 20 4c 69 63 65 6e 63 65 0a 20 2a 20 64 65 73  c Licence. * des
00b0: 63 72 69 62 65 64 20 69 6e 20 74 68 65 20 66 69  cribed in the fi
00c0: 6c 65 20 43 4f 50 59 49 4e 47 2e 20 43 6f 6e 74  le COPYING. Cont
00d0: 61 63 74 20 74 68 65 20 61 75 74 68 6f 72 20 69  act the author i
00e0: 66 20 79 6f 75 20 64 6f 6e 27 74 20 68 61 76 65  f you don't have
00f0: 20 74 68 69 73 0a 20 2a 20 6f 72 20 63 61 6e 27   this. * or can'
0100: 74 20 6c 69 76 65 20 77 69 74 68 20 69 74 2e 20  t live with it. 
0110: 54 68 65 72 65 20 69 73 20 41 42 53 4f 4c 55 54  There is ABSOLUT
0120: 45 4c 59 20 4e 4f 20 57 41 52 52 41 4e 54 59 2c  ELY NO WARRANTY,
0130: 20 65 78 70 6c 69 63 69 74 20 6f 72 20 69 6d 70   explicit or imp
0140: 6c 69 65 64 2c 0a 20 2a 20 6f 6e 20 74 68 69 73  lied,. * on this
0150: 20 73 6f 66 74 77 61 72 65 2e 0a 20 2a 2f 0a 0a   software.. */..
0160: 23 69 66 6e 64 65 66 20 52 45 45 4e 54 52 41 4e  #ifndef REENTRAN
0170: 54 0a 23 69 6e 63 6c 75 64 65 20 22 76 61 63 61  T.#include "vaca
0180: 6c 6c 2e 68 2e 69 6e 22 0a 23 65 6c 73 65 20 2f  ll.h.in".#else /
0190: 2a 20 52 45 45 4e 54 52 41 4e 54 20 2a 2f 0a 23  * REENTRANT */.#
01a0: 69 6e 63 6c 75 64 65 20 22 76 61 63 61 6c 6c 5f  include "vacall_
01b0: 72 2e 68 2e 69 6e 22 0a 23 65 6e 64 69 66 0a 0a  r.h.in".#endif..
01c0: 23 69 66 64 65 66 20 52 45 45 4e 54 52 41 4e 54  #ifdef REENTRANT
01d0: 0a 23 64 65 66 69 6e 65 20 5f 5f 76 61 63 61 6c  .#define __vacal
01e0: 6c 20 5f 5f 76 61 63 61 6c 6c 5f 72 0a 72 65 67  l __vacall_r.reg
01f0: 69 73 74 65 72 20 73 74 72 75 63 74 20 7b 20 76  ister struct { v
0200: 6f 69 64 20 28 2a 76 61 63 61 6c 6c 5f 66 75 6e  oid (*vacall_fun
0210: 63 74 69 6f 6e 29 20 28 76 6f 69 64 2a 2c 76 61  ction) (void*,va
0220: 5f 61 6c 69 73 74 29 3b 20 76 6f 69 64 2a 20 61  _alist); void* a
0230: 72 67 3b 20 7d 0a 20 20 20 20 20 20 20 20 20 2a  rg; }.         *
0240: 09 09 65 6e 76 09 5f 5f 61 73 6d 5f 5f 28 22 72  ..env.__asm__("r
0250: 31 32 22 29 3b 0a 23 65 6e 64 69 66 0a 72 65 67  12");.#endif.reg
0260: 69 73 74 65 72 20 5f 5f 76 61 77 6f 72 64 09 69  ister __vaword.i
0270: 72 65 74 09 5f 5f 61 73 6d 5f 5f 28 22 72 30 22  ret.__asm__("r0"
0280: 29 3b 0a 72 65 67 69 73 74 65 72 20 5f 5f 76 61  );.register __va
0290: 77 6f 72 64 09 69 72 65 74 32 09 5f 5f 61 73 6d  word.iret2.__asm
02a0: 5f 5f 28 22 72 31 22 29 3b 0a 72 65 67 69 73 74  __("r1");.regist
02b0: 65 72 20 66 6c 6f 61 74 09 09 66 72 65 74 09 5f  er float..fret._
02c0: 5f 61 73 6d 5f 5f 28 22 66 30 22 29 3b 0a 72 65  _asm__("f0");.re
02d0: 67 69 73 74 65 72 20 64 6f 75 62 6c 65 09 09 64  gister double..d
02e0: 72 65 74 09 5f 5f 61 73 6d 5f 5f 28 22 66 30 22  ret.__asm__("f0"
02f0: 29 3b 0a 0a 76 6f 69 64 20 2f 2a 20 74 68 65 20  );..void /* the 
0300: 72 65 74 75 72 6e 20 74 79 70 65 20 69 73 20 76  return type is v
0310: 61 72 69 61 62 6c 65 2c 20 6e 6f 74 20 76 6f 69  ariable, not voi
0320: 64 21 20 2a 2f 0a 5f 5f 76 61 63 61 6c 6c 20 28  d! */.__vacall (
0330: 5f 5f 76 61 77 6f 72 64 20 77 6f 72 64 31 2c 20  __vaword word1, 
0340: 5f 5f 76 61 77 6f 72 64 20 77 6f 72 64 32 2c 20  __vaword word2, 
0350: 5f 5f 76 61 77 6f 72 64 20 77 6f 72 64 33 2c 20  __vaword word3, 
0360: 5f 5f 76 61 77 6f 72 64 20 77 6f 72 64 34 2c 0a  __vaword word4,.
0370: 20 20 20 20 20 20 20 20 20 20 5f 5f 76 61 77 6f            __vawo
0380: 72 64 20 66 69 72 73 74 77 6f 72 64 29 0a 7b 0a  rd firstword).{.
0390: 20 20 73 74 72 75 63 74 20 7b 20 6c 6f 6e 67 20    struct { long 
03a0: 72 65 74 61 64 64 72 2c 20 61 72 67 31 2c 20 61  retaddr, arg1, a
03b0: 72 67 32 2c 20 61 72 67 33 2c 20 61 72 67 34 3b  rg2, arg3, arg4;
03c0: 20 7d 20 61 72 67 73 3b 0a 20 20 5f 5f 76 61 5f   } args;.  __va_
03d0: 61 6c 69 73 74 20 6c 69 73 74 3b 0a 20 20 2f 2a  alist list;.  /*
03e0: 20 4d 41 47 49 43 20 41 4c 45 52 54 21 0a 20 20   MAGIC ALERT!.  
03f0: 20 2a 20 54 68 69 73 20 69 73 20 74 68 65 20 6c   * This is the l
0400: 61 73 74 20 73 74 72 75 63 74 20 6f 6e 20 74 68  ast struct on th
0410: 65 20 73 74 61 63 6b 2c 20 73 6f 20 74 68 61 74  e stack, so that
0420: 0a 20 20 20 2a 20 26 61 72 67 73 20 2b 20 31 20  .   * &args + 1 
0430: 3d 3d 20 26 72 65 74 75 72 6e 5f 61 64 64 72 65  == &return_addre
0440: 73 73 20 3d 3d 20 26 66 69 72 73 74 77 6f 72 64  ss == &firstword
0450: 20 2d 20 31 2e 0a 20 20 20 2a 20 4c 6f 6f 6b 20   - 1..   * Look 
0460: 61 74 20 74 68 65 20 61 73 73 65 6d 62 6c 79 20  at the assembly 
0470: 63 6f 64 65 20 74 6f 20 63 6f 6e 76 69 6e 63 65  code to convince
0480: 20 79 6f 75 72 73 65 6c 66 2e 0a 20 20 20 2a 2f   yourself..   */
0490: 0a 20 20 2f 2a 20 4d 6f 76 65 20 74 68 65 20 61  .  /* Move the a
04a0: 72 67 75 6d 65 6e 74 73 20 70 61 73 73 65 64 20  rguments passed 
04b0: 69 6e 20 72 65 67 69 73 74 65 72 73 20 74 6f 20  in registers to 
04c0: 74 68 65 69 72 20 73 74 61 63 6b 20 6c 6f 63 61  their stack loca
04d0: 74 69 6f 6e 73 2e 20 2a 2f 0a 20 20 61 72 67 73  tions. */.  args
04e0: 2e 72 65 74 61 64 64 72 20 3d 20 28 26 66 69 72  .retaddr = (&fir
04f0: 73 74 77 6f 72 64 29 5b 2d 31 5d 3b 20 2f 2a 20  stword)[-1]; /* 
0500: 73 61 76 65 20 74 68 65 20 72 65 74 75 72 6e 20  save the return 
0510: 61 64 64 72 65 73 73 20 2a 2f 0a 20 20 28 26 66  address */.  (&f
0520: 69 72 73 74 77 6f 72 64 29 5b 2d 34 5d 20 3d 20  irstword)[-4] = 
0530: 77 6f 72 64 31 3b 0a 20 20 28 26 66 69 72 73 74  word1;.  (&first
0540: 77 6f 72 64 29 5b 2d 33 5d 20 3d 20 77 6f 72 64  word)[-3] = word
0550: 32 3b 0a 20 20 28 26 66 69 72 73 74 77 6f 72 64  2;.  (&firstword
0560: 29 5b 2d 32 5d 20 3d 20 77 6f 72 64 33 3b 0a 20  )[-2] = word3;. 
0570: 20 28 26 66 69 72 73 74 77 6f 72 64 29 5b 2d 31   (&firstword)[-1
0580: 5d 20 3d 20 77 6f 72 64 34 3b 0a 20 20 2f 2a 20  ] = word4;.  /* 
0590: 50 72 65 70 61 72 65 20 74 68 65 20 76 61 5f 61  Prepare the va_a
05a0: 6c 69 73 74 2e 20 2a 2f 0a 20 20 6c 69 73 74 2e  list. */.  list.
05b0: 66 6c 61 67 73 20 3d 20 30 3b 0a 20 20 6c 69 73  flags = 0;.  lis
05c0: 74 2e 61 70 74 72 20 3d 20 28 6c 6f 6e 67 29 28  t.aptr = (long)(
05d0: 26 66 69 72 73 74 77 6f 72 64 20 2d 20 34 29 3b  &firstword - 4);
05e0: 0a 20 20 6c 69 73 74 2e 72 61 64 64 72 20 3d 20  .  list.raddr = 
05f0: 28 76 6f 69 64 2a 29 30 3b 0a 20 20 6c 69 73 74  (void*)0;.  list
0600: 2e 72 74 79 70 65 20 3d 20 5f 5f 56 41 76 6f 69  .rtype = __VAvoi
0610: 64 3b 0a 20 20 2f 2a 20 43 61 6c 6c 20 76 61 63  d;.  /* Call vac
0620: 61 6c 6c 5f 66 75 6e 63 74 69 6f 6e 2e 20 54 68  all_function. Th
0630: 65 20 6d 61 63 72 6f 73 20 64 6f 20 61 6c 6c 20  e macros do all 
0640: 74 68 65 20 72 65 73 74 2e 20 2a 2f 0a 23 69 66  the rest. */.#if
0650: 6e 64 65 66 20 52 45 45 4e 54 52 41 4e 54 0a 20  ndef REENTRANT. 
0660: 20 28 2a 76 61 63 61 6c 6c 5f 66 75 6e 63 74 69   (*vacall_functi
0670: 6f 6e 29 20 28 26 6c 69 73 74 29 3b 0a 23 65 6c  on) (&list);.#el
0680: 73 65 20 2f 2a 20 52 45 45 4e 54 52 41 4e 54 20  se /* REENTRANT 
0690: 2a 2f 0a 20 20 28 2a 65 6e 76 2d 3e 76 61 63 61  */.  (*env->vaca
06a0: 6c 6c 5f 66 75 6e 63 74 69 6f 6e 29 20 28 65 6e  ll_function) (en
06b0: 76 2d 3e 61 72 67 2c 26 6c 69 73 74 29 3b 0a 23  v->arg,&list);.#
06c0: 65 6e 64 69 66 0a 20 20 2f 2a 20 50 75 74 20 72  endif.  /* Put r
06d0: 65 74 75 72 6e 20 76 61 6c 75 65 20 69 6e 74 6f  eturn value into
06e0: 20 70 72 6f 70 65 72 20 72 65 67 69 73 74 65 72   proper register
06f0: 2e 20 2a 2f 0a 20 20 69 66 20 28 6c 69 73 74 2e  . */.  if (list.
0700: 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41 76 6f 69  rtype == __VAvoi
0710: 64 29 20 7b 0a 20 20 7d 20 65 6c 73 65 0a 20 20  d) {.  } else.  
0720: 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d  if (list.rtype =
0730: 3d 20 5f 5f 56 41 63 68 61 72 29 20 7b 0a 20 20  = __VAchar) {.  
0740: 20 20 69 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d    iret = list.tm
0750: 70 2e 5f 63 68 61 72 3b 0a 20 20 7d 20 65 6c 73  p._char;.  } els
0760: 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72 74 79  e.  if (list.rty
0770: 70 65 20 3d 3d 20 5f 5f 56 41 73 63 68 61 72 29  pe == __VAschar)
0780: 20 7b 0a 20 20 20 20 69 72 65 74 20 3d 20 6c 69   {.    iret = li
0790: 73 74 2e 74 6d 70 2e 5f 73 63 68 61 72 3b 0a 20  st.tmp._schar;. 
07a0: 20 7d 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69   } else.  if (li
07b0: 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41  st.rtype == __VA
07c0: 75 63 68 61 72 29 20 7b 0a 20 20 20 20 69 72 65  uchar) {.    ire
07d0: 74 20 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f 75 63  t = list.tmp._uc
07e0: 68 61 72 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20  har;.  } else.  
07f0: 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d  if (list.rtype =
0800: 3d 20 5f 5f 56 41 73 68 6f 72 74 29 20 7b 0a 20  = __VAshort) {. 
0810: 20 20 20 69 72 65 74 20 3d 20 6c 69 73 74 2e 74     iret = list.t
0820: 6d 70 2e 5f 73 68 6f 72 74 3b 0a 20 20 7d 20 65  mp._short;.  } e
0830: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0840: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 75 73 68 6f  type == __VAusho
0850: 72 74 29 20 7b 0a 20 20 20 20 69 72 65 74 20 3d  rt) {.    iret =
0860: 20 6c 69 73 74 2e 74 6d 70 2e 5f 75 73 68 6f 72   list.tmp._ushor
0870: 74 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66  t;.  } else.  if
0880: 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20   (list.rtype == 
0890: 5f 5f 56 41 69 6e 74 29 20 7b 0a 20 20 20 20 69  __VAint) {.    i
08a0: 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f  ret = list.tmp._
08b0: 69 6e 74 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20  int;.  } else.  
08c0: 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d  if (list.rtype =
08d0: 3d 20 5f 5f 56 41 75 69 6e 74 29 20 7b 0a 20 20  = __VAuint) {.  
08e0: 20 20 69 72 65 74 20 3d 20 6c 69 73 74 2e 74 6d    iret = list.tm
08f0: 70 2e 5f 75 69 6e 74 3b 0a 20 20 7d 20 65 6c 73  p._uint;.  } els
0900: 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72 74 79  e.  if (list.rty
0910: 70 65 20 3d 3d 20 5f 5f 56 41 6c 6f 6e 67 29 20  pe == __VAlong) 
0920: 7b 0a 20 20 20 20 69 72 65 74 20 3d 20 6c 69 73  {.    iret = lis
0930: 74 2e 74 6d 70 2e 5f 6c 6f 6e 67 3b 0a 20 20 7d  t.tmp._long;.  }
0940: 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74   else.  if (list
0950: 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41 75 6c  .rtype == __VAul
0960: 6f 6e 67 29 20 7b 0a 20 20 20 20 69 72 65 74 20  ong) {.    iret 
0970: 3d 20 6c 69 73 74 2e 74 6d 70 2e 5f 75 6c 6f 6e  = list.tmp._ulon
0980: 67 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66  g;.  } else.  if
0990: 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20   (list.rtype == 
09a0: 5f 5f 56 41 6c 6f 6e 67 6c 6f 6e 67 20 7c 7c 20  __VAlonglong || 
09b0: 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20 5f 5f  list.rtype == __
09c0: 56 41 75 6c 6f 6e 67 6c 6f 6e 67 29 20 7b 0a 20  VAulonglong) {. 
09d0: 20 20 20 69 72 65 74 20 20 3d 20 28 28 5f 5f 76     iret  = ((__v
09e0: 61 77 6f 72 64 20 2a 29 20 26 6c 69 73 74 2e 74  aword *) &list.t
09f0: 6d 70 2e 5f 6c 6f 6e 67 6c 6f 6e 67 29 5b 30 5d  mp._longlong)[0]
0a00: 3b 0a 20 20 20 20 69 72 65 74 32 20 3d 20 28 28  ;.    iret2 = ((
0a10: 5f 5f 76 61 77 6f 72 64 20 2a 29 20 26 6c 69 73  __vaword *) &lis
0a20: 74 2e 74 6d 70 2e 5f 6c 6f 6e 67 6c 6f 6e 67 29  t.tmp._longlong)
0a30: 5b 31 5d 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20  [1];.  } else.  
0a40: 69 66 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d  if (list.rtype =
0a50: 3d 20 5f 5f 56 41 66 6c 6f 61 74 29 20 7b 0a 20  = __VAfloat) {. 
0a60: 20 20 20 66 72 65 74 20 3d 20 6c 69 73 74 2e 74     fret = list.t
0a70: 6d 70 2e 5f 66 6c 6f 61 74 3b 0a 20 20 7d 20 65  mp._float;.  } e
0a80: 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74 2e 72  lse.  if (list.r
0a90: 74 79 70 65 20 3d 3d 20 5f 5f 56 41 64 6f 75 62  type == __VAdoub
0aa0: 6c 65 29 20 7b 0a 20 20 20 20 64 72 65 74 20 3d  le) {.    dret =
0ab0: 20 6c 69 73 74 2e 74 6d 70 2e 5f 64 6f 75 62 6c   list.tmp._doubl
0ac0: 65 3b 0a 20 20 7d 20 65 6c 73 65 0a 20 20 69 66  e;.  } else.  if
0ad0: 20 28 6c 69 73 74 2e 72 74 79 70 65 20 3d 3d 20   (list.rtype == 
0ae0: 5f 5f 56 41 76 6f 69 64 70 29 20 7b 0a 20 20 20  __VAvoidp) {.   
0af0: 20 69 72 65 74 20 3d 20 28 6c 6f 6e 67 29 6c 69   iret = (long)li
0b00: 73 74 2e 74 6d 70 2e 5f 70 74 72 3b 0a 20 20 7d  st.tmp._ptr;.  }
0b10: 20 65 6c 73 65 0a 20 20 69 66 20 28 6c 69 73 74   else.  if (list
0b20: 2e 72 74 79 70 65 20 3d 3d 20 5f 5f 56 41 73 74  .rtype == __VAst
0b30: 72 75 63 74 29 20 7b 0a 20 20 20 20 2f 2a 20 4e  ruct) {.    /* N
0b40: 42 3a 20 4f 6e 20 61 72 6d 2c 20 61 6c 6c 20 73  B: On arm, all s
0b50: 74 72 75 63 74 75 72 65 20 73 69 7a 65 73 20 61  tructure sizes a
0b60: 72 65 20 64 69 76 69 73 69 62 6c 65 20 62 79 20  re divisible by 
0b70: 34 2e 20 2a 2f 0a 20 20 20 20 69 66 20 28 6c 69  4. */.    if (li
0b80: 73 74 2e 66 6c 61 67 73 20 26 20 5f 5f 56 41 5f  st.flags & __VA_
0b90: 50 43 43 5f 53 54 52 55 43 54 5f 52 45 54 55 52  PCC_STRUCT_RETUR
0ba0: 4e 29 20 7b 0a 20 20 20 20 20 20 2f 2a 20 70 63  N) {.      /* pc
0bb0: 63 20 73 74 72 75 63 74 20 72 65 74 75 72 6e 20  c struct return 
0bc0: 63 6f 6e 76 65 6e 74 69 6f 6e 20 2a 2f 0a 20 20  convention */.  
0bd0: 20 20 20 20 69 72 65 74 20 3d 20 28 6c 6f 6e 67      iret = (long
0be0: 29 20 6c 69 73 74 2e 72 61 64 64 72 3b 0a 20 20  ) list.raddr;.  
0bf0: 20 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20 20    } else {.     
0c00: 20 2f 2a 20 6e 6f 72 6d 61 6c 20 73 74 72 75 63   /* normal struc
0c10: 74 20 72 65 74 75 72 6e 20 63 6f 6e 76 65 6e 74  t return convent
0c20: 69 6f 6e 20 2a 2f 0a 20 20 20 20 20 20 69 66 20  ion */.      if 
0c30: 28 6c 69 73 74 2e 66 6c 61 67 73 20 26 20 5f 5f  (list.flags & __
0c40: 56 41 5f 52 45 47 49 53 54 45 52 5f 53 54 52 55  VA_REGISTER_STRU
0c50: 43 54 5f 52 45 54 55 52 4e 29 20 7b 0a 20 20 20  CT_RETURN) {.   
0c60: 20 20 20 20 20 69 66 20 28 6c 69 73 74 2e 72 73       if (list.rs
0c70: 69 7a 65 20 3d 3d 20 73 69 7a 65 6f 66 28 63 68  ize == sizeof(ch
0c80: 61 72 29 29 20 7b 20 2f 2a 20 63 61 6e 27 74 20  ar)) { /* can't 
0c90: 6f 63 63 75 72 20 2a 2f 0a 20 20 20 20 20 20 20  occur */.       
0ca0: 20 20 20 69 72 65 74 20 3d 20 2a 28 75 6e 73 69     iret = *(unsi
0cb0: 67 6e 65 64 20 63 68 61 72 20 2a 29 20 6c 69 73  gned char *) lis
0cc0: 74 2e 72 61 64 64 72 3b 0a 20 20 20 20 20 20 20  t.raddr;.       
0cd0: 20 7d 20 65 6c 73 65 0a 20 20 20 20 20 20 20 20   } else.        
0ce0: 69 66 20 28 6c 69 73 74 2e 72 73 69 7a 65 20 3d  if (list.rsize =
0cf0: 3d 20 73 69 7a 65 6f 66 28 73 68 6f 72 74 29 29  = sizeof(short))
0d00: 20 7b 20 2f 2a 20 63 61 6e 27 74 20 6f 63 63 75   { /* can't occu
0d10: 72 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 69  r */.          i
0d20: 72 65 74 20 3d 20 2a 28 75 6e 73 69 67 6e 65 64  ret = *(unsigned
0d30: 20 73 68 6f 72 74 20 2a 29 20 6c 69 73 74 2e 72   short *) list.r
0d40: 61 64 64 72 3b 0a 20 20 20 20 20 20 20 20 7d 20  addr;.        } 
0d50: 65 6c 73 65 0a 20 20 20 20 20 20 20 20 69 66 20  else.        if 
0d60: 28 6c 69 73 74 2e 72 73 69 7a 65 20 3d 3d 20 73  (list.rsize == s
0d70: 69 7a 65 6f 66 28 69 6e 74 29 29 20 7b 0a 20 20  izeof(int)) {.  
0d80: 20 20 20 20 20 20 20 20 69 72 65 74 20 3d 20 2a          iret = *
0d90: 28 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 2a 29  (unsigned int *)
0da0: 20 6c 69 73 74 2e 72 61 64 64 72 3b 0a 20 20 20   list.raddr;.   
0db0: 20 20 20 20 20 7d 20 65 6c 73 65 0a 20 20 20 20       } else.    
0dc0: 20 20 20 20 69 66 20 28 6c 69 73 74 2e 72 73 69      if (list.rsi
0dd0: 7a 65 20 3d 3d 20 32 2a 73 69 7a 65 6f 66 28 5f  ze == 2*sizeof(_
0de0: 5f 76 61 77 6f 72 64 29 29 20 7b 0a 20 20 20 20  _vaword)) {.    
0df0: 20 20 20 20 20 20 69 72 65 74 20 20 3d 20 28 28        iret  = ((
0e00: 5f 5f 76 61 77 6f 72 64 20 2a 29 20 6c 69 73 74  __vaword *) list
0e10: 2e 72 61 64 64 72 29 5b 30 5d 3b 0a 20 20 20 20  .raddr)[0];.    
0e20: 20 20 20 20 20 20 69 72 65 74 32 20 3d 20 28 28        iret2 = ((
0e30: 5f 5f 76 61 77 6f 72 64 20 2a 29 20 6c 69 73 74  __vaword *) list
0e40: 2e 72 61 64 64 72 29 5b 31 5d 3b 0a 20 20 20 20  .raddr)[1];.    
0e50: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20      }.      }.  
0e60: 20 20 7d 0a 20 20 7d 0a 20 20 28 26 66 69 72 73    }.  }.  (&firs
0e70: 74 77 6f 72 64 29 5b 2d 31 5d 20 3d 20 61 72 67  tword)[-1] = arg
0e80: 73 2e 72 65 74 61 64 64 72 3b 20 2f 2a 20 72 65  s.retaddr; /* re
0e90: 73 74 6f 72 65 20 74 68 65 20 72 65 74 75 72 6e  store the return
0ea0: 20 61 64 64 72 65 73 73 20 2a 2f 0a 7d 0a         address */.}.