This is the mail archive of the mailing list for the GCC project.

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: expanding addrs for initializers

> In the same department as unchecked conversions, we have unchecked unions in 
> Ada, so we again need a bit more leeway.  I've applied the following patch.

I think this patch is better :-(

It seems a lot of code assumes that a no-op convert of a different
size "just works" by the time it gets to this function, although it
clearly does NOT work for m32c because of the blind padding problem.
I recall having reservations about this part of the patch before, it
seems they were justfied.

So, rather than add exception after exception, let's just drop the
check and go back to the way it was before.

	* varasm.c (output_constant): Allow size-changing no-op
	conversions again.

Index: varasm.c
RCS file: /cvs/gcc/gcc/gcc/varasm.c,v
retrieving revision 1.529
diff -p -U3 -r1.529 varasm.c
--- varasm.c	18 Sep 2005 17:11:11 -0000	1.529
+++ varasm.c	19 Sep 2005 19:58:14 -0000
@@ -3880,15 +3880,6 @@ output_constant (tree exp, unsigned HOST
       HOST_WIDE_INT type_size = int_size_in_bytes (TREE_TYPE (exp));
       HOST_WIDE_INT op_size = int_size_in_bytes (TREE_TYPE (TREE_OPERAND (exp, 0)));
-      /* Make sure eliminating the conversion is really a no-op, except with
-	 VIEW_CONVERT_EXPRs to allow for wild Ada unchecked conversions and
-	 union types to allow for Ada unchecked unions.  */
-      if (type_size != op_size
-	internal_error ("no-op convert from %wd to %wd bytes in initializer",
-			op_size, type_size);
       exp = TREE_OPERAND (exp, 0);

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]