In ego, put both words and double-words in reg_float.
authorGeorge Koehler <xkernigh@netscape.net>
Fri, 17 Feb 2017 00:55:52 +0000 (19:55 -0500)
committerGeorge Koehler <xkernigh@netscape.net>
Fri, 17 Feb 2017 00:55:52 +0000 (19:55 -0500)
commita20b87ca011d70ed25d98634d36302434289d5f4
treec3586092aebd2ee7a00de6c5aa930b295fe2d7d0
parentcbe5d8640b9b268f5e085b7fd319a5bf8ad8775a
In ego, put both words and double-words in reg_float.

The size of a reg_float isn't in the descr file, so ego doesn't know.
PowerPC and SPARC are the only arches with floating-point registers in
their descr files.  PowerPC and SPARC registers can hold both 4-byte
and 8-byte floats, so I want ego to do both sizes.

This might break our SPARC code expander because ego doesn't know that
8-byte values take 2 registers in SPARC.  (So ego might allocate too
many registers and deallocate too much stack space.)  We don't build
the SPARC code expander, and its descr file is already wrong: its list
of register save costs is too short, so ego will read past the end of
the array.

This commit doesn't fix the problem with ego and PowerPC ncg.  Right
now, ncg refuses to put 4-byte floats in registers, but ego expects
them to get registers and deallocates their stack space.  So ncg emits
programs that use the deallocated space, and the values of 4-byte
floats become corrupt.
util/ego/ra/ra_profits.c