2021-12-07 22:48:33 +01:00
|
|
|
/*
|
|
|
|
DingusPPC - The Experimental PowerPC Macintosh emulator
|
|
|
|
Copyright (C) 2018-21 divingkatae and maximum
|
|
|
|
(theweirdo) spatium
|
|
|
|
|
|
|
|
(Contact divingkatae#1017 or powermax#2286 on Discord for more info)
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file Definitions for the PDM on-board video. */
|
|
|
|
|
|
|
|
#ifndef PDM_ONBOARD_H
|
|
|
|
#define PDM_ONBOARD_H
|
|
|
|
|
|
|
|
#include <devices/video/videoctrl.h>
|
|
|
|
|
|
|
|
#include <cinttypes>
|
|
|
|
|
2023-11-03 00:21:33 -07:00
|
|
|
class HMC;
|
|
|
|
class InterruptCtrl;
|
|
|
|
|
2021-12-07 22:48:33 +01:00
|
|
|
#define PDM_VMODE_OFF 0x1F
|
|
|
|
|
|
|
|
/** Max. size of our framebuffer in bytes (RGB 13-inch, 16 bpp) */
|
|
|
|
#define PDM_FB_SIZE_MAX (640 * 480 * 2)
|
|
|
|
|
|
|
|
/** Fixed video modes supported by the PDM on-board video. */
|
|
|
|
enum PdmVideoMode : uint8_t {
|
|
|
|
Portrait = 1,
|
|
|
|
Rgb12in = 2,
|
|
|
|
Rgb13in = 6,
|
|
|
|
Rgb16in = 9,
|
|
|
|
VGA = 0xB
|
|
|
|
};
|
|
|
|
|
|
|
|
class PdmOnboardVideo : public VideoCtrlBase {
|
|
|
|
public:
|
|
|
|
PdmOnboardVideo();
|
|
|
|
~PdmOnboardVideo() = default;
|
|
|
|
|
|
|
|
uint8_t get_video_mode() {
|
|
|
|
return ((this->video_mode & 0x1F) | this->blanking);
|
|
|
|
};
|
|
|
|
|
|
|
|
void set_video_mode(uint8_t new_mode);
|
|
|
|
void set_pixel_depth(uint8_t depth);
|
2022-01-10 17:09:21 +01:00
|
|
|
void set_vdac_config(uint8_t config);
|
|
|
|
uint8_t get_vdac_config() {
|
|
|
|
return this->vdac_mode;
|
|
|
|
};
|
2021-12-07 22:48:33 +01:00
|
|
|
void set_clut_index(uint8_t index);
|
|
|
|
void set_clut_color(uint8_t color);
|
|
|
|
|
2023-08-01 17:41:02 +02:00
|
|
|
void init_interrupts(InterruptCtrl *int_ctrl, uint32_t vbl_irq_id) {
|
|
|
|
this->int_ctrl = int_ctrl;
|
|
|
|
this->irq_id = vbl_irq_id;
|
|
|
|
};
|
|
|
|
|
2021-12-07 22:48:33 +01:00
|
|
|
protected:
|
2023-12-02 20:41:30 -08:00
|
|
|
void set_depth_internal(int width);
|
2021-12-07 22:48:33 +01:00
|
|
|
void enable_video_internal();
|
|
|
|
void disable_video_internal();
|
2024-08-25 17:36:33 -07:00
|
|
|
void convert_frame_1bpp_indexed(uint8_t *dst_buf, int dst_pitch) override;
|
|
|
|
void convert_frame_2bpp_indexed(uint8_t *dst_buf, int dst_pitch) override;
|
|
|
|
void convert_frame_4bpp_indexed(uint8_t *dst_buf, int dst_pitch) override;
|
2021-12-07 22:48:33 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
uint8_t video_mode;
|
|
|
|
uint8_t blanking;
|
|
|
|
uint8_t vdac_mode;
|
|
|
|
uint8_t clut_index;
|
|
|
|
uint8_t comp_index;
|
|
|
|
uint8_t clut_color[3];
|
|
|
|
|
|
|
|
HMC* hmc_obj;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // PDM_ONBOARD_H
|