1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-16 11:30:22 +00:00
CLK/Machines/Amiga/Blitter.hpp

70 lines
1.5 KiB
C++
Raw Normal View History

2021-07-22 18:43:07 -04:00
//
// Blitter.hpp
// Clock Signal
//
// Created by Thomas Harte on 22/07/2021.
// Copyright © 2021 Thomas Harte. All rights reserved.
//
#ifndef Blitter_hpp
#define Blitter_hpp
#include <cstddef>
#include <cstdint>
#include "../../ClockReceiver/ClockReceiver.hpp"
#include "DMADevice.hpp"
2021-07-22 18:43:07 -04:00
namespace Amiga {
2021-10-29 11:29:22 -07:00
class Blitter: public DMADevice<4, 4> {
2021-07-22 18:43:07 -04:00
public:
using DMADevice::DMADevice;
2021-07-22 18:43:07 -04:00
// Various setters; it's assumed that address decoding is handled externally.
//
// In all cases where a channel is identified numerically, it's taken that
// 0 = A, 1 = B, 2 = C, 3 = D.
void set_control(int index, uint16_t value);
void set_first_word_mask(uint16_t value);
void set_last_word_mask(uint16_t value);
2021-07-22 18:43:07 -04:00
void set_size(uint16_t value);
void set_minterms(uint16_t value);
void set_vertical_size(uint16_t value);
void set_horizontal_size(uint16_t value);
void set_data(int channel, uint16_t value);
uint16_t get_status();
bool advance();
2021-07-22 18:43:07 -04:00
private:
int width_ = 0, height_ = 0;
int shifts_[2]{};
2021-09-26 19:18:12 -04:00
uint16_t a_mask_[2] = {0xffff, 0xffff};
bool line_mode_ = false;
2021-09-26 19:18:12 -04:00
bool one_dot_ = false;
int line_direction_ = 0;
int line_sign_ = 1;
uint32_t direction_ = 1;
2021-09-28 22:11:58 -04:00
bool inclusive_fill_ = false;
bool exclusive_fill_ = false;
bool fill_carry_ = false;
2021-09-26 19:18:12 -04:00
bool channel_enables_[4]{};
uint8_t minterms_ = 0;
2021-09-23 22:05:59 -04:00
uint32_t a32_ = 0, b32_ = 0;
uint16_t a_data_ = 0, b_data_ = 0, c_data_ = 0;
2021-09-20 23:08:26 -04:00
2021-10-28 18:12:46 -07:00
bool not_zero_flag_ = false;
2021-07-22 18:43:07 -04:00
};
}
#endif /* Blitter_hpp */