Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(728)

Unified Diff: tests_lit/reader_tests/casts.ll

Issue 514273002: Add cast instructions to subzero's pnacl bitcode translator. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Fix issues in patch set 2. Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/PNaClTranslator.cpp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests_lit/reader_tests/casts.ll
diff --git a/tests_lit/reader_tests/casts.ll b/tests_lit/reader_tests/casts.ll
new file mode 100644
index 0000000000000000000000000000000000000000..f09de256336fc422744a368f21071c1bd35a861d
--- /dev/null
+++ b/tests_lit/reader_tests/casts.ll
@@ -0,0 +1,537 @@
+; Tests if we can read cast operations.
+
+; RUN: llvm-as < %s | pnacl-freeze \
+; RUN: | %llvm2ice -notranslate -verbose=inst -build-on-read \
+; RUN: -allow-pnacl-reader-error-recovery \
+; RUN: | FileCheck %s
+
+; TODO(kschimpf) Find way to test pointer conversions (since they in general
+; get removed by pnacl-freeze).
+
+define i32 @TruncI64(i64 %v) {
+ %v1 = trunc i64 %v to i1
+ %v8 = trunc i64 %v to i8
+ %v16 = trunc i64 %v to i16
+ %v32 = trunc i64 %v to i32
+ ret i32 %v32
+}
+
+; CHECK: define i32 @TruncI64(i64 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i64 %__0 to i1
+; CHECK-NEXT: %__2 = trunc i64 %__0 to i8
+; CHECK-NEXT: %__3 = trunc i64 %__0 to i16
+; CHECK-NEXT: %__4 = trunc i64 %__0 to i32
+; CHECK-NEXT: ret i32 %__4
+; CHECK-NEXT: }
+
+define void @TruncI32(i32 %v) {
+ %v1 = trunc i32 %v to i1
+ %v8 = trunc i32 %v to i8
+ %v16 = trunc i32 %v to i16
+ ret void
+}
+
+; CHECK-NEXT: define void @TruncI32(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i1
+; CHECK-NEXT: %__2 = trunc i32 %__0 to i8
+; CHECK-NEXT: %__3 = trunc i32 %__0 to i16
+; CHECK-NEXT: ret void
+; CHECK-NEXT: }
+
+define void @TruncI16(i32 %p) {
+ %v = trunc i32 %p to i16
+ %v1 = trunc i16 %v to i1
+ %v8 = trunc i16 %v to i8
+ ret void
+}
+
+; CHECK-NEXT: define void @TruncI16(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i16
+; CHECK-NEXT: %__2 = trunc i16 %__1 to i1
+; CHECK-NEXT: %__3 = trunc i16 %__1 to i8
+; CHECK-NEXT: ret void
+; CHECK-NEXT: }
+
+define void @TruncI8(i32 %p) {
+ %v = trunc i32 %p to i8
+ %v1 = trunc i8 %v to i1
+ ret void
+}
+
+; CHECK-NEXT: define void @TruncI8(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i8
+; CHECK-NEXT: %__2 = trunc i8 %__1 to i1
+; CHECK-NEXT: ret void
+; CHECK-NEXT: }
+
+define i64 @ZextI1(i32 %p) {
+ %v = trunc i32 %p to i1
+ %v8 = zext i1 %v to i8
+ %v16 = zext i1 %v to i16
+ %v32 = zext i1 %v to i32
+ %v64 = zext i1 %v to i64
+ ret i64 %v64
+}
+
+; CHECK-NEXT: define i64 @ZextI1(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i1
+; CHECK-NEXT: %__2 = zext i1 %__1 to i8
+; CHECK-NEXT: %__3 = zext i1 %__1 to i16
+; CHECK-NEXT: %__4 = zext i1 %__1 to i32
+; CHECK-NEXT: %__5 = zext i1 %__1 to i64
+; CHECK-NEXT: ret i64 %__5
+; CHECK-NEXT: }
+
+define i32 @ZextI8(i32 %p) {
+ %v = trunc i32 %p to i8
+ %v16 = zext i8 %v to i16
+ %v32 = zext i8 %v to i32
+ %v64 = zext i8 %v to i64
+ ret i32 %v32
+}
+
+; CHECK-NEXT: define i32 @ZextI8(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i8
+; CHECK-NEXT: %__2 = zext i8 %__1 to i16
+; CHECK-NEXT: %__3 = zext i8 %__1 to i32
+; CHECK-NEXT: %__4 = zext i8 %__1 to i64
+; CHECK-NEXT: ret i32 %__3
+; CHECK-NEXT: }
+
+define i64 @ZextI16(i32 %p) {
+ %v = trunc i32 %p to i16
+ %v32 = zext i16 %v to i32
+ %v64 = zext i16 %v to i64
+ ret i64 %v64
+}
+
+; CHECK-NEXT: define i64 @ZextI16(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i16
+; CHECK-NEXT: %__2 = zext i16 %__1 to i32
+; CHECK-NEXT: %__3 = zext i16 %__1 to i64
+; CHECK-NEXT: ret i64 %__3
+; CHECK-NEXT: }
+
+define i64 @Zexti32(i32 %v) {
+ %v64 = zext i32 %v to i64
+ ret i64 %v64
+}
+
+; CHECK-NEXT: define i64 @Zexti32(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = zext i32 %__0 to i64
+; CHECK-NEXT: ret i64 %__1
+; CHECK-NEXT: }
+
+define i32 @SextI1(i32 %p) {
+ %v = trunc i32 %p to i1
+ %v8 = sext i1 %v to i8
+ %v16 = sext i1 %v to i16
+ %v32 = sext i1 %v to i32
+ %v64 = sext i1 %v to i64
+ ret i32 %v32
+}
+
+; CHECK-NEXT: define i32 @SextI1(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i1
+; CHECK-NEXT: %__2 = sext i1 %__1 to i8
+; CHECK-NEXT: %__3 = sext i1 %__1 to i16
+; CHECK-NEXT: %__4 = sext i1 %__1 to i32
+; CHECK-NEXT: %__5 = sext i1 %__1 to i64
+; CHECK-NEXT: ret i32 %__4
+; CHECK-NEXT: }
+
+define i64 @SextI8(i32 %p) {
+ %v = trunc i32 %p to i8
+ %v16 = sext i8 %v to i16
+ %v32 = sext i8 %v to i32
+ %v64 = sext i8 %v to i64
+ ret i64 %v64
+}
+
+; CHECK-NEXT: define i64 @SextI8(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i8
+; CHECK-NEXT: %__2 = sext i8 %__1 to i16
+; CHECK-NEXT: %__3 = sext i8 %__1 to i32
+; CHECK-NEXT: %__4 = sext i8 %__1 to i64
+; CHECK-NEXT: ret i64 %__4
+; CHECK-NEXT: }
+
+define i32 @SextI16(i32 %p) {
+ %v = trunc i32 %p to i16
+ %v32 = sext i16 %v to i32
+ %v64 = sext i16 %v to i64
+ ret i32 %v32
+}
+
+; CHECK-NEXT: define i32 @SextI16(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i16
+; CHECK-NEXT: %__2 = sext i16 %__1 to i32
+; CHECK-NEXT: %__3 = sext i16 %__1 to i64
+; CHECK-NEXT: ret i32 %__2
+; CHECK-NEXT: }
+
+define i64 @Sexti32(i32 %v) {
+ %v64 = sext i32 %v to i64
+ ret i64 %v64
+}
+
+; CHECK-NEXT: define i64 @Sexti32(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = sext i32 %__0 to i64
+; CHECK-NEXT: ret i64 %__1
+; CHECK-NEXT: }
+
+define float @Fptrunc(double %v) {
+ %vfloat = fptrunc double %v to float
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @Fptrunc(double %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = fptrunc double %__0 to float
+; CHECK-NEXT: ret float %__1
+; CHECK-NEXT: }
+
+define double @Fpext(float %v) {
+ %vdouble = fpext float %v to double
+ ret double %vdouble
+}
+
+; CHECK-NEXT: define double @Fpext(float %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = fpext float %__0 to double
+; CHECK-NEXT: ret double %__1
+; CHECK-NEXT: }
+
+define i32 @FptouiFloat(float %v) {
+ %v1 = fptoui float %v to i1
+ %v8 = fptoui float %v to i8
+ %v16 = fptoui float %v to i16
+ %v32 = fptoui float %v to i32
+ %v64 = fptoui float %v to i64
+ ret i32 %v32
+}
+
+; CHECK-NEXT: define i32 @FptouiFloat(float %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = fptoui float %__0 to i1
+; CHECK-NEXT: %__2 = fptoui float %__0 to i8
+; CHECK-NEXT: %__3 = fptoui float %__0 to i16
+; CHECK-NEXT: %__4 = fptoui float %__0 to i32
+; CHECK-NEXT: %__5 = fptoui float %__0 to i64
+; CHECK-NEXT: ret i32 %__4
+; CHECK-NEXT: }
+
+define i32 @FptouiDouble(double %v) {
+ %v1 = fptoui double %v to i1
+ %v8 = fptoui double %v to i8
+ %v16 = fptoui double %v to i16
+ %v32 = fptoui double %v to i32
+ %v64 = fptoui double %v to i64
+ ret i32 %v32
+}
+
+; CHECK-NEXT: define i32 @FptouiDouble(double %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = fptoui double %__0 to i1
+; CHECK-NEXT: %__2 = fptoui double %__0 to i8
+; CHECK-NEXT: %__3 = fptoui double %__0 to i16
+; CHECK-NEXT: %__4 = fptoui double %__0 to i32
+; CHECK-NEXT: %__5 = fptoui double %__0 to i64
+; CHECK-NEXT: ret i32 %__4
+; CHECK-NEXT: }
+
+define i32 @FptosiFloat(float %v) {
+ %v1 = fptosi float %v to i1
+ %v8 = fptosi float %v to i8
+ %v16 = fptosi float %v to i16
+ %v32 = fptosi float %v to i32
+ %v64 = fptosi float %v to i64
+ ret i32 %v32
+}
+
+; CHECK-NEXT: define i32 @FptosiFloat(float %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = fptosi float %__0 to i1
+; CHECK-NEXT: %__2 = fptosi float %__0 to i8
+; CHECK-NEXT: %__3 = fptosi float %__0 to i16
+; CHECK-NEXT: %__4 = fptosi float %__0 to i32
+; CHECK-NEXT: %__5 = fptosi float %__0 to i64
+; CHECK-NEXT: ret i32 %__4
+; CHECK-NEXT: }
+
+define i32 @FptosiDouble(double %v) {
+ %v1 = fptosi double %v to i1
+ %v8 = fptosi double %v to i8
+ %v16 = fptosi double %v to i16
+ %v32 = fptosi double %v to i32
+ %v64 = fptosi double %v to i64
+ ret i32 %v32
+}
+
+; CHECK-NEXT: define i32 @FptosiDouble(double %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = fptosi double %__0 to i1
+; CHECK-NEXT: %__2 = fptosi double %__0 to i8
+; CHECK-NEXT: %__3 = fptosi double %__0 to i16
+; CHECK-NEXT: %__4 = fptosi double %__0 to i32
+; CHECK-NEXT: %__5 = fptosi double %__0 to i64
+; CHECK-NEXT: ret i32 %__4
+; CHECK-NEXT: }
+
+define float @UitofpI1(i32 %p) {
+ %v = trunc i32 %p to i1
+ %vfloat = uitofp i1 %v to float
+ %vdouble = uitofp i1 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @UitofpI1(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i1
+; CHECK-NEXT: %__2 = uitofp i1 %__1 to float
+; CHECK-NEXT: %__3 = uitofp i1 %__1 to double
+; CHECK-NEXT: ret float %__2
+; CHECK-NEXT: }
+
+define float @UitofpI8(i32 %p) {
+ %v = trunc i32 %p to i8
+ %vfloat = uitofp i8 %v to float
+ %vdouble = uitofp i8 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @UitofpI8(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i8
+; CHECK-NEXT: %__2 = uitofp i8 %__1 to float
+; CHECK-NEXT: %__3 = uitofp i8 %__1 to double
+; CHECK-NEXT: ret float %__2
+; CHECK-NEXT: }
+
+define float @UitofpI16(i32 %p) {
+ %v = trunc i32 %p to i16
+ %vfloat = uitofp i16 %v to float
+ %vdouble = uitofp i16 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @UitofpI16(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i16
+; CHECK-NEXT: %__2 = uitofp i16 %__1 to float
+; CHECK-NEXT: %__3 = uitofp i16 %__1 to double
+; CHECK-NEXT: ret float %__2
+; CHECK-NEXT: }
+
+define float @UitofpI32(i32 %v) {
+ %vfloat = uitofp i32 %v to float
+ %vdouble = uitofp i32 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @UitofpI32(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = uitofp i32 %__0 to float
+; CHECK-NEXT: %__2 = uitofp i32 %__0 to double
+; CHECK-NEXT: ret float %__1
+; CHECK-NEXT: }
+
+define float @UitofpI64(i64 %v) {
+ %vfloat = uitofp i64 %v to float
+ %vdouble = uitofp i64 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @UitofpI64(i64 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = uitofp i64 %__0 to float
+; CHECK-NEXT: %__2 = uitofp i64 %__0 to double
+; CHECK-NEXT: ret float %__1
+; CHECK-NEXT: }
+
+define float @SitofpI1(i32 %p) {
+ %v = trunc i32 %p to i1
+ %vfloat = sitofp i1 %v to float
+ %vdouble = sitofp i1 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @SitofpI1(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i1
+; CHECK-NEXT: %__2 = sitofp i1 %__1 to float
+; CHECK-NEXT: %__3 = sitofp i1 %__1 to double
+; CHECK-NEXT: ret float %__2
+; CHECK-NEXT: }
+
+define float @SitofpI8(i32 %p) {
+ %v = trunc i32 %p to i8
+ %vfloat = sitofp i8 %v to float
+ %vdouble = sitofp i8 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @SitofpI8(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i8
+; CHECK-NEXT: %__2 = sitofp i8 %__1 to float
+; CHECK-NEXT: %__3 = sitofp i8 %__1 to double
+; CHECK-NEXT: ret float %__2
+; CHECK-NEXT: }
+
+define float @SitofpI16(i32 %p) {
+ %v = trunc i32 %p to i16
+ %vfloat = sitofp i16 %v to float
+ %vdouble = sitofp i16 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @SitofpI16(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = trunc i32 %__0 to i16
+; CHECK-NEXT: %__2 = sitofp i16 %__1 to float
+; CHECK-NEXT: %__3 = sitofp i16 %__1 to double
+; CHECK-NEXT: ret float %__2
+; CHECK-NEXT: }
+
+define float @SitofpI32(i32 %v) {
+ %vfloat = sitofp i32 %v to float
+ %vdouble = sitofp i32 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @SitofpI32(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = sitofp i32 %__0 to float
+; CHECK-NEXT: %__2 = sitofp i32 %__0 to double
+; CHECK-NEXT: ret float %__1
+; CHECK-NEXT: }
+
+define float @SitofpI64(i64 %v) {
+ %vfloat = sitofp i64 %v to float
+ %vdouble = sitofp i64 %v to double
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @SitofpI64(i64 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = sitofp i64 %__0 to float
+; CHECK-NEXT: %__2 = sitofp i64 %__0 to double
+; CHECK-NEXT: ret float %__1
+; CHECK-NEXT: }
+
+define float @BitcastI32(i32 %v) {
+ %vfloat = bitcast i32 %v to float
+ ret float %vfloat
+}
+
+; CHECK-NEXT: define float @BitcastI32(i32 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast i32 %__0 to float
+; CHECK-NEXT: ret float %__1
+; CHECK-NEXT: }
+
+define double @BitcastI64(i64 %v) {
+ %vdouble = bitcast i64 %v to double
+ ret double %vdouble
+}
+
+; CHECK-NEXT: define double @BitcastI64(i64 %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast i64 %__0 to double
+; CHECK-NEXT: ret double %__1
+; CHECK-NEXT: }
+
+define i32 @BitcastFloat(float %v) {
+ %vi32 = bitcast float %v to i32
+ ret i32 %vi32
+}
+
+; CHECK-NEXT: define i32 @BitcastFloat(float %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast float %__0 to i32
+; CHECK-NEXT: ret i32 %__1
+; CHECK-NEXT: }
+
+define i64 @BitcastDouble(double %v) {
+ %vi64 = bitcast double %v to i64
+ ret i64 %vi64
+}
+
+; CHECK-NEXT: define i64 @BitcastDouble(double %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast double %__0 to i64
+; CHECK-NEXT: ret i64 %__1
+; CHECK-NEXT: }
+
+define void @BitcastV4xFloat(<4 x float> %v) {
+ %v4xi32 = bitcast <4 x float> %v to <4 x i32>
+ %v8xi16 = bitcast <4 x float> %v to <8 x i16>
+ %v16xi8 = bitcast <4 x float> %v to <16 x i8>
+ ret void
+}
+
+; CHECK-NEXT: define void @BitcastV4xFloat(<4 x float> %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast <4 x float> %__0 to <4 x i32>
+; CHECK-NEXT: %__2 = bitcast <4 x float> %__0 to <8 x i16>
+; CHECK-NEXT: %__3 = bitcast <4 x float> %__0 to <16 x i8>
+; CHECK-NEXT: ret void
+; CHECK-NEXT: }
+
+define void @BitcastV4xi32(<4 x i32> %v) {
+ %v4xfloat = bitcast <4 x i32> %v to <4 x float>
+ %v8xi16 = bitcast <4 x i32> %v to <8 x i16>
+ %v16xi8 = bitcast <4 x i32> %v to <16 x i8>
+ ret void
+}
+
+; CHECK-NEXT: define void @BitcastV4xi32(<4 x i32> %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast <4 x i32> %__0 to <4 x float>
+; CHECK-NEXT: %__2 = bitcast <4 x i32> %__0 to <8 x i16>
+; CHECK-NEXT: %__3 = bitcast <4 x i32> %__0 to <16 x i8>
+; CHECK-NEXT: ret void
+; CHECK-NEXT: }
+
+define void @BitcastV4xi16(<8 x i16> %v) {
+ %v4xfloat = bitcast <8 x i16> %v to <4 x float>
+ %v4xi32 = bitcast <8 x i16> %v to <4 x i32>
+ %v16xi8 = bitcast <8 x i16> %v to <16 x i8>
+ ret void
+}
+
+; CHECK-NEXT: define void @BitcastV4xi16(<8 x i16> %__0) {
jvoung (off chromium) 2014/08/29 17:26:34 Function name should be V8xi16 ?
Karl 2014/09/02 17:47:57 Done.
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast <8 x i16> %__0 to <4 x float>
+; CHECK-NEXT: %__2 = bitcast <8 x i16> %__0 to <4 x i32>
+; CHECK-NEXT: %__3 = bitcast <8 x i16> %__0 to <16 x i8>
+; CHECK-NEXT: ret void
+; CHECK-NEXT: }
+
+define void @BitcastV16xi8(<16 x i8> %v) {
+ %v4xfloat = bitcast <16 x i8> %v to <4 x float>
+ %v4xi32 = bitcast <16 x i8> %v to <4 x i32>
+ %v8xi16 = bitcast <16 x i8> %v to <8 x i16>
+ ret void
+}
+
+; CHECK-NEXT: define void @BitcastV16xi8(<16 x i8> %__0) {
+; CHECK-NEXT: __0:
+; CHECK-NEXT: %__1 = bitcast <16 x i8> %__0 to <4 x float>
+; CHECK-NEXT: %__2 = bitcast <16 x i8> %__0 to <4 x i32>
+; CHECK-NEXT: %__3 = bitcast <16 x i8> %__0 to <8 x i16>
+; CHECK-NEXT: ret void
+; CHECK-NEXT: }
« no previous file with comments | « src/PNaClTranslator.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698