register variables allocation in Pyramids
P. Vijay
vijay at topaz.ARPA
Fri Jul 5 23:04:53 AEST 1985
>> I have to admit to getting into the sloppy habit of stopping after
>> six register declarations. But that's not why I'm writing this.
>> . . what I really want to do is make another point here, and that
>> is that you should declare register variables before ordinary
>> variables (in general), since some machines (Pyramids) ignore the
>> word ``register'' and just put the first N (12) variables in
>> registers. (Such a machine must, of course, be able to take the
>> address of a register.)
>Sounds like the Pyramid compiler has a problem there, to the extent that
>it's not following the spirit of the `register' declaration. Who ever said
>that "order of declaration" is a hint to the compiler on which variables
>are most frequently used?!
>
>Also, it's not generally possible to declare register variables before
>ordinary variables--parameters are effectively just initialized local
>variables, but the syntax requires that they all be declared before any of
>the locals. The parameter-vs-local distinction is another reason that
>compilers ought not to do what the Pyramid compiler is described as doing.
Pyramid C compiler seems to be taking an easy way out, when
it comes to allocating register variables. However, I would like to
point out that Pyramid architecture allows for a large number of
registers and every invocation of a function results in a new set of
registers (a la TI994, I think). Actually, there are 16 global
registers for each process. Besides this, for every invocation of a
function, three sets of 16 registers each are allocated. One of the
sets is specifically for storing local variables (if you have more
than 16 local vars, the rest can be placed on the data stack). Also,
the call instruction ensures that the third register set (Parameter
Register Set) before the call is the first register set (Temporary
Register Set), on entry into the function. Thus whatever arguments
you want to pass, you store in the parameter registers in some order,
and the function you are calling will see them in its temporary
registers. Needless to say, the value(s) being RETurned is (are) put
in the temporary register set, so that on return the caller sees it
(them) in its parameter register. Actually, because one may have data
types that cannot be fit into the 32 bit registers, parameter passing
uses the data stack too, if necessary. BTW, the local variables can
be stored (where else) in the second register set (Local Register
Set), one of which is created for every invocation.
Hope this clears up some of the astonishment expressed over
the *stupidity* of the Pyramid C compiler. Philosophy here is if you
can get the hardware to supply you with reasonable amount of
registers, without the hassle of saving them over calls, you don't
break your head over register allocation (*sort of*).
--Vijay--
More information about the Comp.lang.c
mailing list