HACK mescc: Consider truncate after each shift operation.

XXX For every binop / binop* operation?  We need tests?

* module/mescc/compile.scm (expr->register): After lshift and rshift,
use convert-r0.

Instead of truncating on size of first operand, truncate on largest of
default/int or size of first operand
This commit is contained in:
Janneke Nieuwenhuizen 2023-07-30 09:51:08 +02:00 committed by Ekaitz Zarraga
parent 1f14a62e0a
commit 6b477daae4
1 changed files with 14 additions and 2 deletions

View File

@ -1216,8 +1216,20 @@
(append-text info (wrap-as (as info 'not-r)))))
((bitwise-or ,a ,b) ((binop->r info) a b 'r0-or-r1))
((bitwise-xor ,a ,b) ((binop->r info) a b 'r0-xor-r1))
((lshift ,a ,b) ((binop->r info) a b 'r0<<r1))
((rshift ,a ,b) ((binop->r info) a b 'r0>>r1))
((lshift ,a ,b) ;; FIXME for all binop/binop*?
(let* ((type-a (ast->type a info))
(default (get-type "default" info))
(type (if (> (->size type-a info) (->size default info)) type-a
default))
(info ((binop->r info) a b 'r0<<r1)))
(append-text info (convert-r0 info type))))
((rshift ,a ,b) ;; FIXME for all binop/binop*?
(let* ((type-a (ast->type a info))
(default (get-type "default" info))
(type (if (> (->size type-a info) (->size default info)) type-a
default))
(info ((binop->r info) a b 'r0>>r1)))
(append-text info (convert-r0 info type))))
((div ,a ,b)
((binop->r info) a b 'r0/r1
(signed? (ast->type a info))))