mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-13 22:32:03 +00:00
Resolves a further 11 conversion errors.
This commit is contained in:
parent
5b21da7874
commit
51ee83a427
@ -960,7 +960,7 @@ template <class T, bool dtack_is_implicit, bool signal_will_perform> void Proces
|
|||||||
|
|
||||||
const uint16_t remainder = uint16_t(dividend % divisor);
|
const uint16_t remainder = uint16_t(dividend % divisor);
|
||||||
active_program_->destination->halves.high.full = remainder;
|
active_program_->destination->halves.high.full = remainder;
|
||||||
active_program_->destination->halves.low.full = quotient;
|
active_program_->destination->halves.low.full = uint16_t(quotient);
|
||||||
|
|
||||||
overflow_flag_ = 0;
|
overflow_flag_ = 0;
|
||||||
zero_result_ = quotient;
|
zero_result_ = quotient;
|
||||||
@ -1020,14 +1020,14 @@ template <class T, bool dtack_is_implicit, bool signal_will_perform> void Proces
|
|||||||
}
|
}
|
||||||
|
|
||||||
overflow_flag_ = 0;
|
overflow_flag_ = 0;
|
||||||
zero_result_ = quotient;
|
zero_result_ = decltype(zero_result_)(quotient);
|
||||||
negative_flag_ = zero_result_ & 0x8000;
|
negative_flag_ = zero_result_ & 0x8000;
|
||||||
|
|
||||||
// TODO: check sign rules here; am I necessarily giving the remainder the correct sign?
|
// TODO: check sign rules here; am I necessarily giving the remainder the correct sign?
|
||||||
// (and, if not, am I counting it in the correct direction?)
|
// (and, if not, am I counting it in the correct direction?)
|
||||||
const uint16_t remainder = uint16_t(dividend % divisor);
|
const uint16_t remainder = uint16_t(dividend % divisor);
|
||||||
active_program_->destination->halves.high.full = remainder;
|
active_program_->destination->halves.high.full = remainder;
|
||||||
active_program_->destination->halves.low.full = quotient;
|
active_program_->destination->halves.low.full = uint16_t(quotient);
|
||||||
|
|
||||||
// Algorithm here: there is a fixed three-microcycle cost per bit set
|
// Algorithm here: there is a fixed three-microcycle cost per bit set
|
||||||
// in the unsigned quotient; there is an additional microcycle for
|
// in the unsigned quotient; there is an additional microcycle for
|
||||||
@ -1287,10 +1287,10 @@ template <class T, bool dtack_is_implicit, bool signal_will_perform> void Proces
|
|||||||
const int destination = 0;
|
const int destination = 0;
|
||||||
const int source = active_program_->destination->halves.low.halves.low;
|
const int source = active_program_->destination->halves.low.halves.low;
|
||||||
const auto result = destination - source;
|
const auto result = destination - source;
|
||||||
active_program_->destination->halves.low.halves.low = result;
|
active_program_->destination->halves.low.halves.low = uint8_t(result);
|
||||||
|
|
||||||
zero_result_ = result & 0xff;
|
zero_result_ = result & 0xff;
|
||||||
extend_flag_ = carry_flag_ = result & ~0xff;
|
extend_flag_ = carry_flag_ = decltype(carry_flag_)(result & ~0xff);
|
||||||
negative_flag_ = result & 0x80;
|
negative_flag_ = result & 0x80;
|
||||||
overflow_flag_ = sub_overflow() & 0x80;
|
overflow_flag_ = sub_overflow() & 0x80;
|
||||||
} break;
|
} break;
|
||||||
@ -1299,10 +1299,10 @@ template <class T, bool dtack_is_implicit, bool signal_will_perform> void Proces
|
|||||||
const int destination = 0;
|
const int destination = 0;
|
||||||
const int source = active_program_->destination->halves.low.full;
|
const int source = active_program_->destination->halves.low.full;
|
||||||
const auto result = destination - source;
|
const auto result = destination - source;
|
||||||
active_program_->destination->halves.low.full = result;
|
active_program_->destination->halves.low.full = uint16_t(result);
|
||||||
|
|
||||||
zero_result_ = result & 0xffff;
|
zero_result_ = result & 0xffff;
|
||||||
extend_flag_ = carry_flag_ = result & ~0xffff;
|
extend_flag_ = carry_flag_ = decltype(carry_flag_)(result & ~0xffff);
|
||||||
negative_flag_ = result & 0x8000;
|
negative_flag_ = result & 0x8000;
|
||||||
overflow_flag_ = sub_overflow() & 0x8000;
|
overflow_flag_ = sub_overflow() & 0x8000;
|
||||||
} break;
|
} break;
|
||||||
@ -1326,10 +1326,10 @@ template <class T, bool dtack_is_implicit, bool signal_will_perform> void Proces
|
|||||||
const int source = active_program_->destination->halves.low.halves.low;
|
const int source = active_program_->destination->halves.low.halves.low;
|
||||||
const int destination = 0;
|
const int destination = 0;
|
||||||
const auto result = destination - source - (extend_flag_ ? 1 : 0);
|
const auto result = destination - source - (extend_flag_ ? 1 : 0);
|
||||||
active_program_->destination->halves.low.halves.low = result;
|
active_program_->destination->halves.low.halves.low = uint8_t(result);
|
||||||
|
|
||||||
zero_result_ = result & 0xff;
|
zero_result_ = result & 0xff;
|
||||||
extend_flag_ = carry_flag_ = result & ~0xff;
|
extend_flag_ = carry_flag_ = decltype(carry_flag_)(result & ~0xff);
|
||||||
negative_flag_ = result & 0x80;
|
negative_flag_ = result & 0x80;
|
||||||
overflow_flag_ = sub_overflow() & 0x80;
|
overflow_flag_ = sub_overflow() & 0x80;
|
||||||
} break;
|
} break;
|
||||||
@ -1338,10 +1338,10 @@ template <class T, bool dtack_is_implicit, bool signal_will_perform> void Proces
|
|||||||
const int source = active_program_->destination->halves.low.full;
|
const int source = active_program_->destination->halves.low.full;
|
||||||
const int destination = 0;
|
const int destination = 0;
|
||||||
const auto result = destination - source - (extend_flag_ ? 1 : 0);
|
const auto result = destination - source - (extend_flag_ ? 1 : 0);
|
||||||
active_program_->destination->halves.low.full = result;
|
active_program_->destination->halves.low.full = uint16_t(result);
|
||||||
|
|
||||||
zero_result_ = result & 0xffff;
|
zero_result_ = result & 0xffff;
|
||||||
extend_flag_ = carry_flag_ = result & ~0xffff;
|
extend_flag_ = carry_flag_ = decltype(carry_flag_)(result & ~0xffff);
|
||||||
negative_flag_ = result & 0x8000;
|
negative_flag_ = result & 0x8000;
|
||||||
overflow_flag_ = sub_overflow() & 0x8000;
|
overflow_flag_ = sub_overflow() & 0x8000;
|
||||||
} break;
|
} break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user