summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Lenharth <andrewl@lenharth.org>2006-03-27 23:38:48 +0000
committerAndrew Lenharth <andrewl@lenharth.org>2006-03-27 23:38:48 +0000
commit4a89e2e9ec087a17c6952ec7011456c6daad80da (patch)
treecf70927a10fac071bbb9e648dd34dbe4dd655367
parentd387cc5cde2512be877f75cbef90b7dc8822645c (diff)
downloadbcm5719-llvm-4a89e2e9ec087a17c6952ec7011456c6daad80da.tar.gz
bcm5719-llvm-4a89e2e9ec087a17c6952ec7011456c6daad80da.zip
Adding links to a node collapsed during type merging crashes.
llvm-svn: 27193
-rw-r--r--llvm/test/Regression/Analysis/DSGraph/2006-03-27-LinkedCollapsed.ll26
1 files changed, 26 insertions, 0 deletions
diff --git a/llvm/test/Regression/Analysis/DSGraph/2006-03-27-LinkedCollapsed.ll b/llvm/test/Regression/Analysis/DSGraph/2006-03-27-LinkedCollapsed.ll
new file mode 100644
index 00000000000..06af9063233
--- /dev/null
+++ b/llvm/test/Regression/Analysis/DSGraph/2006-03-27-LinkedCollapsed.ll
@@ -0,0 +1,26 @@
+; RUN: llvm-as < %s | analyze -datastructure
+
+target endian = little
+target pointersize = 32
+target triple = "i686-pc-linux-gnu"
+deplibs = [ "c", "crtend", "stdc++" ]
+ %struct.Blend_Map_Entry = type { float, ubyte, { [2 x double], [4 x ubyte] } }
+ %struct.Blend_Map_Struct = type { short, short, short, int, %struct.Blend_Map_Entry* }
+ %struct.Image_Colour_Struct = type { ushort, ushort, ushort, ushort, ushort }
+ %struct.Image_Struct = type { int, int, int, int, int, short, short, [3 x double], float, float, int, int, short, %struct.Image_Colour_Struct*, { ubyte** } }
+ %struct.Pattern_Struct = type { ushort, ushort, ushort, int, float, float, float, %struct.Warps_Struct*, %struct.Pattern_Struct*, %struct.Blend_Map_Struct*, { [3 x double], [4 x ubyte] } }
+ %struct.Tnormal_Struct = type { ushort, ushort, ushort, int, float, float, float, %struct.Warps_Struct*, %struct.Pattern_Struct*, %struct.Blend_Map_Struct*, { [3 x double], [4 x ubyte] }, float }
+ %struct.Warps_Struct = type { ushort, %struct.Warps_Struct* }
+
+implementation ; Functions:
+
+declare fastcc %struct.Image_Struct* %Parse_Image()
+
+fastcc void %Parse_Bump_Map(%struct.Tnormal_Struct* %Tnormal) {
+entry:
+ %tmp.0 = tail call fastcc %struct.Image_Struct* %Parse_Image( ) ; <%struct.Image_Struct*> [#uses=1]
+ %tmp.28 = getelementptr %struct.Tnormal_Struct* %Tnormal, int 0, uint 10 ; <{ [3 x double], [4 x ubyte] }*> [#uses=1]
+ %tmp.32 = cast { [3 x double], [4 x ubyte] }* %tmp.28 to %struct.Image_Struct** ; <%struct.Image_Struct**> [#uses=1]
+ store %struct.Image_Struct* %tmp.0, %struct.Image_Struct** %tmp.32
+ ret void
+}
OpenPOWER on IntegriCloud