]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c-common.c (c_common_type_for_mode): Pass the mode's precision to make_[un]signed_typ...
authorDJ Delorie <dj@redhat.com>
Tue, 22 Feb 2005 20:10:45 +0000 (15:10 -0500)
committerDJ Delorie <dj@gcc.gnu.org>
Tue, 22 Feb 2005 20:10:45 +0000 (15:10 -0500)
* c-common.c (c_common_type_for_mode): Pass the mode's precision
to make_[un]signed_type, not the mode itself.

From-SVN: r95412

gcc/ChangeLog
gcc/c-common.c

index 266ce0d190d9f4f3f82285f8bb27f660dbdc8463..5af7fb69356bfa12e29ffe2a62b57a0ac07a8780 100644 (file)
@@ -1,3 +1,8 @@
+2005-02-22  DJ Delorie  <dj@redhat.com>
+
+       * c-common.c (c_common_type_for_mode): Pass the mode's precision
+       to make_[un]signed_type, not the mode itself.
+
 2005-02-22  Kazu Hirata  <kazu@cs.umass.edu>
 
        * cfg.c (cached_make_edge): Call make_edge if edge cache is
index a4dfdd84136bd3370ca6faf4d1dcc337f2d4f2f6..39868e886592d82b0fa1f041800b448f19b362cb 100644 (file)
@@ -1606,10 +1606,14 @@ c_common_type_for_mode (enum machine_mode mode, int unsignedp)
     return void_type_node;
 
   if (mode == TYPE_MODE (build_pointer_type (char_type_node)))
-    return unsignedp ? make_unsigned_type (mode) : make_signed_type (mode);
+    return (unsignedp
+           ? make_unsigned_type (GET_MODE_PRECISION (mode))
+           : make_signed_type (GET_MODE_PRECISION (mode)));
 
   if (mode == TYPE_MODE (build_pointer_type (integer_type_node)))
-    return unsignedp ? make_unsigned_type (mode) : make_signed_type (mode);
+    return (unsignedp
+           ? make_unsigned_type (GET_MODE_PRECISION (mode))
+           : make_signed_type (GET_MODE_PRECISION (mode)));
 
   if (COMPLEX_MODE_P (mode))
     {