diff options
| author | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2020-08-06 00:07:49 +0200 |
|---|---|---|
| committer | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2020-08-06 18:30:44 +0200 |
| commit | c2a5bd264187f42564b7055bce4cf72a7985cbc5 (patch) | |
| tree | b055e335373510a6ff76e974727d44b433718113 /evaluate.c | |
| parent | f01f79df0512ef16dc1ae681edf75e6924a8cf2e (diff) | |
| download | sparse-dev-c2a5bd264187f42564b7055bce4cf72a7985cbc5.tar.gz | |
shift-assign: restrict shift count to unsigned int
After the RHS of shift-assigns had been integer-promoted,
both gcc & clang seems to restrict it to an unsigned int.
This only make a difference when the shift count is negative
and would it make it UB.
Better to have the same generated code, so make the same here.
Signed-off-by: Luc Van Oostenryck <luc.vanoostenryck@gmail.com>
Diffstat (limited to 'evaluate.c')
| -rw-r--r-- | evaluate.c | 5 |
1 files changed, 5 insertions, 0 deletions
@@ -1348,6 +1348,11 @@ static int evaluate_assign_op(struct expression *expr) unrestrict(expr->right, sclass, &s); source = integer_promotion(s); expr->right = cast_to(expr->right, source); + + // both gcc & clang seems to do this, so ... + if (target->bit_size > source->bit_size) + expr->right = cast_to(expr->right, &uint_ctype); + goto Cast; } else if (!(sclass & TYPE_RESTRICT)) goto usual; |
