summaryrefslogtreecommitdiff
path: root/compiler/ncgmat.pas
diff options
context:
space:
mode:
authorflorian <florian@3ad0048d-3df7-0310-abae-a5850022a9f2>2014-02-16 13:15:16 +0000
committerflorian <florian@3ad0048d-3df7-0310-abae-a5850022a9f2>2014-02-16 13:15:16 +0000
commitdf736dc035bed17e1ff9e9ec70e4ab238444cb00 (patch)
tree84caf1dd231f96e2318ca21e45031a4f51f8c63e /compiler/ncgmat.pas
parent839a87d08bc48262cf7d9af3964317c4a808a19a (diff)
downloadfpc-df736dc035bed17e1ff9e9ec70e4ab238444cb00.tar.gz
* cleanup
git-svn-id: http://svn.freepascal.org/svn/fpc/trunk@26798 3ad0048d-3df7-0310-abae-a5850022a9f2
Diffstat (limited to 'compiler/ncgmat.pas')
-rw-r--r--compiler/ncgmat.pas9
1 files changed, 1 insertions, 8 deletions
diff --git a/compiler/ncgmat.pas b/compiler/ncgmat.pas
index 543ccab3e5..b67f93c876 100644
--- a/compiler/ncgmat.pas
+++ b/compiler/ncgmat.pas
@@ -488,16 +488,9 @@ implementation
{ shifting by a constant directly coded: }
if (right.nodetype=ordconstn) then
begin
- { l shl 32 should 0 imho, but neither TP nor Delphi do it in this way (FK)
- if right.value<=31 then
- }
+ { shl/shr must "wrap around", so use ... and 31 }
cg.a_op_const_reg_reg(current_asmdata.CurrAsmList,op,location.size,
tordconstnode(right).value.uvalue and 31,left.location.register,location.register);
- {
- else
- emit_reg_reg(A_XOR,S_L,hregister1,
- hregister1);
- }
end
else
begin