xpcom/reflect/xptcall/src/md/unix/xptcinvoke_ipf64.cpp

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_ipf64.cpp	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,100 @@
     1.4 +
     1.5 +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
     1.6 + *
     1.7 + * This Source Code Form is subject to the terms of the Mozilla Public
     1.8 + * License, v. 2.0. If a copy of the MPL was not distributed with this
     1.9 + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
    1.10 +
    1.11 +#include "xptcprivate.h"
    1.12 +
    1.13 +#include <stdint.h>
    1.14 +
    1.15 +// "This code is for IA64 only"
    1.16 +
    1.17 +
    1.18 +/* invoke_copy_to_stack() will copy from variant array 's' to
    1.19 + * the stack argument area 'mloc', the integer register area 'iloc', and
    1.20 + * the float register area 'floc'.
    1.21 + *
    1.22 + */
    1.23 +extern "C" void
    1.24 +invoke_copy_to_stack(uint64_t* mloc, uint64_t* iloc, uint64_t* floc,
    1.25 +  const uint32_t paramCount, nsXPTCVariant* s)
    1.26 +{
    1.27 +  uint64_t* dest = mloc;
    1.28 +  uint32_t len = paramCount;
    1.29 +  nsXPTCVariant* source = s;
    1.30 +
    1.31 +  uint32_t indx;
    1.32 +  uint32_t endlen;
    1.33 +  endlen = (len > 7) ? 7 : len;
    1.34 +  /* handle the memory arguments */
    1.35 +  for (indx = 7; indx < len; ++indx)
    1.36 +  {
    1.37 +    if (source[indx].IsPtrData())
    1.38 +    {
    1.39 +      /* 64 bit pointer mode */
    1.40 +      *((void**) dest) = source[indx].ptr;
    1.41 +    }
    1.42 +    else
    1.43 +    switch (source[indx].type)
    1.44 +    {
    1.45 +    case nsXPTType::T_I8    : *(dest) = source[indx].val.i8;  break;
    1.46 +    case nsXPTType::T_I16   : *(dest) = source[indx].val.i16; break;
    1.47 +    case nsXPTType::T_I32   : *(dest) = source[indx].val.i32; break;
    1.48 +    case nsXPTType::T_I64   : *(dest) = source[indx].val.i64; break;
    1.49 +    case nsXPTType::T_U8    : *(dest) = source[indx].val.u8;  break;
    1.50 +    case nsXPTType::T_U16   : *(dest) = source[indx].val.u16; break;
    1.51 +    case nsXPTType::T_U32   : *(dest) = source[indx].val.u32; break;
    1.52 +    case nsXPTType::T_U64   : *(dest) = source[indx].val.u64; break;
    1.53 +    case nsXPTType::T_FLOAT : *(dest) = source[indx].val.u32; break;
    1.54 +    case nsXPTType::T_DOUBLE: *(dest) = source[indx].val.u64; break;
    1.55 +    case nsXPTType::T_BOOL  : *(dest) = source[indx].val.b; break;
    1.56 +    case nsXPTType::T_CHAR  : *(dest) = source[indx].val.c; break;
    1.57 +    case nsXPTType::T_WCHAR : *(dest) = source[indx].val.wc; break;
    1.58 +    default:
    1.59 +    // all the others are plain pointer types
    1.60 +      /* 64 bit pointer mode */
    1.61 +      *((void**) dest) = source[indx].val.p;
    1.62 +    }
    1.63 +    ++dest;
    1.64 +  }
    1.65 +  /* process register arguments */
    1.66 +  dest = iloc;
    1.67 +  for (indx = 0; indx < endlen; ++indx)
    1.68 +  {
    1.69 +    if (source[indx].IsPtrData())
    1.70 +    {
    1.71 +      /* 64 bit pointer mode */
    1.72 +      *((void**) dest) = source[indx].ptr;
    1.73 +    }
    1.74 +    else
    1.75 +    switch (source[indx].type)
    1.76 +    {
    1.77 +    case nsXPTType::T_I8    : *(dest) = source[indx].val.i8; break;
    1.78 +    case nsXPTType::T_I16   : *(dest) = source[indx].val.i16; break;
    1.79 +    case nsXPTType::T_I32   : *(dest) = source[indx].val.i32; break;
    1.80 +    case nsXPTType::T_I64   : *(dest) = source[indx].val.i64; break;
    1.81 +    case nsXPTType::T_U8    : *(dest) = source[indx].val.u8; break;
    1.82 +    case nsXPTType::T_U16   : *(dest) = source[indx].val.u16; break;
    1.83 +    case nsXPTType::T_U32   : *(dest) = source[indx].val.u32; break;
    1.84 +    case nsXPTType::T_U64   : *(dest) = source[indx].val.u64; break;
    1.85 +    case nsXPTType::T_FLOAT :
    1.86 +      *((double*) (floc++)) = (double) source[indx].val.f;
    1.87 +      break;
    1.88 +    case nsXPTType::T_DOUBLE:
    1.89 +      *((double*) (floc++)) = source[indx].val.d;
    1.90 +      break;
    1.91 +    case nsXPTType::T_BOOL  : *(dest) = source[indx].val.b; break;
    1.92 +    case nsXPTType::T_CHAR  : *(dest) = source[indx].val.c; break;
    1.93 +    case nsXPTType::T_WCHAR : *(dest) = source[indx].val.wc; break;
    1.94 +    default:
    1.95 +    // all the others are plain pointer types
    1.96 +      /* 64 bit pointer mode */
    1.97 +      *((void**) dest) = source[indx].val.p;
    1.98 +    }
    1.99 +    ++dest;
   1.100 +  }
   1.101 +
   1.102 +}
   1.103 +

mercurial