riscv64: Add Zba extension instructions (#6087)
* riscv64: Use `add.uw` to zero extend * riscv64: Implement `add.uw` optimizations * riscv64: Add `Zba` `iadd+ishl` optimizations * riscv64: Add `shl+uextend` optimizations based on `Zba` * riscv64: Fix some issues with `Zba` instructions * riscv64: Restrict shnadd selection * riscv64: Fix `extend` priorities * riscv64: Remove redundant `addw` rule * riscv64: Specify type for `add` extend rules * riscv64: Use `u64_from_imm64` extractor instead of `uimm8` * riscv64: Restrict `uextend` in `shnadd.uw` rules * riscv64: Use concrete type in `slli.uw` rule * riscv64: Add extra arithmetic extends tests Co-authored-by: Jamey Sharp <jsharp@fastly.com> * riscv64: Make `Adduw` types concrete * riscv64: Add extra arithmetic extend tests * riscv64: Add `sextend`+Arithmetic rules * riscv64: Fix whitespace * cranelift: Move arithmetic extends tests with i128 to separate file --------- Co-authored-by: Jamey Sharp <jsharp@fastly.com>
This commit is contained in:
@@ -1157,9 +1157,15 @@
|
||||
(let ((val Reg (value_regs_get val 0)))
|
||||
(alu_rr_imm12 (AluOPRRI.Zexth) val (imm12_const 0))))
|
||||
|
||||
;; With `zba` we have a `zext.w` instruction
|
||||
(rule 2 (extend val (ExtendOp.Zero) $I32 $I64)
|
||||
(if-let $true (has_zba))
|
||||
(let ((val Reg (value_regs_get val 0)))
|
||||
(alu_rrr (AluOPRRR.Adduw) val (zero_reg))))
|
||||
|
||||
;;; Signed rules extending to I128
|
||||
;; Extend the bottom part, and extract the sign bit from the bottom as the top
|
||||
(rule 2 (extend val (ExtendOp.Signed) (fits_in_64 from_ty) $I128)
|
||||
(rule 3 (extend val (ExtendOp.Signed) (fits_in_64 from_ty) $I128)
|
||||
(let ((val Reg (value_regs_get val 0))
|
||||
(low Reg (extend val (ExtendOp.Signed) from_ty $I64))
|
||||
(high Reg (alu_rr_imm12 (AluOPRRI.Srai) low (imm12_const 63))))
|
||||
|
||||
Reference in New Issue
Block a user