提交 b21a9104 编写于 作者: R roel kluin 提交者: Paul Mundt

sh: intc_prio_data() test before subtraction on unsigned

bit is unsigned, so test before subtraction
Signed-off-by: NRoel Kluin <roel.kluin@gmail.com>
Signed-off-by: NPaul Mundt <lethal@linux-sh.org>
上级 6eb2139b
...@@ -464,9 +464,10 @@ static unsigned int __init intc_prio_data(struct intc_desc *desc, ...@@ -464,9 +464,10 @@ static unsigned int __init intc_prio_data(struct intc_desc *desc,
} }
fn += (pr->reg_width >> 3) - 1; fn += (pr->reg_width >> 3) - 1;
bit = pr->reg_width - ((j + 1) * pr->field_width);
BUG_ON(bit < 0); BUG_ON((j + 1) * pr->field_width > pr->reg_width);
bit = pr->reg_width - ((j + 1) * pr->field_width);
return _INTC_MK(fn, mode, return _INTC_MK(fn, mode,
intc_get_reg(d, reg_e), intc_get_reg(d, reg_e),
...@@ -531,9 +532,10 @@ static unsigned int __init intc_sense_data(struct intc_desc *desc, ...@@ -531,9 +532,10 @@ static unsigned int __init intc_sense_data(struct intc_desc *desc,
fn = REG_FN_MODIFY_BASE; fn = REG_FN_MODIFY_BASE;
fn += (sr->reg_width >> 3) - 1; fn += (sr->reg_width >> 3) - 1;
bit = sr->reg_width - ((j + 1) * sr->field_width);
BUG_ON(bit < 0); BUG_ON((j + 1) * sr->field_width > sr->reg_width);
bit = sr->reg_width - ((j + 1) * sr->field_width);
return _INTC_MK(fn, 0, intc_get_reg(d, sr->reg), return _INTC_MK(fn, 0, intc_get_reg(d, sr->reg),
0, sr->field_width, bit); 0, sr->field_width, bit);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册