
You can try using ghc directly (instead of cabal) so that you have full
control over what flags are passed, like this:
ghc -fPIC -dynamic -package xx -c plugin.hs
ld -shared -Bsymbolic -L<path to rts lib> -lHSrts-ghc8.0.2 -o plugin.so
plugin.o
If this works then you can find what is wrong/different with your cabal
setup by using verbose flags and looking at what is being passed to ghc.
-harendra
On 10 April 2017 at 18:14, Lana Black
Hello,
I'm working on a Haskell plugin (a shared library) for a C program. When I load the plugin, I get the following error:
./open dlopen() failed: /usr/lib64/ghc-8.0.2/ghc-prim-0.5.0.0/libHSghc-prim-0.5.0.0-ghc8.0.2.so: undefined symbol: stg_thawArrayzh
open is just a testing wrapper around dlopen(). I found out that stg_thawArrayzh symbol is exported by the rts, and my library isn't linked to it, and neither is ghc-prim. How do I fix that? Adding -lHSrts-ghc8.0.2 to ld-options doesn't seem to have any effect.
Thanks. _______________________________________________ Haskell-Cafe mailing list To (un)subscribe, modify options or view archives go to: http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe Only members subscribed via the mailman list are allowed to post.