From 3794d94b68cb51e01b31b9a0935ff41bdaeafb7f Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Sun, 27 Oct 2019 14:09:02 -0400 Subject: [PATCH 1/5] Adds a sanity check on alignment. --- Outputs/OpenGL/ScanTarget.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Outputs/OpenGL/ScanTarget.cpp b/Outputs/OpenGL/ScanTarget.cpp index 08e1d4fbc..85fa3fe0f 100644 --- a/Outputs/OpenGL/ScanTarget.cpp +++ b/Outputs/OpenGL/ScanTarget.cpp @@ -174,6 +174,8 @@ void ScanTarget::end_scan() { } uint8_t *ScanTarget::begin_data(size_t required_length, size_t required_alignment) { + assert(required_alignment); + if(allocation_has_failed_) return nullptr; if(!write_area_texture_.size()) { allocation_has_failed_ = true; From dc4a0e4e3b6b254980ebf9a7c44f52bd8a277e21 Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Sun, 27 Oct 2019 14:09:38 -0400 Subject: [PATCH 2/5] Video only ever reads from RAM, so it can be const *. (it can also be *const, since I set it only once) --- Machines/AmstradCPC/AmstradCPC.cpp | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/Machines/AmstradCPC/AmstradCPC.cpp b/Machines/AmstradCPC/AmstradCPC.cpp index 76d234613..7b824edd2 100644 --- a/Machines/AmstradCPC/AmstradCPC.cpp +++ b/Machines/AmstradCPC/AmstradCPC.cpp @@ -171,7 +171,7 @@ class AYDeferrer { */ class CRTCBusHandler { public: - CRTCBusHandler(uint8_t *ram, InterruptTimer &interrupt_timer) : + CRTCBusHandler(const uint8_t *ram, InterruptTimer &interrupt_timer) : crt_(1024, 1, Outputs::Display::Type::PAL50, Outputs::Display::InputDataType::Red2Green2Blue2), ram_(ram), interrupt_timer_(interrupt_timer) { @@ -263,25 +263,25 @@ class CRTCBusHandler { case 0: reinterpret_cast(pixel_pointer_)[0] = mode0_output_[ram_[address]]; reinterpret_cast(pixel_pointer_)[1] = mode0_output_[ram_[address+1]]; - pixel_pointer_ += 4; + pixel_pointer_ += 2 * sizeof(uint16_t); break; case 1: reinterpret_cast(pixel_pointer_)[0] = mode1_output_[ram_[address]]; reinterpret_cast(pixel_pointer_)[1] = mode1_output_[ram_[address+1]]; - pixel_pointer_ += 8; + pixel_pointer_ += 2 * sizeof(uint32_t); break; case 2: reinterpret_cast(pixel_pointer_)[0] = mode2_output_[ram_[address]]; reinterpret_cast(pixel_pointer_)[1] = mode2_output_[ram_[address+1]]; - pixel_pointer_ += 16; + pixel_pointer_ += 2 * sizeof(uint64_t); break; case 3: reinterpret_cast(pixel_pointer_)[0] = mode3_output_[ram_[address]]; reinterpret_cast(pixel_pointer_)[1] = mode3_output_[ram_[address+1]]; - pixel_pointer_ += 4; + pixel_pointer_ += 2 * sizeof(uint16_t); break; } @@ -538,7 +538,7 @@ class CRTCBusHandler { Outputs::CRT::CRT crt_; uint8_t *pixel_data_ = nullptr, *pixel_pointer_ = nullptr; - uint8_t *ram_ = nullptr; + const uint8_t *const ram_ = nullptr; int next_mode_ = 2, mode_ = 2; From 0fc191c87d561494eb266a1b8235060409c5693b Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Sun, 27 Oct 2019 14:21:22 -0400 Subject: [PATCH 3/5] Switched a few `static_cast` to constructor syntax. --- Machines/AmstradCPC/AmstradCPC.cpp | 42 +++++++++++++++--------------- 1 file changed, 21 insertions(+), 21 deletions(-) diff --git a/Machines/AmstradCPC/AmstradCPC.cpp b/Machines/AmstradCPC/AmstradCPC.cpp index 7b824edd2..cdc4364f8 100644 --- a/Machines/AmstradCPC/AmstradCPC.cpp +++ b/Machines/AmstradCPC/AmstradCPC.cpp @@ -41,7 +41,7 @@ namespace AmstradCPC { std::vector> get_options() { return Configurable::standard_options( - static_cast(Configurable::DisplayRGB | Configurable::DisplayCompositeColour) + Configurable::StandardOptions(Configurable::DisplayRGB | Configurable::DisplayCompositeColour) ); } @@ -250,7 +250,7 @@ class CRTCBusHandler { // MA13 MA12 RA2 RA1 RA0 MA9 MA8 MA7 MA6 MA5 MA4 MA3 MA2 MA1 MA0 CCLK // ... so form the real access address. const uint16_t address = - static_cast( + uint16_t( ((state.refresh_address & 0x3ff) << 1) | ((state.row_address & 0x7) << 11) | ((state.refresh_address & 0x3000) << 2) @@ -397,16 +397,16 @@ class CRTCBusHandler { void establish_palette_hits() { for(int c = 0; c < 256; c++) { - mode0_palette_hits_[Mode0Colour0(c)].push_back(static_cast(c)); - mode0_palette_hits_[Mode0Colour1(c)].push_back(static_cast(c)); + mode0_palette_hits_[Mode0Colour0(c)].push_back(uint8_t(c)); + mode0_palette_hits_[Mode0Colour1(c)].push_back(uint8_t(c)); - mode1_palette_hits_[Mode1Colour0(c)].push_back(static_cast(c)); - mode1_palette_hits_[Mode1Colour1(c)].push_back(static_cast(c)); - mode1_palette_hits_[Mode1Colour2(c)].push_back(static_cast(c)); - mode1_palette_hits_[Mode1Colour3(c)].push_back(static_cast(c)); + mode1_palette_hits_[Mode1Colour0(c)].push_back(uint8_t(c)); + mode1_palette_hits_[Mode1Colour1(c)].push_back(uint8_t(c)); + mode1_palette_hits_[Mode1Colour2(c)].push_back(uint8_t(c)); + mode1_palette_hits_[Mode1Colour3(c)].push_back(uint8_t(c)); - mode3_palette_hits_[Mode3Colour0(c)].push_back(static_cast(c)); - mode3_palette_hits_[Mode3Colour1(c)].push_back(static_cast(c)); + mode3_palette_hits_[Mode3Colour0(c)].push_back(uint8_t(c)); + mode3_palette_hits_[Mode3Colour1(c)].push_back(uint8_t(c)); } } @@ -416,7 +416,7 @@ class CRTCBusHandler { // Mode 0: abcdefgh -> [gcea] [hdfb] for(int c = 0; c < 256; c++) { // prepare mode 0 - uint8_t *mode0_pixels = reinterpret_cast(&mode0_output_[c]); + uint8_t *const mode0_pixels = reinterpret_cast(&mode0_output_[c]); mode0_pixels[0] = palette_[Mode0Colour0(c)]; mode0_pixels[1] = palette_[Mode0Colour1(c)]; } @@ -425,7 +425,7 @@ class CRTCBusHandler { case 1: for(int c = 0; c < 256; c++) { // prepare mode 1 - uint8_t *mode1_pixels = reinterpret_cast(&mode1_output_[c]); + uint8_t *const mode1_pixels = reinterpret_cast(&mode1_output_[c]); mode1_pixels[0] = palette_[Mode1Colour0(c)]; mode1_pixels[1] = palette_[Mode1Colour1(c)]; mode1_pixels[2] = palette_[Mode1Colour2(c)]; @@ -436,7 +436,7 @@ class CRTCBusHandler { case 2: for(int c = 0; c < 256; c++) { // prepare mode 2 - uint8_t *mode2_pixels = reinterpret_cast(&mode2_output_[c]); + uint8_t *const mode2_pixels = reinterpret_cast(&mode2_output_[c]); mode2_pixels[0] = palette_[((c & 0x80) >> 7)]; mode2_pixels[1] = palette_[((c & 0x40) >> 6)]; mode2_pixels[2] = palette_[((c & 0x20) >> 5)]; @@ -451,7 +451,7 @@ class CRTCBusHandler { case 3: for(int c = 0; c < 256; c++) { // prepare mode 3 - uint8_t *mode3_pixels = reinterpret_cast(&mode3_output_[c]); + uint8_t *const mode3_pixels = reinterpret_cast(&mode3_output_[c]); mode3_pixels[0] = palette_[Mode3Colour0(c)]; mode3_pixels[1] = palette_[Mode3Colour1(c)]; } @@ -463,7 +463,7 @@ class CRTCBusHandler { switch(mode_) { case 0: { for(uint8_t c : mode0_palette_hits_[pen]) { - uint8_t *mode0_pixels = reinterpret_cast(&mode0_output_[c]); + uint8_t *const mode0_pixels = reinterpret_cast(&mode0_output_[c]); mode0_pixels[0] = palette_[Mode0Colour0(c)]; mode0_pixels[1] = palette_[Mode0Colour1(c)]; } @@ -471,7 +471,7 @@ class CRTCBusHandler { case 1: if(pen > 3) return; for(uint8_t c : mode1_palette_hits_[pen]) { - uint8_t *mode1_pixels = reinterpret_cast(&mode1_output_[c]); + uint8_t *const mode1_pixels = reinterpret_cast(&mode1_output_[c]); mode1_pixels[0] = palette_[Mode1Colour0(c)]; mode1_pixels[1] = palette_[Mode1Colour1(c)]; mode1_pixels[2] = palette_[Mode1Colour2(c)]; @@ -488,7 +488,7 @@ class CRTCBusHandler { if(pen > 3) return; // Same argument applies here as to case 1, as the unused bits aren't masked out. for(uint8_t c : mode3_palette_hits_[pen]) { - uint8_t *mode3_pixels = reinterpret_cast(&mode3_output_[c]); + uint8_t *const mode3_pixels = reinterpret_cast(&mode3_output_[c]); mode3_pixels[0] = palette_[Mode3Colour0(c)]; mode3_pixels[1] = palette_[Mode3Colour1(c)]; } @@ -574,7 +574,7 @@ class KeyboardState: public GI::AY38910::PortHandler { Sets the row currently being reported to the AY. */ void set_row(int row) { - row_ = static_cast(row); + row_ = size_t(row); } /*! @@ -593,7 +593,7 @@ class KeyboardState: public GI::AY38910::PortHandler { */ void set_is_pressed(bool is_pressed, int line, int key) { int mask = 1 << key; - assert(static_cast(line) < sizeof(rows_)); + assert(size_t(line) < sizeof(rows_)); if(is_pressed) rows_[line] &= ~mask; else rows_[line] |= mask; } @@ -826,8 +826,8 @@ template class ConcreteMachine: for(std::size_t index = 0; index < roms.size(); ++index) { auto &data = roms[index]; if(!data) throw ROMMachine::Error::MissingROMs; - roms_[static_cast(index)] = std::move(*data); - roms_[static_cast(index)].resize(16384); + roms_[int(index)] = std::move(*data); + roms_[int(index)].resize(16384); } // Establish default memory map From 1aba1db62c018af8e205467f6a9ac79924b174d8 Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Sun, 27 Oct 2019 21:30:58 -0400 Subject: [PATCH 4/5] Corrects test. --- OSBindings/Mac/Clock SignalTests/MacintoshVideoTests.mm | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/OSBindings/Mac/Clock SignalTests/MacintoshVideoTests.mm b/OSBindings/Mac/Clock SignalTests/MacintoshVideoTests.mm index b955d9348..ef833ac71 100644 --- a/OSBindings/Mac/Clock SignalTests/MacintoshVideoTests.mm +++ b/OSBindings/Mac/Clock SignalTests/MacintoshVideoTests.mm @@ -23,7 +23,8 @@ - (void)setUp { // Put setup code here. This method is called before the invocation of each test method in the class. - _video.reset(new Apple::Macintosh::Video(_ram, _dummy_audio, _dummy_drive_speed_accumulator)); + _video.reset(new Apple::Macintosh::Video(_dummy_audio, _dummy_drive_speed_accumulator)); + _video->set_ram(_ram, sizeof(_ram) - 1); } - (void)testPrediction { From 4266264449b658cbf5b6c618ede5ee5eef1bf286 Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Sun, 27 Oct 2019 21:31:31 -0400 Subject: [PATCH 5/5] Switches to the more idiomatic .empty(). --- Outputs/OpenGL/ScanTarget.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Outputs/OpenGL/ScanTarget.cpp b/Outputs/OpenGL/ScanTarget.cpp index 85fa3fe0f..b4b1a4fe4 100644 --- a/Outputs/OpenGL/ScanTarget.cpp +++ b/Outputs/OpenGL/ScanTarget.cpp @@ -177,7 +177,7 @@ uint8_t *ScanTarget::begin_data(size_t required_length, size_t required_alignmen assert(required_alignment); if(allocation_has_failed_) return nullptr; - if(!write_area_texture_.size()) { + if(write_area_texture_.empty()) { allocation_has_failed_ = true; return nullptr; }