Add RISC-V encodings for lui.
This instruction can materialize constants with the low 12 bits clear.
This commit is contained in:
@@ -5,8 +5,8 @@ from __future__ import absolute_import
|
||||
from base import instructions as base
|
||||
from base.immediates import intcc
|
||||
from .defs import RV32, RV64
|
||||
from .recipes import OPIMM, OPIMM32, OP, OP32
|
||||
from .recipes import JALR, R, Rshamt, Ricmp, I, Iicmp, Iret
|
||||
from .recipes import OPIMM, OPIMM32, OP, OP32, LUI
|
||||
from .recipes import JALR, R, Rshamt, Ricmp, I, Iicmp, Iret, U
|
||||
from .settings import use_m
|
||||
from cdsl.ast import Var
|
||||
|
||||
@@ -66,6 +66,11 @@ RV64.enc(base.icmp_imm.i64(intcc.slt, x, y), Iicmp, OPIMM(0b010))
|
||||
RV32.enc(base.icmp_imm.i32(intcc.ult, x, y), Iicmp, OPIMM(0b011))
|
||||
RV64.enc(base.icmp_imm.i64(intcc.ult, x, y), Iicmp, OPIMM(0b011))
|
||||
|
||||
# Integer constants with the low 12 bits clear are materialized by lui.
|
||||
RV32.enc(base.iconst.i32, U, LUI())
|
||||
RV64.enc(base.iconst.i32, U, LUI())
|
||||
RV64.enc(base.iconst.i64, U, LUI())
|
||||
|
||||
# "M" Standard Extension for Integer Multiplication and Division.
|
||||
# Gated by the `use_m` flag.
|
||||
RV32.enc(base.imul.i32, R, OP(0b000, 0b0000001), isap=use_m)
|
||||
|
||||
Reference in New Issue
Block a user