------- Comment #2 from ian at airs dot com 2006-02-02 18:14 -------
With an updated version of RTH's subreg lowering pass, I get this instruction
sequence:
f:
movl 16(%esp), %eax
movl 4(%esp), %edx
movl 8(%esp), %ecx
shrl $16, %eax
andl $255, %eax
shldl $8, %edx, %ecx
sall $8, %edx
orl %edx, %eax
movl %ecx, %edx
ret
This is one instruction shorter than the icc sequence, due to the use of shldl.
It could be improved by switching the roles of %ecx and %edx to avoid the
final move, although that is complex to implement give the way the register
allocator currently handles pseudo-registers larger than word mode.
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=24929