Archive

Posts Tagged ‘compiler testing’

Finding the ‘minimum’ faulty program

March 17th, 2009 Derek-Jones No comments

A few weeks ago I received an inquiry about running a course/workshop on compiler writing. This does not does not happen very often and it reminded me that many years ago the ACCU asked if I would run a mentored group on compiler writing, I was busy writing a book at the time. The inquiry got me thinking it would be fun to run a compiler writing mentored group over a 6-9 month period and I emailed the general ACCU reflector asking if anybody was interested in joining such a group (any reader wanting to join the group has to be a member of the ACCU).

Over the weekend I had a brainwave for a project, automatic compiler test generation coupled with a program source code minimizer (I need a better name for this bit). Automatic test generation sounds great in theory but in practice whittling down the source code of those programs that result in a fault being exhibited, to create a usable sized test case that is practical for debugging purposes can be a major effort. What is needed is a tool to automatically do the whittling, i.e., a test case minimizer.

A simple algorithm for whittling down the source of a large test program is to continually throw away that half/third/quarter of the code that is not needed for the fault to manifest itself. A compiler project that took as input source code, removed half/third/quarter of the code and generated output that could be compiled and executed is realistic. The input/reduce/output process could be repeated until the generated source was considered to have reached some minima. Ok, this will soak up some cpu time, but computers are cheap and people are expensive.

Where does the test source code come from? Easy, it is generated from the same yacc grammar that the compiler, written by the mentored group member, uses to parse its input. Fortunately such a generation tool is available and ready to use.

The beauty is using the same grammar to generate tests and parse input. This means there is no need to worry about which language subset to use initially and support for additional language syntax can be added incrementally.

Experience shows that automatically generated test programs quickly uncover faults in production compilers, even when working with language subsets. Compiler implementors are loath to spend time cutting down a large program to find the statement/expression where the fault lies, this project will produce a tool that does the job for them.

So to recap, the mentored group is going to write one or more automatic source code generators that will be used to stress test compilers written by other people (e.g., gcc and Microsoft). Group members will also write their own compiler that reads in this automatically generated source code, throws some of it away and writes out syntactically/semantically correct source code. Various scripts will be be written to glue this all together.

Group members can pick the language they want to work with. The initial subset could just include supports for integer types, if-statements and binary operators.

If you had trouble making any sense all this, don’t join the group.

FireStats icon Powered by FireStatshow can i get some cialis

cialis for woman

generic propecia mastercard

generic levitra canada

cialis for less 20 mg

brand name cialis

buy viagra on line

cialis dosage mg

buy cialis 5 mg

levitra 20mg

buy cialis without a prescription

cialis okay for women

generic cialis canadian

online propecia cheap

buy generic cialis

buy levitra online

cialis kanada

buy cialis fedex shipping

cialis buy

cialis dose

buy xenical propecia

cheapest propecia in uk

canadian pharmacy

cialis philippines

canadian levitra

order levitra online

cialis and diarrhea

levitra vs viagra

buying cialis

online pharmacy propecia renova

i need to buy propecia

levitra sales uk

indian cialis

next day delivery cialis

buy cialis online

best propecia prices

buy propecia without prescription

levitra tabs

cialis daily canada

buy discount viagra

buying cialis in canada

cheepest cialis

cialis alternitives

cialis canada

levitra online prescription

discount propecia propecia

cialis fast delivery usa

daily cialis cost

buying generic cialis mexico rx

discount real viagra

can i order viagra from the chemist

cheapest viagra usa

generic levitra mexico

buying cialis online

buy propecia online usa

cialis okay for women

generic cialis

order propecia prescriptions

cialis low price

cialis professional

cheap online levitra

levitra canadian pharmacy

buy cialis usa

get viagra

cialis delivered overnight

buy viagra online canada

cialis discount prices

levitra buy online

cialis medication

buy viagra online cheap us

buy viagra china

cheapest viagra

canadian pharmacy viagra

ordering viagra overnight delivery

fast propecia

generic cialis

canadian healthcare pharmacy

natural viagra pills

cialis woman

canadian propecia cheap

cialis headaches

buy real viagra online

levitra cheap canadian pharmacy

generic propecia sale

buy xenical propecia

buy propecia without a prescription

cialis 5 mg buy

5 mg cialis canada

cialis fast delivery

brand name cialis

canadian healthcare pharmacy

bestellen levitra online

cialis discount

low price cialis

combine cialis and levitra

buy cheap levitra

levitra in india

buy drug propecia

cialis overnight delivery

cialis for woman

buy cialis once daily

canada pharmacy propecia

how to get viagra

buy vardenafil levitra

cialis no rx

brand cialis

canadian viagra india

cialis fast delivery

cheap viagra on line

cheap propecia order online

baldness male propecia

cheapest price propecia cheap

cialis uk

cialis cheap

cialis usa

cheapest propecia pharmacy online

cialis daily dosing cost

cialis buy

cialis daily canada

cialis in mexico

bestellen levitra

beta blockers and viagra

buy cialis

canadian healthcare viagra

best price for propecia

bruising on cialis

cheap propecia no prescription

original levitra

cialis from canada

buy cialis online without prescription

discount levitra online us

brand viagra

canadian propecia cheap

cialis brand name

buy canada in propecia

cialis tablets vs viagra

canadian healthcare

buy viagra in canada

canadian pharmacy cialis pfizer

cialis 30 mg

info levitra

cialis woman

cheap levitra without prescription

how to buy cialis in canada

brand cialis

gele viagra

canadian pharmacy cialis

brand name cialis overnight

cheapest prices on propecia

generic cialis next day shipping

buying viagra with no prescription

best way to take cialis

buy viagra without prescription

levitra for sale

canadian viagra india

index

cheap levitra without prescription

buy propecia on line

canada propecia prescription

buy generic levitra online

generic cialis next day delivery

brand name cialis overnight

generic viagra canada

cheap viagra generic

generic cialis india discount

cialis by mail

levitra online pharmacy

discount levitra purchase

cialis to buy

cialis angioplasty

best way to take cialis

cialis india pharmacy

buy cheap generic propecia

cialis canadian

best deal for propecia

generic cialis next day shipping

generic cialis from india

cheap discount levitra

generic levitra cheap

cialis from india

no prescription viagra

mail order levitra

canadian generic viagra online

female viagra

canadian healthcare cialis

order levitra

buy 5 mg cialis

buy discount viagra

cheap levitra tablets

buy pfizer viagra in canada

canada meds viagra

herbal viagra

brand viagra over the net

bestellen levitra online

cialis dosage mg

buying viagra in canada

cheapest priced propecia

best viagra

getting cialis from canada

cheapest viagra

cheap canadian viagra

cialis brand

buy generic levitra online

buy cheapest propecia

cialis blood thinner

cialis samples

cheap viagra online

cialis daily dosage pharmacy

generic propecia alternative

cheap levitra prescription

cialis for sale

buy viagra online

buy viagra mexico

cialis discounts

cialis overnight

cialis 50 mg

cialis angioplasty

cialis trazodone

buy levitra with no prescription

order cheapest propecia online

how to buy cialis in canada

buy cheap generic propecia

buy online prescription propecia

cialis 50 mg

cheap levitra

buy online prescription propecia

online pharmacy cost levitra

cialis price in canada

cialis fast delivery usa

buy viagra pills

buying cialis online

buy generic viagra india rx

cialis levitra sales

buying viagra in canada

levitra lowest price

buy generic cialis

canada generic propecia

best price generic propecia

generic levitra usa

how to get cialis no prescription

bestellen levitra

buying viagra

chip cialis

generic levitra cialis

buy viagra

best price for propecia

cialis on sale

cheap cialis

how much is viagra

cialis arterial fibrillation