[GHC] #9656: Process and thread init/deinit hooks for C libraries

GHC ghc-devs at haskell.org
Wed Oct 1 22:29:51 UTC 2014


#9656: Process and thread init/deinit hooks for C libraries
-------------------------------------+-------------------------------------
       Reporter:  3noch              |                   Owner:
           Type:  feature request    |                  Status:  new
       Priority:  normal             |               Milestone:
      Component:  Compiler           |                 Version:  7.8.3
       Keywords:  FFI                |        Operating System:
   Architecture:  Unknown/Multiple   |  Unknown/Multiple
     Difficulty:  Unknown            |         Type of failure:
     Blocked By:                     |  None/Unknown
Related Tickets:                     |               Test Case:
                                     |                Blocking:
                                     |  Differential Revisions:
-------------------------------------+-------------------------------------
 Haskell's FFI for C seems geared toward C as an optimization. But in many
 cases, we use the C FFI merely hook into a 3rd-party library. In this
 case, the FFI seems a bit lacking. In my specific case, I want to link
 against libmysqlclient_r to perform MySQL queries. However, the library
 requires global init and deinit. Worse, it requires init/deinit for *each*
 thread that wishes to interact with its API. This type of thing is not
 entirely uncommon among C libraries. Of course, we can bend over backward
 to inter-operate with such libraries (e.g. wrap the C API with our own
 versions that ensure proper initialization), but the process is
 painstaking and often requires decent performance overhead.

 I would like to request some sort of hook registration where the FFI can
 be used to accomplish these common tasks. Perhaps it's too difficult, but
 it doesn't hurt to ask!

--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/9656>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler


More information about the ghc-tickets mailing list