OSDN Git Service

[VM]Fix FTBFS.
[csp-qt/common_source_project-fm7.git] / source / src / vm / familybasic / ppu.h
1 /*
2         Nintendo Family BASIC Emulator 'eFamilyBASIC'
3
4         Origin : nester
5         Author : Takeda.Toshiya
6         Date   : 2010.08.11-
7
8         [ PPU ]
9 */
10
11 #ifndef _PPU_H_
12 #define _PPU_H_
13
14 #include "../vm.h"
15 #include "../../emu.h"
16 #include "../device.h"
17
18 #define MIRROR_HORIZ    0
19 #define MIRROR_VERT     1
20 #define MIRROR_4SCREEN  2
21
22 class MEMORY;
23
24 class PPU : public DEVICE
25 {
26 private:
27         DEVICE *d_cpu;
28         MEMORY *d_memory;
29         
30         scrntype_t palette_pc[64];
31         uint8_t screen[240][256 + 16];  // 2*8 = side margin
32         uint8_t solid_buf[512];
33         
34         header_t header;
35         uint32_t banks[16];
36         uint8_t* bank_ptr[16];
37 //      uint8_t chr_rom[0x2000];
38         uint32_t chr_rom_size;
39         uint32_t chr_rom_mask;
40         uint8_t *chr_rom;
41         uint8_t name_tables[0x1000];
42         uint8_t spr_ram[0x100];
43         uint8_t bg_pal[0x10];
44         uint8_t spr_pal[0x10];
45         uint8_t spr_ram_rw_ptr;
46         
47         uint8_t regs[8];
48         uint16_t bg_pattern_table_addr;
49         uint16_t spr_pattern_table_addr;
50         uint16_t ppu_addr_inc;
51         uint8_t rgb_bak;
52         bool toggle_2005_2006;
53         uint8_t read_2007_buffer;
54         
55         uint16_t loopy_v;
56         uint16_t loopy_t;
57         uint8_t loopy_x;
58         
59         void render_scanline(int v);
60         void render_bg(int v);
61         void render_spr(int v);
62         void update_palette();
63         void decl_state_header(header_t *p);
64         
65 public:
66         PPU(VM* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
67         {
68                 set_device_name(_T("PPU"));
69         }
70         ~PPU() {}
71         
72         // common functions
73         void initialize();
74         void release();
75         void reset();
76         void write_data8(uint32_t addr, uint32_t data);
77         uint32_t read_data8(uint32_t addr);
78         void event_vline(int v, int clock);
79         void decl_state();
80         void save_state(FILEIO* state_fio);
81         bool load_state(FILEIO* state_fio);
82         
83         // unique functions
84         void set_context_cpu(DEVICE* device)
85         {
86                 d_cpu = device;
87         }
88         void set_context_memory(MEMORY* device)
89         {
90                 d_memory = device;
91         }
92         uint8_t *get_spr_ram()
93         {
94                 return spr_ram;
95         }
96         uint8_t *get_name_tables()
97         {
98                 return name_tables;
99         }
100         bool spr_enabled()
101         {
102                 return ((regs[1] & 0x10) != 0);
103         }
104         bool bg_enabled()
105         {
106                 return ((regs[1] & 0x08) != 0);
107         }
108         void load_rom_image(const _TCHAR *file_name);
109         void draw_screen();
110         void set_ppu_bank(uint8_t bank, uint32_t bank_num);
111         void set_mirroring(int mirror);
112         void set_mirroring(uint32_t nt0, uint32_t nt1, uint32_t nt2, uint32_t nt3);
113 };
114
115 #endif