2 * Copyright (C) 2014 Oracle.
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; either version 2
7 * of the License, or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, see http://www.gnu.org/copyleft/gpl.txt
22 static void match_binop(struct expression
*expr
)
27 if (expr
->op
!= SPECIAL_RIGHTSHIFT
)
30 if (!get_implied_value(expr
->right
, &bits
))
33 type
= get_type(expr
->left
);
36 if (type_bits(type
) > bits
.value
)
38 sm_msg("warn: right shifting more than type allows");
41 static void match_binop2(struct expression
*expr
)
43 struct expression
*left
;
44 struct expression
*tmp
;
47 if (expr
->op
!= SPECIAL_RIGHTSHIFT
)
50 left
= strip_expr(expr
->left
);
51 tmp
= get_assigned_expr(left
);
54 if (left
->type
!= EXPR_BINOP
|| left
->op
!= '&')
57 if (!get_implied_value(expr
->right
, &shift
))
59 if (!get_implied_value(left
->right
, &mask
))
62 if ((unsigned long long)-1 & mask
.uvalue
>> shift
.uvalue
)
65 sm_msg("warn: mask and shift to zero");
68 static void match_assign(struct expression
*expr
)
73 if (expr
->op
!= SPECIAL_SHR_ASSIGN
)
76 if (!get_implied_value(expr
->right
, &bits
))
78 type
= get_type(expr
->left
);
81 if (type_bits(type
) > bits
.value
)
83 sm_msg("warn: right shift assign to zero");
86 void check_shift_to_zero(int id
)
90 add_hook(&match_binop
, BINOP_HOOK
);
91 add_hook(&match_binop2
, BINOP_HOOK
);
93 add_hook(&match_assign
, ASSIGNMENT_HOOK
);