public inbox for libffi-discuss@sourceware.org
 help / color / mirror / Atom feed
* Help: correct way to handle struct return values.
@ 2017-05-28  3:14 Kaz Kylheku
  2017-05-28  4:13 ` Kaz Kylheku
  0 siblings, 1 reply; 2+ messages in thread
From: Kaz Kylheku @ 2017-05-28  3:14 UTC (permalink / raw)
  To: libffi-discuss

Hi all,

In the current texinfo doc, the callback stub does this to
return a value of type int:

   /* Acts like puts with the file given at time of enclosure. */
   void puts_binding(ffi_cif *cif, void *ret, void* args[],
                   void *stream)
   {
     *(ffi_arg *)ret = fputs(*(char **)args[0], (FILE *)stream);
   }

Can someone show what the code would look like for a function
that returns the following type, and work everywhere: all
supported platforms, big or little endian:

   struct little { char a, b };

Obvously, this can't be used:

    *(ffi_arg *)ret = fun_returning_struct_little(...);

After everything, I'm not confident that this is correct, either:

    *(struct little *)ret = fun_returning_struct_little(...);

Also, can someone show how to extract "struct little" in after
a ffi down call? If the type is int, we can do this:

    ffi_arg rc_buf;
    int rc;
    ffi_call(&cif, puts, &rc_buf, values);
    rc = rc_buf;

But what if rc is of type "little struct"? Again, we can't just use a 
cast.

Lastly, how does any of this change for  struct bigger_struct { long x, 
y, z; }?

Thanks.

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2017-05-28  4:13 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-05-28  3:14 Help: correct way to handle struct return values Kaz Kylheku
2017-05-28  4:13 ` Kaz Kylheku

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).