I was wondering if there\'s a way to disable predication in gcc/g++. When I get the object dump of my code, I don\'t want there to be any CMOV, CCMP, etc instructions in it.
Try the following arguments on the gcc command line:
-fno-if-conversion -fno-if-conversion2 -fno-tree-loop-if-convert
This worked for me and the trick was the last argument, which is needed for some cases where ifs are converted to conditional moves inside loops, and these cases aren't covered by the other two arguments.
I discovered this based on this conversation from the gcc mailing lists:
--- Comment #1 from Andrew Pinski --- I don't think -fno-if-conversion and -fno-if-conversion2 are designed to turn off all predicated instructions.
Note -O3 turns on -ftree-loop-if-convert which also causes production of predicated instructions (predicated moves).
You could try targetting a previous x86 instruction set that didn't have these instructions?
http://gcc.gnu.org/onlinedocs/gcc-3.2.3/gcc/Target-Options.html
gcc -b i386 main.c
(I've not tried this)
I ran into that problem before and in my case the solution was to disable if-conversion. You can use the compilation flags:
-fno-if-conversion -fno-if-conversion2