From: Richard Kenner Date: Fri, 18 Apr 2003 22:27:18 +0000 (+0000) Subject: * expmed.c (mask_rtx): Avoid undefined shifts for BITSIZE of 0. X-Git-Tag: releases/gcc-3.4.0~7179 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=21102f257e4fc2ddf71eaa26806b4adb133ff5ad;p=thirdparty%2Fgcc.git * expmed.c (mask_rtx): Avoid undefined shifts for BITSIZE of 0. From-SVN: r65796 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 0847ad9610dd..3df6d2ccb323 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2003-04-18 Richard Kenner + + * expmed.c (mask_rtx): Avoid undefined shifts for BITSIZE of 0. + 2003-04-18 Olivier Hainque * calls.c (expand_call): Move special case for constructor calls diff --git a/gcc/expmed.c b/gcc/expmed.c index 33d815280bf0..b48576bfc781 100644 --- a/gcc/expmed.c +++ b/gcc/expmed.c @@ -1698,7 +1698,9 @@ mask_rtx (mode, bitpos, bitsize, complement) { HOST_WIDE_INT masklow, maskhigh; - if (bitpos < HOST_BITS_PER_WIDE_INT) + if (bitsize == 0) + masklow = 0; + else if (bitpos < HOST_BITS_PER_WIDE_INT) masklow = (HOST_WIDE_INT) -1 << bitpos; else masklow = 0; @@ -1712,7 +1714,9 @@ mask_rtx (mode, bitpos, bitsize, complement) else maskhigh = (HOST_WIDE_INT) -1 << (bitpos - HOST_BITS_PER_WIDE_INT); - if (bitpos + bitsize > HOST_BITS_PER_WIDE_INT) + if (bitsize == 0) + maskhigh = 0; + else if (bitpos + bitsize > HOST_BITS_PER_WIDE_INT) maskhigh &= ((unsigned HOST_WIDE_INT) -1 >> (2 * HOST_BITS_PER_WIDE_INT - bitpos - bitsize)); else