diff options
author | Xavier Leroy <xavier.leroy@inria.fr> | 2019-04-12 15:47:49 +0200 |
---|---|---|
committer | Xavier Leroy <xavierleroy@users.noreply.github.com> | 2019-05-20 18:00:46 +0200 |
commit | e9cca9c8166fadb16c64df0fbb0b9ca640c0f594 (patch) | |
tree | 58fe5d8dd5d7e39c99539b35f983b6d22ceac9d9 /arm/CBuiltins.ml | |
parent | 5b7fc96afb149ad916a9bf5015fe1eb2e0baaa7c (diff) | |
download | compcert-e9cca9c8166fadb16c64df0fbb0b9ca640c0f594.tar.gz compcert-e9cca9c8166fadb16c64df0fbb0b9ca640c0f594.zip |
PowerPC: make sure evaluation of conditions do not destroy any register
This will be useful to implement a "select" (conditional move) operation later.
- Introduce `Asmgen.loadimm64_notemp` to load a 64-bit integer
constant into a register without going through memory and without
needing a temporary register.
- Use `Asmgen.loadimm64_notemp` instead of `Asmgen.loadimm64` in the
compilation of conditions, so that GPR12 is no longer needed as a
temporary.
- Share code and proofs common to the two `Asmgen.loadimm64_` functions
as the `Asmgen.loadimm64_32s` function.
Diffstat (limited to 'arm/CBuiltins.ml')
0 files changed, 0 insertions, 0 deletions