> How do you handle tail calls and value types?I haven't worried too much about optimisation yet, so it doesn't do anything special for tail calls (although neither does the java compiler). LLVM types are translated to their equivalent java primitive type (or currently it raises an assertion if there is no equivalent type). -- David Roberts da.vidr.cc On Sat, Nov 28, 2009 at 02:56, Jon Harrop <jon at ffconsultancy.com> wrote:> On Friday 27 November 2009 05:55:59 David Roberts wrote: >> > If you translate to a big array of memory and index into it, how is it >> > better than the mips -> java compiler? >> >> Yes, it is similar to the mips to java compiler in that regard, but it >> does have several advantages over it. For example, functions are >> mapped to individual methods (rather than just a big chunk of >> translated instructions), allowing Java to call individual functions >> in the compiled language and vice versa. This also allows programs to >> be split amongst multiple classes rather than statically linking >> everything into the one file (which is sometimes not possible for >> large projects). > > How do you handle tail calls and value types? > > -- > Dr Jon Harrop, Flying Frog Consultancy Ltd. > ffconsultancy.com/?e > _______________________________________________ > LLVM Developers mailing list > LLVMdev at cs.uiuc.edu llvm.cs.uiuc.edu > lists.cs.uiuc.edu/mailman/listinfo/llvmdev >
On Saturday 28 November 2009 06:20:39 David Roberts wrote:> > How do you handle tail calls and value types? > > I haven't worried too much about optimisation yet, so it doesn't do > anything special for tail calls (although neither does the java > compiler). LLVM types are translated to their equivalent java > primitive type (or currently it raises an assertion if there is no > equivalent type).So it will stack overflow on tail calls and break with run-time errors on structs? I would love to be able to evaluate LLVM IR in a safe environment (like the JVM) for debugging purposes but this is too incomplete to be useful for me: my IR depends heavily upon tail calls and value types. Unfortunately, the MSIL backend and lli are also incomplete and, therefore, useless for me too. As Chris said, the LLVM world really needs any fully working solution rather than a selection of incomplete solutions. -- Dr Jon Harrop, Flying Frog Consultancy Ltd. ffconsultancy.com/?e
> So it will stack overflow on tail callsAt the moment, yes. But then again, so does java. Also, it looks like they're working on support for tail calls in the Da Vinci Machine[1].> and break with run-time errorsWhen I said it raises an assertion, I meant at compile-time.> on structs?No, structs are supported. The only unsupported types at the moment (as far as I am aware) are things like i31 and f80.> I would love to be able to evaluate LLVM IR in a safe environment (like the > JVM) for debugging purposes but this is too incomplete to be useful for me: > my IR depends heavily upon tail calls and value types. Unfortunately, the > MSIL backend and lli are also incomplete and, therefore, useless for me too. > > As Chris said, the LLVM world really needs any fully working solution rather > than a selection of incomplete solutions.I haven't been working on this project for too long - you can't expect it to be perfect on the first release. [1] openjdk.java.net/projects/mlvm/subprojects.html#TailCalls -- David Roberts da.vidr.cc On Sun, Nov 29, 2009 at 09:49, Jon Harrop <jon at ffconsultancy.com> wrote:> On Saturday 28 November 2009 06:20:39 David Roberts wrote: >> > How do you handle tail calls and value types? >> >> I haven't worried too much about optimisation yet, so it doesn't do >> anything special for tail calls (although neither does the java >> compiler). LLVM types are translated to their equivalent java >> primitive type (or currently it raises an assertion if there is no >> equivalent type). > > So it will stack overflow on tail calls and break with run-time errors on > structs? > > I would love to be able to evaluate LLVM IR in a safe environment (like the > JVM) for debugging purposes but this is too incomplete to be useful for me: > my IR depends heavily upon tail calls and value types. Unfortunately, the > MSIL backend and lli are also incomplete and, therefore, useless for me too. > > As Chris said, the LLVM world really needs any fully working solution rather > than a selection of incomplete solutions. > > -- > Dr Jon Harrop, Flying Frog Consultancy Ltd. > ffconsultancy.com/?e > _______________________________________________ > LLVM Developers mailing list > LLVMdev at cs.uiuc.edu llvm.cs.uiuc.edu > lists.cs.uiuc.edu/mailman/listinfo/llvmdev >