On Tue, Mar 21, 2017 at 01:36:50PM +0000, Dibyendu Majumdar wrote: > Hi Luc, > > On 21 March 2017 at 13:00, Luc Van Oostenryck > <luc.vanoostenryck@xxxxxxxxx> wrote: > > On Tue, Mar 21, 2017 at 11:24:57AM +0000, Dibyendu Majumdar wrote: > >> Thank you once again for posting this set of patches. I wanted to > >> understand what your approach is with testing of the LLVM backend in > >> general. The test cases that are currently present and also the new > >> ones you are adding do not appear to be runnable. Unless you are > >> saving expected LLVM IR output and comparing the test output with that > >> I think the tests do not prove that the generated code is correct. > > > > I'm not surprised at all that some of the test cases, new or old, > > are not runnable (I suppose that you mean that their execution > > produce wrong result). > > I meant that they are not runnable as in you cannot run the compiled > output. Moreover the tests do not validate the expected results. > > > > > It's a bit too early for me to look closely at the generated code, > > there was simply too much input code that caused crashes, triggered > > some asserts or produced type error in the LLVM IR. And it's not > > like everything is now solved regarding this. > > > > Okay understand this. > > > For the next steps, yes, it would certainly be needed to have tests > > for the correctness of the generated code. And by 'tests' I mean > > 'test cases suitable and present in sparse's test suite'. > > I was somehow expecting you will submit them/somes as you seem > > quite interested in sparse/LLVM. > > > > Indeed I am and I have a bunch of tests in my repository that I run > everytime I change something. These tests are all runnable in the > sense mentioned above, and all are designed to validate that results > are as expected. I am happy to contribute these as I mentioned before > - but I am not sure of the process. Do I just submit patches? Are > there any specific needs for how the tests should be run? I haven't yet really thought about it but here is a few things: - small, specific tests are preferable but - bigger tests have also their uses. - testing the output of llvm-dis can be interesting but is very sensitive to details of the code (like names and such). - 'sparsei' (sparse-llvm + lli) can be usefull for these tests (maybe you already use it?). Otherwise, yes sending patches to the mailing list is the normal way to contribute but maybe Chris is fine to accept other means too. If needed I can be an intermeadiate in the process. > I am very much interested in ensuring that as changes occur in sparse > they do not break things. While I will catch these breaks in my > repository it is better to catch them upstream. It's very much the same for me, I much prefer having tests while developing than going blindly, submitting a serie, waiting for feedback and respin. -- Luc -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html