File: x32-irtranslator.ll

package info (click to toggle)
llvm-toolchain-16 1%3A16.0.6-15~deb11u2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 1,634,820 kB
  • sloc: cpp: 6,179,261; ansic: 1,216,205; asm: 741,319; python: 196,614; objc: 75,325; f90: 49,640; lisp: 32,396; pascal: 12,286; sh: 9,394; perl: 7,442; ml: 5,494; awk: 3,523; makefile: 2,723; javascript: 1,206; xml: 886; fortran: 581; cs: 573
file content (29 lines) | stat: -rw-r--r-- 1,210 bytes parent folder | download | duplicates (17)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
; NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
; RUN: llc -global-isel -mtriple=x86_64-linux-gnux32 -stop-after=irtranslator -verify-machineinstrs < %s -o - | FileCheck -check-prefix=X32ABI %s

define ptr @ret_ptr() {
  ; X32ABI-LABEL: name: ret_ptr
  ; X32ABI: bb.1 (%ir-block.0):
  ; X32ABI:   [[DEF:%[0-9]+]]:_(p0) = G_IMPLICIT_DEF
  ; X32ABI:   [[LOAD:%[0-9]+]]:_(p0) = G_LOAD [[DEF]](p0) :: (load (p0) from `ptr undef`)
  ; X32ABI:   [[PTRTOINT:%[0-9]+]]:_(s32) = G_PTRTOINT [[LOAD]](p0)
  ; X32ABI:   [[ZEXT:%[0-9]+]]:_(s64) = G_ZEXT [[PTRTOINT]](s32)
  ; X32ABI:   $rax = COPY [[ZEXT]](s64)
  ; X32ABI:   RET 0, implicit $rax
  %ptr = load ptr, ptr undef
  ret ptr %ptr
}

define void @arg_ptr(ptr %ptr) {
  ; X32ABI-LABEL: name: arg_ptr
  ; X32ABI: bb.1 (%ir-block.0):
  ; X32ABI:   liveins: $rdi
  ; X32ABI:   [[COPY:%[0-9]+]]:_(s64) = COPY $rdi
  ; X32ABI:   [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC [[COPY]](s64)
  ; X32ABI:   [[INTTOPTR:%[0-9]+]]:_(p0) = G_INTTOPTR [[TRUNC]](s32)
  ; X32ABI:   [[C:%[0-9]+]]:_(s32) = G_CONSTANT i32 1
  ; X32ABI:   G_STORE [[C]](s32), [[INTTOPTR]](p0) :: (store (s32) into %ir.ptr)
  ; X32ABI:   RET 0
  store i32 1, ptr %ptr
  ret void
}