|  | 
|  | 1 | +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --check-globals all --version 5 | 
|  | 2 | +; RUN: opt < %s -passes=rel-lookup-table-converter -relocation-model=pic -S | FileCheck %s | 
|  | 3 | +; REQUIRES: nvptx-registered-target | 
|  | 4 | +target triple = "nvptx64-nvidia-cuda" | 
|  | 5 | + | 
|  | 6 | +; Do not produce relative lookup table for nvptx target. | 
|  | 7 | + | 
|  | 8 | +@a1 = internal constant i32 0, align 4 | 
|  | 9 | +@b1 = internal constant i32 0, align 4 | 
|  | 10 | +@c1 = internal constant i32 0, align 4 | 
|  | 11 | +@d1 = internal constant i32 0, align 4 | 
|  | 12 | + | 
|  | 13 | +@switch.table = private unnamed_addr constant [3 x ptr] [ptr @a1, ptr @b1, ptr @c1], align 8 | 
|  | 14 | + | 
|  | 15 | +;. | 
|  | 16 | +; CHECK: @a1 = internal constant i32 0, align 4 | 
|  | 17 | +; CHECK: @b1 = internal constant i32 0, align 4 | 
|  | 18 | +; CHECK: @c1 = internal constant i32 0, align 4 | 
|  | 19 | +; CHECK: @d1 = internal constant i32 0, align 4 | 
|  | 20 | +; CHECK: @switch.table = private unnamed_addr constant [3 x ptr] [ptr @a1, ptr @b1, ptr @c1], align 8 | 
|  | 21 | +;. | 
|  | 22 | +define ptr @internal_linkage(i32 %cond) { | 
|  | 23 | +; CHECK-LABEL: define ptr @internal_linkage( | 
|  | 24 | +; CHECK-SAME: i32 [[COND:%.*]]) { | 
|  | 25 | +; CHECK-NEXT:    [[SWITCH_GEP:%.*]] = getelementptr inbounds [3 x ptr], ptr @switch.table, i32 0, i32 [[COND]] | 
|  | 26 | +; CHECK-NEXT:    [[RELTABLE_INTRINSIC:%.*]] = load ptr, ptr [[SWITCH_GEP]], align 8 | 
|  | 27 | +; CHECK-NEXT:    ret ptr [[RELTABLE_INTRINSIC]] | 
|  | 28 | +; | 
|  | 29 | +  %switch.gep = getelementptr inbounds [3 x ptr], ptr @switch.table, i32 0, i32 %cond | 
|  | 30 | +  %switch.load = load ptr, ptr %switch.gep, align 8 | 
|  | 31 | +  ret ptr %switch.load | 
|  | 32 | +} | 
0 commit comments