|
@@ -2868,6 +2868,13 @@ implementation
|
|
|
(left.nodetype in [subn,addn,muln,divn,modn,xorn,andn,orn]) and
|
|
|
checkremovebiginttypeconvs(left,foundsint,[s8bit,u8bit,s16bit,u16bit,s32bit,u32bit],int64(low(longint)),high(cardinal)) then
|
|
|
doremoveinttypeconvs(left,generrordef,not foundsint,s32inttype,u32inttype);
|
|
|
+{$if defined(cpu16bitalu)}
|
|
|
+ if (resultdef.size <= 2) and
|
|
|
+ (is_32bitint(left.resultdef) or is_64bitint(left.resultdef)) and
|
|
|
+ (left.nodetype in [subn,addn,muln,divn,modn,xorn,andn,orn]) and
|
|
|
+ checkremovebiginttypeconvs(left,foundsint,[s8bit,u8bit,s16bit,u16bit],int64(low(smallint)),high(word)) then
|
|
|
+ doremoveinttypeconvs(left,generrordef,not foundsint,s16inttype,u16inttype);
|
|
|
+{$endif defined(cpu16bitalu)}
|
|
|
{$if defined(cpu8bitalu)}
|
|
|
if (resultdef.size<left.resultdef.size) and
|
|
|
is_integer(left.resultdef) and
|