mirror of
https://github.com/TomHarte/CLK.git
synced 2024-12-27 01:31:42 +00:00
Merge branch 'master' into DiskWrites
This commit is contained in:
commit
42f25cdffc
@ -46,6 +46,7 @@ VideoOutput::VideoOutput(uint8_t *memory) :
|
|||||||
{
|
{
|
||||||
memset(palette_, 0xf, sizeof(palette_));
|
memset(palette_, 0xf, sizeof(palette_));
|
||||||
setup_screen_map();
|
setup_screen_map();
|
||||||
|
setup_base_address();
|
||||||
|
|
||||||
crt_.reset(new Outputs::CRT::CRT(crt_cycles_per_line, 8, Outputs::CRT::DisplayType::PAL50, 1));
|
crt_.reset(new Outputs::CRT::CRT(crt_cycles_per_line, 8, Outputs::CRT::DisplayType::PAL50, 1));
|
||||||
crt_->set_rgb_sampling_function(
|
crt_->set_rgb_sampling_function(
|
||||||
@ -302,13 +303,7 @@ void VideoOutput::set_register(int address, uint8_t value)
|
|||||||
if(new_screen_mode != screen_mode_)
|
if(new_screen_mode != screen_mode_)
|
||||||
{
|
{
|
||||||
screen_mode_ = new_screen_mode;
|
screen_mode_ = new_screen_mode;
|
||||||
switch(screen_mode_)
|
setup_base_address();
|
||||||
{
|
|
||||||
case 0: case 1: case 2: screen_mode_base_address_ = 0x3000; break;
|
|
||||||
case 3: screen_mode_base_address_ = 0x4000; break;
|
|
||||||
case 4: case 5: screen_mode_base_address_ = 0x5800; break;
|
|
||||||
case 6: screen_mode_base_address_ = 0x6000; break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -372,6 +367,17 @@ void VideoOutput::set_register(int address, uint8_t value)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VideoOutput::setup_base_address()
|
||||||
|
{
|
||||||
|
switch(screen_mode_)
|
||||||
|
{
|
||||||
|
case 0: case 1: case 2: screen_mode_base_address_ = 0x3000; break;
|
||||||
|
case 3: screen_mode_base_address_ = 0x4000; break;
|
||||||
|
case 4: case 5: screen_mode_base_address_ = 0x5800; break;
|
||||||
|
case 6: screen_mode_base_address_ = 0x6000; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#pragma mark - Interrupts
|
#pragma mark - Interrupts
|
||||||
|
|
||||||
VideoOutput::Interrupt VideoOutput::get_next_interrupt()
|
VideoOutput::Interrupt VideoOutput::get_next_interrupt()
|
||||||
|
@ -77,6 +77,7 @@ class VideoOutput {
|
|||||||
inline void start_pixel_line();
|
inline void start_pixel_line();
|
||||||
inline void end_pixel_line();
|
inline void end_pixel_line();
|
||||||
inline void output_pixels(unsigned int number_of_cycles);
|
inline void output_pixels(unsigned int number_of_cycles);
|
||||||
|
inline void setup_base_address();
|
||||||
|
|
||||||
int output_position_, unused_cycles_;
|
int output_position_, unused_cycles_;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user