mirror of
https://github.com/TomHarte/CLK.git
synced 2024-11-22 12:33:29 +00:00
Eliminate hard-coded assumption of 16kb.
Clearly I'll have to do something else to support 128k+, probably move the ram pointer?
This commit is contained in:
parent
9085ba4081
commit
4d96122884
@ -360,10 +360,10 @@ template <Personality personality> struct Base {
|
||||
break;
|
||||
}
|
||||
}
|
||||
ram_[ram_pointer_ & 16383] = read_ahead_buffer_;
|
||||
ram_[ram_pointer_ & memory_mask(personality)] = read_ahead_buffer_;
|
||||
break;
|
||||
case MemoryAccess::Read:
|
||||
read_ahead_buffer_ = ram_[ram_pointer_ & 16383];
|
||||
read_ahead_buffer_ = ram_[ram_pointer_ & memory_mask(personality)];
|
||||
break;
|
||||
}
|
||||
++ram_pointer_;
|
||||
|
@ -42,6 +42,10 @@ constexpr size_t memory_size(Personality p) {
|
||||
}
|
||||
}
|
||||
|
||||
constexpr uint16_t memory_mask(Personality p) {
|
||||
return (memory_size(p) >= 65536) ? 0xffff : uint16_t(memory_size(p) - 1);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user