mirror of
https://github.com/TomHarte/CLK.git
synced 2024-11-22 12:33:29 +00:00
Ensure did_divu/s are performed even upon divide by zero.
This commit is contained in:
parent
7788a109b0
commit
8ffaf1a8e4
@ -522,17 +522,18 @@ template <
|
||||
#define DIV(Type16, Type32, flow_function) { \
|
||||
status.carry_flag = 0; \
|
||||
\
|
||||
const auto dividend = Type32(dest.l); \
|
||||
const auto divisor = Type32(Type16(src.w)); \
|
||||
\
|
||||
if(!divisor) { \
|
||||
status.negative_flag = status.overflow_flag = 0; \
|
||||
status.zero_result = 1; \
|
||||
flow_controller.raise_exception(Exception::IntegerDivideByZero); \
|
||||
flow_controller.template flow_function<false>(dividend, divisor); \
|
||||
return; \
|
||||
} \
|
||||
\
|
||||
const auto dividend = Type32(dest.l); \
|
||||
const auto quotient = dividend / divisor; \
|
||||
\
|
||||
if(quotient != Type32(Type16(quotient))) { \
|
||||
status.overflow_flag = 1; \
|
||||
flow_controller.template flow_function<true>(dividend, divisor); \
|
||||
|
Loading…
Reference in New Issue
Block a user