better way of fixing shift of 1 by 64-bit to avoid integer overflow

This commit is contained in:
Stanislav Shwartsman 2017-04-17 20:38:18 +00:00
parent 7f2191c117
commit 2cae01edea

View File

@ -258,7 +258,7 @@ void bx_hpet_c::update_irq(HPETTimer *timer, bx_bool set)
} else { } else {
route = timer_int_route(timer); route = timer_int_route(timer);
} }
mask = (Bit64u)(1 << timer->tn); mask = (BX_CONST64(1) << timer->tn);
if (!set || !timer_enabled(timer) || !hpet_enabled()) { if (!set || !timer_enabled(timer) || !hpet_enabled()) {
s.isr &= ~mask; s.isr &= ~mask;
if (!timer_fsb_route(timer)) { if (!timer_fsb_route(timer)) {
@ -464,7 +464,7 @@ void bx_hpet_c::write_aligned(bx_phy_address address, Bit32u value)
case HPET_STATUS: case HPET_STATUS:
val = new_val & s.isr; val = new_val & s.isr;
for (i = 0; i < s.num_timers; i++) { for (i = 0; i < s.num_timers; i++) {
if (val & (Bit64u)(1 << i)) { if (val & (BX_CONST64(1) << i)) {
update_irq(&s.timer[i], 0); update_irq(&s.timer[i], 0);
} }
} }