Skip to content
Snippets Groups Projects
Commit aa9282aa authored by Ben Gamari's avatar Ben Gamari
Browse files

Document that ccall convention doesn't support varargs

We do not support foreign "C" imports of varargs functions. While this
works on amd64, in general the platform's calling convention may need
more type information that our Cmm representation can currently provide.
For instance, this is the case with Darwin's AArch64 calling convention.
Document this fact in the users guide and fix T5423 which makes use of a
disallowed foreign import.

Closes #18854.
parent 0c4bfed8
No related branches found
No related tags found
No related merge requests found
Pipeline #26358 failed
......@@ -83,6 +83,21 @@ For more details on the implementation see the Paper:
Last known to be accessible `here
<https://www.microsoft.com/en-us/research/wp-content/uploads/2004/09/conc-ffi.pdf>`_.
Varargs not supported by ``ccall`` calling convention
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Note that functions requiring varargs arguments are unsupported by the ``ccall``
calling convention. Foreign imports needing to call such functions should rather
``capi`` convention, giving an explicit signature for the needed call-pattern.
For instance, one could write: ::
foreign import "capi" "printf"
my_printf :: Ptr CChar -> CInt -> IO ()
printInt :: CInt -> IO ()
printInt n = my_printf "printed number %d" n
.. _ffi-ghcexts:
GHC extensions to the FFI Chapter
......
#include <stdio.h>
#include "Stg.h"
void flush_stdout(void)
{
fflush(stdout);
}
void print_it(
StgWord r1,
StgWord r2,
StgWord r3,
StgWord r4,
StgWord r5,
StgWord r5,
StgWord r7,
StgWord r8,
StgWord r9,
StgWord r10
)
{
printf("%d %d %d %d %d %d %d %d %d %d\n",
r1, r2, r3, r4, r5, r6, r7, r8, r9, r10);
}
......@@ -10,7 +10,6 @@ test (W_ r1,
W_ r9,
W_ r10)
{
foreign "C" printf("%d %d %d %d %d %d %d %d %d %d\n",
r1, r2, r3, r4, r5, r6, r7, r8, r9, r10);
foreign "C" test_it(r1, r2, r3, r4, r5, r6, r7, r8, r9, r10);
return (r10);
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment