Hi Our front end is written in a CLR language, and we're currently interacting with the middle/back-end by writing out .ll files. This was convenient to get started with, but they're getting to a "huge and unwieldy" stage now. I was wondering if anyone's attempted writing proxy/wrapper C++/CLI classes so that the IR API can be used directly from managed languages. Any tips/pointers/code/stories of horrible failure? thanks, scott
Take a look at this page. It might give you more information: http://vmkit.llvm.org/ -bw On Tue, Aug 12, 2008 at 4:38 PM, Scott Graham <scott.llvm at h4ck3r.net> wrote:> Hi > > Our front end is written in a CLR language, and we're currently > interacting with the middle/back-end by writing out .ll files. This > was convenient to get started with, but they're getting to a "huge and > unwieldy" stage now. > > I was wondering if anyone's attempted writing proxy/wrapper C++/CLI > classes so that the IR API can be used directly from managed > languages. Any tips/pointers/code/stories of horrible failure? > > thanks, > scott > _______________________________________________ > LLVM Developers mailing list > LLVMdev at cs.uiuc.edu http://llvm.cs.uiuc.edu > http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev >
Hi, thanks for the pointer.>From what I can tell, while vmkit targets VMs, the front-end iswritten in C++, not in a managed language. Am I missing something? (or was the "might" as vaguely hopeful as it sounded? :) scott On Tue, Aug 12, 2008 at 5:06 PM, Bill Wendling <isanbard at gmail.com> wrote:> Take a look at this page. It might give you more information: > > http://vmkit.llvm.org/ > > -bw > > On Tue, Aug 12, 2008 at 4:38 PM, Scott Graham <scott.llvm at h4ck3r.net> wrote: >> Hi >> >> Our front end is written in a CLR language, and we're currently >> interacting with the middle/back-end by writing out .ll files. This >> was convenient to get started with, but they're getting to a "huge and >> unwieldy" stage now. >> >> I was wondering if anyone's attempted writing proxy/wrapper C++/CLI >> classes so that the IR API can be used directly from managed >> languages. Any tips/pointers/code/stories of horrible failure? >> >> thanks, >> scott >> _______________________________________________ >> LLVM Developers mailing list >> LLVMdev at cs.uiuc.edu http://llvm.cs.uiuc.edu >> http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev >> > _______________________________________________ > LLVM Developers mailing list > LLVMdev at cs.uiuc.edu http://llvm.cs.uiuc.edu > http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev >
Gordon Henriksen
2008-Aug-13 00:51 UTC
[LLVMdev] CLR or C++/CLI interface to IR building API
On Aug 12, 2008, at 19:38, Scott Graham wrote:> Our front end is written in a CLR language, and we're currently > interacting with the middle/back-end by writing out .ll files. This > was convenient to get started with, but they're getting to a "huge > and unwieldy" stage now.Yup. This is in the FAQ now: http://llvm.org/docs/FAQ.html#langirgen> I was wondering if anyone's attempted writing proxy/wrapper C++/CLI > classes so that the IR API can be used directly from managed > languages.LLVM has C bindings which you should be able to P/Invoke straightforwardly. A rational managed API could be built atop these. Visit include/llvm-c in the source tree. These were specifically designed for use via FFIs like P/Invoke. Several bindings have been built atop the C bindings (Ocaml, Haskell, D, and Python that I know of), but only the Ocaml ones are on trunk. We would welcome additional bindings into mainline if you are inclined to contribute. These bindings are not 100% complete, but your usage case has the best coverage.> Any tips/pointers/code/stories of horrible failure?I would advise against the Managed C++ route. In my experience, the pointy edges of the unmanaged environment (no GC, no memory safety) compound the pointy edges of the managed environment (finalization, asynchronous exceptions)—the end result is the worst of both worlds. I wouldn't really advise trying to P/Invoke LLVM's C++ APIs directly, either. There is a recurring 'first/next/prev/last' pattern in the bindings. It allows efficiently implementing values similar to Module::iterator, Function::iterator, et al. The Ocaml bindings include a functional interpretation of this pattern. Each language seems to have a different idiom for handling iteration. — Gordon
On Tue, Aug 12, 2008 at 5:51 PM, Gordon Henriksen <gordonhenriksen at me.com> wrote:> On Aug 12, 2008, at 19:38, Scott Graham wrote: > > LLVM has C bindings which you should be able to P/Invoke > straightforwardly. A rational managed API could be built atop these. > Visit include/llvm-c in the source tree. These were specifically > designed for use via FFIs like P/Invoke.Thanks Gordon, I'll see what I can do with llvm-c. If we decide to go this way (it'll be a relatively large change from generating text I expect), I'll try to make sure things are kept separate so the bindings can be contributed back.> I wouldn't really advise trying to P/Invoke LLVM's C++ APIs directly, > either.Good to know, I'd started writing proxy "ref class" classes, but it was starting to get a bit icky with multiple inheritance and abstract bases. I think the straight C version makes more sense. thanks, scott
Reasonably Related Threads
- [LLVMdev] CLR or C++/CLI interface to IR building API
- [LLVMdev] CLR or C++/CLI interface to IR building API
- Trying to run mixed (MFC w/ CLR support) on wine failed
- IronRuby's Marshal.dump doesn't work with CLR types, or ruby types backed by a CLR type
- R compiler for .Net CLR