Gents,

In some targets, like pdp11 and vax, most instructions can reference data in 
memory directly.

So when I have "if (x < y) ..." I would expect something like this:

        cmpw  x, y
        bgeq  1f
        ...

What I actually see, with -O2 and/or -Os, is:

        movw  x, r0
        movw  y, r1
        cmpw  r0, r1
        bgeq  1f
        ...

which is both longer and slower.  I can't tell why this happens, or how to stop 
it.  The machine description has "general_operand" so it doesn't seem to be the 
place that forces things into registers.

        paul

Reply via email to