diff options
-rw-r--r-- | gcc/objc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/objc/objc-act.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/objc.dg/encode-9.m | 13 |
4 files changed, 29 insertions, 3 deletions
diff --git a/gcc/objc/ChangeLog b/gcc/objc/ChangeLog index f2a6fd6..5f7951f 100644 --- a/gcc/objc/ChangeLog +++ b/gcc/objc/ChangeLog @@ -1,3 +1,8 @@ +2005-12-12 Andrew Pinski <pinskia@physics.uc.edu> + + PR objc/25348 + * objc-act.c (encode_array): Handle arrays to zero sized types. + 2005-12-07 Rafael Ávila de Espíndola <rafael.espindola@gmail.com> * Make-lang.in (objc.all.build, objc.install-normal): Remove. diff --git a/gcc/objc/objc-act.c b/gcc/objc/objc-act.c index 817553a..201a722 100644 --- a/gcc/objc/objc-act.c +++ b/gcc/objc/objc-act.c @@ -7920,9 +7920,12 @@ encode_array (tree type, int curtype, int format) return; } - sprintf (buffer, "[" HOST_WIDE_INT_PRINT_DEC, - (TREE_INT_CST_LOW (an_int_cst) - / TREE_INT_CST_LOW (TYPE_SIZE (array_of)))); + if (TREE_INT_CST_LOW (TYPE_SIZE (array_of)) == 0) + sprintf (buffer, "[" HOST_WIDE_INT_PRINT_DEC, (HOST_WIDE_INT)0); + else + sprintf (buffer, "[" HOST_WIDE_INT_PRINT_DEC, + TREE_INT_CST_LOW (an_int_cst) + / TREE_INT_CST_LOW (TYPE_SIZE (array_of))); obstack_grow (&util_obstack, buffer, strlen (buffer)); encode_type (array_of, curtype, format); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 208450a..8617acc 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-12-12 Andrew Pinski <pinskia@physics.uc.edu> + + PR objc/25348 + * objc.dg/encode-9.m: New test. + 2005-12-12 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> PR testsuite/20772 diff --git a/gcc/testsuite/objc.dg/encode-9.m b/gcc/testsuite/objc.dg/encode-9.m new file mode 100644 index 0000000..3b00575 --- /dev/null +++ b/gcc/testsuite/objc.dg/encode-9.m @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-options "-fgnu-runtime " } */ + +/* There was an ICE due to diving by zero in the objc front-end. */ + +struct f +{ + int i; + struct{} g[4]; + int tt; +}; + +char *e = @encode(struct f); |