Archive

Posts Tagged ‘compiler writer’

Minimum information needed for writing a code generator

January 29th, 2010 Derek-Jones No comments

If a compiler writer is faced with writing a back-end for an undocumented processor, what is the minimum amount of information that needs to be reverse engineered?

It is possible to implement a universal computer using a cpu that has a single instruction, subtract-and-branch-if-lessthan-or-equal-to-zero. This is all very well, but processors based on using a single instruction are a bit thin on the ground and the processor to hand is likely to support a larger number of simpler instructions.

A subtract-and-branch-if-lessthan-or-equal-to-zero instruction could be implemented on a register based machine using the appropriate sequence of load-from-memory, subtract-two-registers, store-register-to-memory and jump-if-subtract-lessthan-or-equal instructions. Information about other instructions, such as add and multiply, would be useful for code optimization. (The Turing machine model of computation is sufficiently far removed from how most programs and computers operate that it is not considered further.)

Are we done? In theory yes, in practice no. A couple pf practical problems have been glossed over; how do source literals (e.g., "Hello World") initially get written to storage, where does the storage used by the program come from and what is the file format of an executable?

Literals that are not created using an instruction (most processors have instructions for loading an integer constant into a register) are written to a part of the executable file that is read into storage by the loader on program startup. All well and good if we know enough about the format of an executable file to be able to correct generate this information and can get the operating system to put in the desired storage location. Otherwise we have to figure out some other solution.

If we know two storage locations containing values that differ by one a sequence of instructions could subtract one value from the other to eventually obtain any desired value. This bootstrap process would speed up as a wider range of know value/location pairs was built up.

How do we go about obtaining a chunk of storage? An executable file usually contains information on the initial amount of storage needed by a program when it is loaded. Calls to the heap manager are another way of obtaining storage. Again we need to know where to write the appropriate information in the executable file.

What minimum amount of storage might be expected to be available? A program executing within a stack/heap based memory model has a default amount of storage allocated for the stack (a minimum of 16k I believe under Mac OS X or iPhone OS). A program could treat the stack as its storage. Ideally what we need is the ability to access storage via an offset from the stack pointer, at worse we would have to adjust the stack pointer to the appropriate offset, pop the value into a register and then reset the stack pointer; storing would involve a push.

Having performed some calculation we probably want to communicate one or more values to the outside world. A call to a library routine, such as printf, needs information on the parameter passing conventions (e.g., which parameters get stored in which registers or have storage allocated for them {a function returning a structure type usually has the necessary storage allocated by the calling function with the address passed as an extra parameter}) and the location of any return value. If ABI information is not available a bit of lateral thinking might be needed to come up with an alternative output method.

I have not said anything about making use of signals and exception handling. These are hard enough to get right when documentation is available. The Turing machine theory folk usually skip over these real-world issues and I will join them for the time being.

Criteria for knowing a language

December 23rd, 2008 Derek-Jones 1 comment

What does it mean for somebody to claim to know a computer language? In the commercial world it means the person is claiming to be capable of fluently (i.e., only using knowledge contained in their head and without having to unduly ponder) reading, and writing code in some generally accepted style applicable to that language. The academic world generally sets a much lower standard of competence (perhaps because most of its inhabitants leave before any significant expertise is acquired). If I had a penny for every recent graduate who claimed to know a language and was incapable of writing a program that read in a list of integers and printed their sum (I know companies that set tougher problems but they do not seem to have higher failure rates), I would be a rich man.

One experiment asked 21 postgraduate and academic staff which of the following individuals they would regard as knowing Java:

  • A cannot program in Java, but knows that Java is a popular programming language.
  • B cannot write a Java program from scratch, but can make very simple changes to an existing Java program (such as changing a string constant that specifies a URL).
  • C can use a tool such as JBuilder to write a very simple Java program, but cannot use control flow constructs such as while loops.
  • D can write Java programs that use while loops, arrays, and the Java class libraries, but only within one class; she cannot write a program that consists of several classes.
  • E can create complex Java programs and classes, but needs to occasionally refer to documentation for details of the Java language and class libraries
  • The results were:

    _ NO YES
    A 21  0
    B 18  3
    C 16  5
    D  8 13
    E  0 21

    These answers reflect the environment from which the subjects were drawn. When I wrote compilers for a living I did not consider that anybody knew a language unless they had written a compiler for it, a point of view echoed by other compiler writers I knew.

    I’m not sure that commercial developers would be happy with answer (E), in fact they could probably expand (E) into five separate questions that tested the degree to which a person was able to combine various elements of the language to create a meaningful whole. In the commercial world stage (E) is where people are expected to start.

    The criteria used to decide whether somebody knows a language depends on which group of people you talk to; academics, professional developers and compiler writers each have their own in-group standards. In a sense the question is irrelevant, a small amount of language knowledge applied well can be used to do a reasonable job of creating a program for most applications.

    www.wenn.com
    FireStats icon Powered by FireStatswww.tinynibbles.com cialis daily in canada

    cialis cheap

    buy viagra without prescription

    cost of daily cialis

    next day delivery cialis

    cheap levitra tablets

    low cost canadian viagra

    levitra discount

    china viagra

    levitra tabs

    online pharmacy propecia viagra

    buy levitra uk

    levitra low price

    cialis alternative

    buy cialis usa

    mail order levitra

    cialis buy overnight

    buy cheap levitra online

    cheapest prices for viagra

    levitra in india

    bestellen levitra online

    female viagra pills

    canadian viagra india

    i need to buy propecia

    cialis dosage mg

    cialis on women

    cialis purchase

    cheapest propecia sale uk

    cheapest propecia uk

    cheap viagra online

    buy cialis without prescription

    for sale levitra

    cheapest viagra

    buy real cialis

    hydrochlorothiazide cialis

    buy propecia online prescription

    canada viagra

    brand viagra professional

    cheapest viagra online

    how to get viagra

    generic propecia for sale

    buy propecia now

    mexico levitra

    buy viagra on line

    buy cheap levitra

    canadian viagra 50mg

    order cheap levitra

    buy cialis for daily use

    how strong is 5 mg of cialis

    cialis overnight

    order cheap propecia

    best viagra

    cialis vs levitra

    cialis professional no prescription

    cheap propecia no prescription

    generic propecia 5mg

    overnight delivery viagra

    buy fast propecia

    cialis overnight delivery

    buy discount viagra

    cialis quick shipment

    mexico pharmacy cialis

    online viagra gel to buy

    cialis cheap us pharmacy

    once a day viagra

    online generic cialis 100 mg

    buy propecia prescriptions online

    buy cialis once daily

    online cheap viagra

    mail online order propecia

    generic levitra overnight delivery

    buy prescription propecia without

    buying generic cialis mexico rx

    levitra order prescription

    buy propecia generic

    cialis 50 mg

    canadian viagra

    levitra online sales

    lowest propecia prices

    cialis 5 mg italia

    cialis next day

    indian cialis generic

    cost levitra low

    generic cialis from india

    cialis strenght mg

    discount propecia online

    generic propecia sale

    levitra mail order

    daily dosage cialis

    cheap levitra uk

    canada online pharmacy levitra

    cheap propecia uk

    cialis fast delivery

    cialis tablets

    cheap cialis

    cheap levitra prescription

    buy viagra germany canadian meds

    cialis and ketoconazole

    cialis 5 mg buy

    generic viagra made in india

    online pharmacy propecia renova

    cheap canadian viagra

    gele viagra

    order viagra or levitra

    cialis en mexico

    online propecia prescriptions

    buy cheap generic levitra

    order levitra online

    cialis discount

    cialis transdermal

    cheap viagra canada or india

    genuine cialis pills

    lowest cost levitra

    discount cialis india

    generic viagra made in usa

    cialis from canada

    cheap prescription propecia

    cialis to buy

    5 mg original brand cialis

    cialis professional 100 mg

    buy generic cialis

    obtain viagra without prescription

    levitra cost

    50 mg cialis

    overnight delivery cialis

    buy levitra overnight

    buy propecia online

    cialis next day delivery

    canadian healthcare viagra

    buy levitra us

    lowest price on non generic levitra

    buy levitra online from canada

    lowest price propecia best

    cialis profesional

    how much does cialis cost

    herbal propecia

    online propecia prescription

    cheap propecia 5mg

    indian cialis

    canadian pharmacy viagra

    best price cialis

    generic propecia alternative

    generic viagra canadian

    cialis discounts

    canadian online pharmacy cialis

    best price for generic cialis

    buy cialis canada

    brand name cialis

    order prescription propecia

    get cialis online

    brand viagra over the net

    levitra next day delivery

    generic levitra online

    buying generic propecia

    buy viagra online cheap us

    low cost propecia

    levitra prescription

    cheapest viagra usa

    once daily cialis

    discount generic propecia

    cialis price

    buying levitra online

    cialis and canada custom

    generic levitra canada

    canadian healthcare

    generic propecia fda approved

    cialis daily dosage pharmacy

    buy viagra china

    generic levitra cheap

    canadian pharmacy discount code viagra

    buying cialis next day delivery

    can i get viagra in mexico

    canada viagra generic

    buying cialis soft tabs 100 mg

    generic cialis sale

    canada online pharmacy propecia

    levitra cheap fast

    buy online prescription propecia

    order propecia

    buy cialis in usa

    cialis prescription

    cialis and diarrhea

    canadian drugs propecia

    cialis pharmacy

    combine cialis and levitra

    generic viagra 100 mg

    levitra where to buy

    buying propecia online

    buy cheap generic propecia

    cheap levitra without prescription

    cialis uk

    levitra in canada

    cialis online

    cialis price 100 mg

    buy viagra online

    cialis professional 20 mg

    cialis headaches

    generic levitra vardenafil

    canada levitra

    buy viagra mexico

    levitra online prescription

    discount propecia propecia

    cialis delivered overnight

    does generic cialis work

    cheap cialis soft

    cialis 100 mg generic

    brand cialis for sale

    generic viagra online

    discount levitra online

    generic propecia online pharmacy

    how much to buy viagra in pounds

    buying viagra in canada

    levitra now online

    buy can from i propecia who

    cheapest overnight cialis

    order cheapest propecia online

    ganeric cialis

    get levitra

    best way to use cialis

    cialis soft pills

    cheap cialis from india

    how much cialis

    levitra from canadian pharmacy

    online cialis

    buy cialis online canada

    buy propecia without prescription

    canadian pharmacy cialis

    canada viagra pharmacies scam

    cheap fast levitra

    brand name cialis overnight

    lowest propecia prices in canada

    canadian pharmacy

    buy levitra vardenafil

    cialis from mexico

    get propecia online pharmacy

    cialis 5 mg

    buy levitra online no prescription

    levitra for sale

    cialis woman

    cialis price in canada

    levitra mg

    lowest propecia 1 mg

    buy generic levitra

    buy propecia online from usa pharmacy

    buying online propecia

    buying cialis

    buy 5 mg cialis

    discount us propecia

    ordering propecia online

    generic viagra canada

    levitra 10mg

    next day viagra

    levitra online overnight delivery

    buy dosages levitra

    canada cheap propecia

    cialis 100 mg

    cialis 20 mg

    cost of propecia

    low cost levitra

    canada propecia prescription

    healthcare canadian pharmacy

    name brand cialis

    cheapest propecia prescription

    lowest priced propecia

    how to buy cialis in canada

    5 mg daily cialis

    buy propecia cheap

    generic viagra india

    getting cialis from canada

    cialis generic 100 mg

    levitra online no prescription

    buy cialis 5 mg

    get levitra online

    cialis by mail

    discount levitra rx

    levitra pill

    cheapest price propecia cheap

    generic levitra purchase

    buy propecia where

    cialis refractory

    canadian viagra and healthcare

    levitra online

    cialis fast delivery usa

    generic propecia finasteride

    how to get cialis in canada

    buy canada levitra

    cialis no prescription

    buy viagra

    cialis tablets foreign

    levitra buy online

    best price generic propecia

    best price levitra

    buy generic viagra india rx

    cheap viagra from uk

    drug generic propecia

    best price for propecia

    buy branded viagra

    buy real viagra online

    natural viagra

    buy propecia on line