File: mul.ll

package info (click to toggle)
intel-graphics-compiler2 2.22.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 107,676 kB
  • sloc: cpp: 809,645; lisp: 288,070; ansic: 16,397; python: 4,010; yacc: 2,588; lex: 1,666; pascal: 314; sh: 186; makefile: 38
file content (21 lines) | stat: -rw-r--r-- 778 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
;=========================== begin_copyright_notice ============================
;
; Copyright (C) 2021 Intel Corporation
;
; SPDX-License-Identifier: MIT
;
;============================ end_copyright_notice =============================

;RUN: %opt %use_old_pass_manager% -GenXReduceIntSize -march=genx64 -S < %s | FileCheck %s

; CHECK-LABEL: test
; CHECK-NEXT: %.sext.reduceintsize = sext <16 x i8> %arg to <16 x i16>
; CHECK-NEXT: %.sext.reduceintsize1 = sext <16 x i8> %arg to <16 x i16>
; CHECK-NEXT: %res = mul <16 x i16> %.sext.reduceintsize, %.sext.reduceintsize1
define <16 x i16> @test(<16 x i8> %arg) {
  %.sext = sext <16 x i8> %arg to <16 x i32>
  %res = mul nsw <16 x i32> %.sext, %.sext
  %.trunc= trunc <16 x i32> %res to <16 x i16>
  ret <16 x i16> %.trunc
}