[Mono-bugs] [Bug 82756][Nor] New - useless instructions generated for struct field init

bugzilla-daemon at bugzilla.ximian.com bugzilla-daemon at bugzilla.ximian.com
Sat Sep 8 13:55:16 EDT 2007


Please do not reply to this email- if you want to comment on the bug, go to the
URL shown below and enter your comments there.

Changed by lupus at ximian.com.

http://bugzilla.ximian.com/show_bug.cgi?id=82756

--- shadow/82756	2007-09-08 13:55:16.000000000 -0400
+++ shadow/82756.tmp.18142	2007-09-08 13:55:16.000000000 -0400
@@ -0,0 +1,54 @@
+Bug#: 82756
+Product: Mono: Compilers
+Version: 1.2
+OS: 
+OS Details: 
+Status: NEW   
+Resolution: 
+Severity: 
+Priority: Normal
+Component: C#
+AssignedTo: rharinath at novell.com                            
+ReportedBy: lupus at ximian.com               
+QAContact: mono-bugs at ximian.com
+TargetMilestone: ---
+URL: 
+Cc: 
+Summary: useless instructions generated for struct field init
+
+mcs generate useless code when initing a struct in a field, either instance
+or static. Basically, given the struct D, for a D field initialized with:
+
+  d_field = new D ();
+
+It will emit the code:
+
+  d_field = new D ()
+  d_field =  d_field;
+
+This just inflates the IL code for no reason and pessimizes the code a lot,
+especially for instance fields (because it loads the this object reference
+across method calls...).
+
+A simple test program follows, check with monodis the presence of the
+useless instructions.
+
+struct D {
+
+	readonly static D d1 = new D (1);
+	static D d2 = new D (2);
+
+	int val;
+
+	public D (int v) {
+		val = v;
+	}
+	static void Main () {
+		D d = new D (5);
+		T t = new T ();
+	}
+}
+
+class T {
+	D d = new D (3);
+}


More information about the mono-bugs mailing list