trunk/src/mess/video/apollo.c
| r29175 | r29176 | |
| 96 | 96 | #define LUT_C0 0x01 |
| 97 | 97 | #define LUT_C1_C0(a) ((a)& (LUT_C1|LUT_C0)) |
| 98 | 98 | |
| 99 | | #define LUT_FIFO_SIZE 1024 |
| 100 | 99 | |
| 101 | | //************************************************************************** |
| 102 | | // class apollo_graphics |
| 103 | | //************************************************************************** |
| 104 | | |
| 105 | | class apollo_graphics /*: public device_t*/ |
| 100 | apollo_graphics_15i::bt458::bt458(running_machine &running_machine) |
| 106 | 101 | { |
| 107 | | public: |
| 108 | | apollo_graphics() |
| 109 | | { |
| 110 | | } |
| 111 | | |
| 112 | | void device_start(running_machine &m_machine); |
| 113 | | void device_reset(); |
| 114 | | void device_reset_mono19i(); |
| 115 | | |
| 116 | | // monochrome control |
| 117 | | READ8_DEVICE_HANDLER( apollo_mcr_r ); |
| 118 | | WRITE8_DEVICE_HANDLER( apollo_mcr_w ); |
| 119 | | |
| 120 | | // monochrome and color memory |
| 121 | | READ16_DEVICE_HANDLER( apollo_mem_r ); |
| 122 | | WRITE16_DEVICE_HANDLER( apollo_mem_w ); |
| 123 | | |
| 124 | | // color control |
| 125 | | READ8_DEVICE_HANDLER( apollo_ccr_r ); |
| 126 | | WRITE8_DEVICE_HANDLER( apollo_ccr_w ); |
| 127 | | |
| 128 | | UINT32 screen_update(bitmap_rgb32 &bitmap, const rectangle &cliprect); |
| 129 | | void vblank_state_changed(device_t *device, screen_device &screen, bool vblank_state); |
| 130 | | |
| 131 | | int is_mono() { return m_n_planes == 1; } |
| 132 | | |
| 133 | | private: |
| 134 | | class lut_fifo; |
| 135 | | class bt458; |
| 136 | | |
| 137 | | running_machine &machine() const |
| 138 | | { |
| 139 | | assert(m_machine != NULL); |
| 140 | | return *m_machine; |
| 141 | | } |
| 142 | | |
| 143 | | const char *cr_text(offs_t offset, UINT8 data, UINT8 rw); |
| 144 | | |
| 145 | | void increment_h_clock(); |
| 146 | | void increment_v_clock(); |
| 147 | | void increment_p_clock(); |
| 148 | | |
| 149 | | void log_cr1(const char * text, device_t *device); |
| 150 | | void set_cr1(device_t *device, UINT8 data); |
| 151 | | void set_cr3a(device_t *device, UINT8 data); |
| 152 | | void set_cr3b(device_t *device, UINT8 data); |
| 153 | | void set_lut_cr(device_t *device, UINT8 data); |
| 154 | | |
| 155 | | UINT32 set_msb0(UINT32 value, UINT8 data) |
| 156 | | { |
| 157 | | return (value & 0xffffff00) | data; |
| 158 | | } |
| 159 | | UINT32 set_lsb0(UINT32 value, UINT8 data) |
| 160 | | { |
| 161 | | return (value & 0xffff00ff) | (data << 8); |
| 162 | | } |
| 163 | | UINT32 set_msb1(UINT32 value, UINT8 data) |
| 164 | | { |
| 165 | | return (value & 0xff00ffff) | (data << 16); |
| 166 | | } |
| 167 | | UINT32 set_lsb1(UINT32 value, UINT8 data) |
| 168 | | { |
| 169 | | return (value & 0x00ffffff) | (data << 24); |
| 170 | | } |
| 171 | | UINT8 get_msb1(UINT32 value) |
| 172 | | { |
| 173 | | return (value >> 16) & 0xff; |
| 174 | | } |
| 175 | | UINT8 get_lsb1(UINT32 value) |
| 176 | | { |
| 177 | | return (value >> 24) & 0xff; |
| 178 | | } |
| 179 | | |
| 180 | | void set_status_rmw(); |
| 181 | | UINT16 rop(UINT16 dest_data, UINT16 src_data, UINT8 plane); |
| 182 | | void set_source_data(UINT32 offset); |
| 183 | | UINT32 get_source_data(UINT8 plane); |
| 184 | | void blt(UINT32 dest_addr, UINT16 mem_mask); |
| 185 | | |
| 186 | | UINT8 get_pixel(UINT32 offset, UINT16 mask); |
| 187 | | UINT8 c4p_read_adc(UINT8 data); |
| 188 | | UINT8 c8p_read_adc(UINT8 data); |
| 189 | | |
| 190 | | void screen_update1(bitmap_rgb32 &bitmap, const rectangle &cliprect); |
| 191 | | |
| 192 | | UINT16 m_n_planes; |
| 193 | | UINT16 m_width; |
| 194 | | UINT16 m_height; |
| 195 | | UINT16 m_buffer_width; |
| 196 | | UINT16 m_buffer_height; |
| 197 | | |
| 198 | | UINT8 m_sr; |
| 199 | | UINT8 m_device_id; |
| 200 | | UINT16 m_write_enable_register; |
| 201 | | UINT32 m_rop_register; |
| 202 | | UINT16 m_diag_mem_request; |
| 203 | | UINT8 m_cr0; |
| 204 | | UINT8 m_cr1; |
| 205 | | UINT8 m_cr2; |
| 206 | | UINT8 m_cr2b; |
| 207 | | UINT8 m_cr2_s_data; |
| 208 | | UINT8 m_cr2_s_plane; |
| 209 | | UINT8 m_cr2_d_plane; |
| 210 | | UINT8 m_cr3a; |
| 211 | | UINT8 m_cr3b; |
| 212 | | UINT8 m_ad_result; |
| 213 | | UINT8 m_ad_pending; |
| 214 | | |
| 215 | | UINT8 m_lut_control; |
| 216 | | UINT8 m_lut_data; |
| 217 | | |
| 218 | | UINT8 m_update_flag; |
| 219 | | UINT8 m_update_pending; |
| 220 | | |
| 221 | | UINT8 m_blt_cycle_count; |
| 222 | | UINT32 m_image_offset; |
| 223 | | UINT32 m_guard_latch[8]; |
| 224 | | |
| 225 | | int m_h_clock; |
| 226 | | int m_v_clock; |
| 227 | | int m_p_clock; |
| 228 | | int m_data_clock; |
| 229 | | |
| 230 | | UINT16 *m_image_memory; |
| 231 | | int m_image_plane_size; |
| 232 | | int m_image_memory_size; |
| 233 | | |
| 234 | | UINT32 m_color_lookup_table[16]; |
| 235 | | |
| 236 | | lut_fifo *m_lut_fifo; |
| 237 | | bt458 *m_bt458; |
| 238 | | |
| 239 | | running_machine *m_machine; |
| 240 | | }; |
| 241 | | |
| 242 | | //************************************************************************** |
| 243 | | // class LUT Fifo |
| 244 | | //************************************************************************** |
| 245 | | |
| 246 | | class apollo_graphics::lut_fifo |
| 247 | | { |
| 248 | | public: |
| 249 | | lut_fifo() |
| 250 | | { |
| 251 | | reset(); |
| 252 | | } |
| 253 | | |
| 254 | | void reset() |
| 255 | | { |
| 256 | | m_size = LUT_FIFO_SIZE; |
| 257 | | m_get_index = 0; |
| 258 | | m_put_index = 0; |
| 259 | | } |
| 260 | | |
| 261 | | void put(const UINT8 data) |
| 262 | | { |
| 263 | | if (!is_full()) |
| 264 | | { |
| 265 | | m_data[m_put_index] = data; |
| 266 | | m_put_index = (m_put_index + 1) % m_size; |
| 267 | | } |
| 268 | | } |
| 269 | | |
| 270 | | UINT8 get() |
| 271 | | { |
| 272 | | UINT8 data = is_empty() ? 0xff : m_data[m_get_index]; |
| 273 | | m_get_index = (m_get_index + 1) % m_size; |
| 274 | | return data; |
| 275 | | } |
| 276 | | |
| 277 | | int is_empty() |
| 278 | | { |
| 279 | | return m_get_index == m_put_index; |
| 280 | | } |
| 281 | | |
| 282 | | int is_full() |
| 283 | | { |
| 284 | | return ((m_put_index + 1) % m_size) == m_get_index; |
| 285 | | } |
| 286 | | |
| 287 | | private: |
| 288 | | UINT16 m_size; |
| 289 | | UINT16 m_get_index; |
| 290 | | UINT16 m_put_index; |
| 291 | | UINT8 m_data[LUT_FIFO_SIZE]; |
| 292 | | }; |
| 293 | | |
| 294 | | //************************************************************************** |
| 295 | | // class Brooktree Bt458 |
| 296 | | //************************************************************************** |
| 297 | | |
| 298 | | class apollo_graphics::bt458 |
| 299 | | { |
| 300 | | public: |
| 301 | | bt458(running_machine &running_machine); |
| 302 | | void start(); |
| 303 | | void reset(); |
| 304 | | UINT8 read(UINT8 c10); |
| 305 | | void write(UINT8 data, UINT8 c10); |
| 306 | | UINT32 get_rgb(UINT8 index); |
| 307 | | |
| 308 | | private: |
| 309 | | running_machine &machine() const |
| 310 | | { |
| 311 | | assert(m_machine != NULL); |
| 312 | | return *m_machine; |
| 313 | | } |
| 314 | | |
| 315 | | UINT8 m_color_counter; |
| 316 | | UINT8 m_red; |
| 317 | | UINT8 m_green; |
| 318 | | |
| 319 | | UINT8 m_address_register; |
| 320 | | UINT32 m_color_palette_RAM[256]; |
| 321 | | UINT32 m_overlay_color[4]; |
| 322 | | UINT8 m_read_mask_register; |
| 323 | | UINT8 m_blink_mask_register; |
| 324 | | UINT8 m_command_register; |
| 325 | | UINT8 m_control_test_register; |
| 326 | | |
| 327 | | running_machine *m_machine; |
| 328 | | }; |
| 329 | | |
| 330 | | apollo_graphics::bt458::bt458(running_machine &running_machine) |
| 331 | | { |
| 332 | 102 | m_machine = &running_machine; |
| 333 | 103 | } |
| 334 | 104 | |
| 335 | | void apollo_graphics::bt458::start() |
| 105 | void apollo_graphics_15i::bt458::start() |
| 336 | 106 | { |
| 337 | | MLOG1(("start apollo_graphics::bt458")); |
| 107 | MLOG1(("start apollo_graphics_15i::bt458")); |
| 338 | 108 | } |
| 339 | 109 | |
| 340 | | void apollo_graphics::bt458::reset() |
| 110 | void apollo_graphics_15i::bt458::reset() |
| 341 | 111 | { |
| 342 | | MLOG1(("reset apollo_graphics::bt458")); |
| 112 | MLOG1(("reset apollo_graphics_15i::bt458")); |
| 343 | 113 | |
| 344 | 114 | m_color_counter = 0; |
| 345 | 115 | m_red = 0; |
| r29175 | r29176 | |
| 354 | 124 | m_control_test_register = 0; |
| 355 | 125 | } |
| 356 | 126 | |
| 357 | | void apollo_graphics::bt458::write(UINT8 data, UINT8 c10) |
| 127 | void apollo_graphics_15i::bt458::write(UINT8 data, UINT8 c10) |
| 358 | 128 | { |
| 359 | 129 | MLOG1(("writing Bt458 data=%02x C1,C0=%d", data, c10)); |
| 360 | 130 | switch (c10) |
| r29175 | r29176 | |
| 427 | 197 | } |
| 428 | 198 | } |
| 429 | 199 | |
| 430 | | UINT8 apollo_graphics::bt458::read(UINT8 c10) |
| 200 | UINT8 apollo_graphics_15i::bt458::read(UINT8 c10) |
| 431 | 201 | { |
| 432 | 202 | UINT8 data = 0xff; |
| 433 | 203 | |
| r29175 | r29176 | |
| 498 | 268 | return data; |
| 499 | 269 | } |
| 500 | 270 | |
| 501 | | UINT32 apollo_graphics::bt458::get_rgb(UINT8 index) |
| 271 | UINT32 apollo_graphics_15i::bt458::get_rgb(UINT8 index) |
| 502 | 272 | { |
| 503 | 273 | return m_color_palette_RAM[index]; |
| 504 | 274 | } |
| 505 | 275 | |
| 506 | | /***************************************************************************** |
| 507 | | INLINE FUNCTIONS |
| 508 | | *****************************************************************************/ |
| 509 | | |
| 510 | | INLINE apollo_graphics *get_safe_token(device_t *device) |
| 511 | | { |
| 512 | | assert(device != NULL); |
| 513 | | assert(device->type() == APOLLO_GRAPHICS || device->type() == APOLLO_MONO19I ); |
| 514 | | return (apollo_graphics *) downcast<apollo_graphics_15i *> (device)->token(); |
| 515 | | } |
| 516 | | |
| 517 | | void apollo_graphics::device_start(running_machine &running_machine) |
| 518 | | { |
| 519 | | m_n_planes = 0; |
| 520 | | m_width = 0; |
| 521 | | m_height = 0; |
| 522 | | m_buffer_width = 0; |
| 523 | | m_buffer_height = 0; |
| 524 | | |
| 525 | | m_sr = 0; |
| 526 | | m_device_id = 0; |
| 527 | | m_write_enable_register = 0; |
| 528 | | m_rop_register = 0; |
| 529 | | m_diag_mem_request = 0; |
| 530 | | m_cr0 = 0; |
| 531 | | m_cr1 = 0; |
| 532 | | m_cr2 = 0; |
| 533 | | m_cr2b = 0; |
| 534 | | m_cr2_s_data = 0; |
| 535 | | m_cr2_s_plane = 0x00; |
| 536 | | m_cr2_d_plane = 0x0e; |
| 537 | | m_cr3a = 0; |
| 538 | | m_cr3b = 0; |
| 539 | | m_ad_result = 0; |
| 540 | | m_ad_pending = 0; |
| 541 | | |
| 542 | | m_lut_control = 0; |
| 543 | | m_lut_data = 0; |
| 544 | | |
| 545 | | m_update_flag = 0; |
| 546 | | m_update_pending = 0; |
| 547 | | |
| 548 | | m_blt_cycle_count = 0; |
| 549 | | m_image_offset = 0; |
| 550 | | memset(m_guard_latch, 0, sizeof(m_guard_latch)); |
| 551 | | |
| 552 | | m_h_clock = 0; |
| 553 | | m_v_clock = 0; |
| 554 | | m_p_clock = 0; |
| 555 | | m_data_clock = 0; |
| 556 | | |
| 557 | | m_image_memory = 0; |
| 558 | | m_image_plane_size = 0; |
| 559 | | m_image_memory_size = 0; |
| 560 | | |
| 561 | | memset(m_color_lookup_table, 0, sizeof(m_color_lookup_table)); |
| 562 | | |
| 563 | | m_lut_fifo = NULL; |
| 564 | | m_bt458 = NULL; |
| 565 | | |
| 566 | | m_machine = &running_machine; |
| 567 | | } |
| 568 | | |
| 569 | | void apollo_graphics::device_reset() |
| 570 | | { |
| 571 | | if (m_n_planes == 0) |
| 572 | | { |
| 573 | | if (apollo_config(APOLLO_CONF_MONO_19I)) |
| 574 | | { |
| 575 | | // monochrome 1280x1024 |
| 576 | | m_n_planes = 1; |
| 577 | | m_device_id = SCREEN_DEVICE_ID_19I; |
| 578 | | m_width = 1280; |
| 579 | | m_height = 1024; |
| 580 | | m_buffer_width = 2048; |
| 581 | | m_buffer_height = 1024; |
| 582 | | } |
| 583 | | else if (apollo_config(APOLLO_CONF_MONO_15I)) |
| 584 | | { |
| 585 | | // monochrome 1024x800 |
| 586 | | m_n_planes = 1; |
| 587 | | m_device_id = SCREEN_DEVICE_ID_15I; |
| 588 | | m_width = 1024; |
| 589 | | m_height = 800; |
| 590 | | m_buffer_width = 1024; |
| 591 | | m_buffer_height = 1024; |
| 592 | | } |
| 593 | | else if (apollo_config(APOLLO_CONF_4_PLANES)) |
| 594 | | { |
| 595 | | // 4-planes color 1024x800 |
| 596 | | m_n_planes = 4; |
| 597 | | m_device_id = SCREEN_DEVICE_ID_C4P; |
| 598 | | m_width = 1024; |
| 599 | | m_height = 800; |
| 600 | | m_buffer_width = 1024; |
| 601 | | m_buffer_height = 1024; |
| 602 | | } |
| 603 | | else |
| 604 | | { |
| 605 | | // 8-planes color 1024x800 |
| 606 | | m_n_planes = 8; |
| 607 | | m_device_id = SCREEN_DEVICE_ID_C8P; |
| 608 | | m_width = 1024; |
| 609 | | m_height = 800; |
| 610 | | m_buffer_width = 1024; |
| 611 | | m_buffer_height = 1024; |
| 612 | | |
| 613 | | m_lut_fifo = new lut_fifo(); |
| 614 | | |
| 615 | | m_bt458 = new bt458(*m_machine); |
| 616 | | m_bt458->start(); |
| 617 | | m_bt458->reset(); |
| 618 | | } |
| 619 | | } |
| 620 | | |
| 621 | | if (m_image_memory == NULL) |
| 622 | | { |
| 623 | | /* allocate the memory image */ |
| 624 | | m_image_plane_size = m_buffer_height * m_buffer_width / 16; |
| 625 | | m_image_memory_size = m_image_plane_size * m_n_planes; |
| 626 | | m_image_memory |
| 627 | | = auto_alloc_array(machine(), UINT16, m_image_memory_size); |
| 628 | | assert(m_image_memory != NULL); |
| 629 | | |
| 630 | | MLOG1(("device reset apollo graphics: buffer=%p size=%0x", m_image_memory, m_image_memory_size)); |
| 631 | | } |
| 632 | | |
| 633 | | memset(m_color_lookup_table, 0, sizeof(m_color_lookup_table)); |
| 634 | | memset(m_image_memory, 0, m_image_memory_size * 2); |
| 635 | | |
| 636 | | // register_vblank_callback(this); |
| 637 | | } |
| 638 | | |
| 639 | | void apollo_graphics::device_reset_mono19i() |
| 640 | | { |
| 641 | | if (m_n_planes == 0) |
| 642 | | { |
| 643 | | // monochrome 1280x1024 |
| 644 | | m_n_planes = 1; |
| 645 | | m_device_id = SCREEN_DEVICE_ID_19I; |
| 646 | | m_width = 1280; |
| 647 | | m_height = 1024; |
| 648 | | m_buffer_width = 2048; |
| 649 | | m_buffer_height = 1024; |
| 650 | | } |
| 651 | | |
| 652 | | device_reset(); |
| 653 | | } |
| 654 | | |
| 655 | 276 | /*************************************************************************** |
| 656 | 277 | Monochrome Controller Registers at 0x5d800 - 0x5dc07 |
| 657 | 278 | ***************************************************************************/ |
| 658 | 279 | |
| 659 | | const char *apollo_graphics::cr_text(offs_t offset, UINT8 data, UINT8 rw) |
| 280 | const char *apollo_graphics_15i::cr_text(offs_t offset, UINT8 data, UINT8 rw) |
| 660 | 281 | { |
| 661 | 282 | static const char *cr0[8] = |
| 662 | 283 | { "cr0 mode=0 CPU dest BLT", "cr0 mode=1 Alternating BLT", |
| r29175 | r29176 | |
| 708 | 329 | } |
| 709 | 330 | } |
| 710 | 331 | |
| 711 | | void apollo_graphics::log_cr1(const char * text, device_t *device) |
| 332 | void apollo_graphics_15i::log_cr1(const char * text) |
| 712 | 333 | { |
| 713 | | DLOG2(("%s: cr0=%02x cr1=%02x sr=%02x pixel_clock=%3d/%3d bl=%d vb=%d vs=%d hs=%d hc=%d vck=%d hck=%d pck=%d vd=%d", |
| 334 | MLOG2(("%s: cr0=%02x cr1=%02x sr=%02x pixel_clock=%3d/%3d bl=%d vb=%d vs=%d hs=%d hc=%d vck=%d hck=%d pck=%d vd=%d", |
| 714 | 335 | text, |
| 715 | 336 | m_cr0, |
| 716 | 337 | m_cr1, |
| r29175 | r29176 | |
| 728 | 349 | m_sr & SR_V_DATA ? 1 : 0)); |
| 729 | 350 | } |
| 730 | 351 | |
| 731 | | void apollo_graphics::increment_h_clock() |
| 352 | void apollo_graphics_15i::increment_h_clock() |
| 732 | 353 | { |
| 733 | 354 | MLOG1(("increment_h_clock: sr=%02x m_h_clock=%d", m_sr, m_h_clock)); |
| 734 | 355 | |
| r29175 | r29176 | |
| 809 | 430 | m_h_clock++; |
| 810 | 431 | } |
| 811 | 432 | |
| 812 | | void apollo_graphics::increment_v_clock() |
| 433 | void apollo_graphics_15i::increment_v_clock() |
| 813 | 434 | { |
| 814 | 435 | MLOG1(("increment_v_clock: sr=%02x m_v_clock=%d", m_sr, m_v_clock)); |
| 815 | 436 | |
| r29175 | r29176 | |
| 896 | 517 | m_data_clock = 0; |
| 897 | 518 | } |
| 898 | 519 | |
| 899 | | void apollo_graphics::increment_p_clock() |
| 520 | void apollo_graphics_15i::increment_p_clock() |
| 900 | 521 | { |
| 901 | 522 | if (m_n_planes == 1) |
| 902 | 523 | { |
| r29175 | r29176 | |
| 954 | 575 | } |
| 955 | 576 | } |
| 956 | 577 | |
| 957 | | void apollo_graphics::set_cr1(device_t *device, UINT8 data) |
| 578 | void apollo_graphics_15i::set_cr1(UINT8 data) |
| 958 | 579 | { |
| 959 | 580 | UINT8 diffs = m_cr1 ^ data; |
| 960 | 581 | m_cr1 = data; |
| r29175 | r29176 | |
| 992 | 613 | m_sr = SR_H_CK | SR_V_BLANK | SR_SYNC | SR_DONE; |
| 993 | 614 | } |
| 994 | 615 | } |
| 995 | | log_cr1("CR1_RESET", device); |
| 616 | log_cr1("CR1_RESET"); |
| 996 | 617 | } |
| 997 | 618 | else |
| 998 | 619 | { |
| 999 | 620 | if ((diffs & CR1_RESET) && (m_cr1 & CR1_RESET) != 0) |
| 1000 | 621 | { |
| 1001 | | log_cr1("CR1_RESET", device); |
| 622 | log_cr1("CR1_RESET"); |
| 1002 | 623 | } |
| 1003 | 624 | |
| 1004 | 625 | if (dh_clock) |
| 1005 | 626 | { |
| 1006 | 627 | increment_h_clock(); |
| 1007 | | log_cr1("CR1_DH_CK", device); |
| 628 | log_cr1("CR1_DH_CK"); |
| 1008 | 629 | } |
| 1009 | 630 | |
| 1010 | 631 | if (dv_clock) |
| 1011 | 632 | { |
| 1012 | 633 | increment_v_clock(); |
| 1013 | | log_cr1("CR1_DV_CK", device); |
| 634 | log_cr1("CR1_DV_CK"); |
| 1014 | 635 | } |
| 1015 | 636 | |
| 1016 | 637 | if (dp_clock) |
| 1017 | 638 | { |
| 1018 | 639 | increment_p_clock(); |
| 1019 | | log_cr1("CR1_DP_CK", device); |
| 640 | log_cr1("CR1_DP_CK"); |
| 1020 | 641 | } |
| 1021 | 642 | |
| 1022 | 643 | if ((m_sr & SR_V_BLANK) == 0) |
| r29175 | r29176 | |
| 1032 | 653 | } |
| 1033 | 654 | } |
| 1034 | 655 | |
| 1035 | | void apollo_graphics::set_cr3a(device_t *device, UINT8 data) |
| 656 | void apollo_graphics_15i::set_cr3a(UINT8 data) |
| 1036 | 657 | { |
| 1037 | 658 | m_cr3a = data; |
| 1038 | 659 | if ((data & 0x80) == 0) |
| r29175 | r29176 | |
| 1041 | 662 | UINT8 bit_mask = 1 << shift; |
| 1042 | 663 | if (data & 0x01) |
| 1043 | 664 | { |
| 1044 | | set_cr1(device, m_cr1 | bit_mask); |
| 665 | set_cr1(m_cr1 | bit_mask); |
| 1045 | 666 | } |
| 1046 | 667 | else |
| 1047 | 668 | { |
| 1048 | | set_cr1(device, m_cr1 & ~bit_mask); |
| 669 | set_cr1(m_cr1 & ~bit_mask); |
| 1049 | 670 | } |
| 1050 | 671 | } |
| 1051 | 672 | } |
| 1052 | 673 | |
| 1053 | | void apollo_graphics::set_cr3b(device_t *device, UINT8 data) |
| 674 | void apollo_graphics_15i::set_cr3b(UINT8 data) |
| 1054 | 675 | { |
| 1055 | 676 | m_cr3b = data; |
| 1056 | 677 | if ((data & 0x80) == 0) |
| r29175 | r29176 | |
| 1059 | 680 | UINT8 bit_mask = 1 << shift; |
| 1060 | 681 | if (data & 0x01) |
| 1061 | 682 | { |
| 1062 | | set_lut_cr(device, m_lut_control | bit_mask); |
| 683 | set_lut_cr(m_lut_control | bit_mask); |
| 1063 | 684 | } |
| 1064 | 685 | else |
| 1065 | 686 | { |
| 1066 | | set_lut_cr(device, m_lut_control & ~bit_mask); |
| 687 | set_lut_cr(m_lut_control & ~bit_mask); |
| 1067 | 688 | } |
| 1068 | 689 | } |
| 1069 | 690 | } |
| 1070 | 691 | |
| 1071 | | void apollo_graphics::set_lut_cr(device_t *device, UINT8 data) |
| 692 | void apollo_graphics_15i::set_lut_cr(UINT8 data) |
| 1072 | 693 | { |
| 1073 | 694 | UINT8 diffs = m_lut_control ^ data; |
| 1074 | 695 | m_lut_control = data; |
| 1075 | 696 | |
| 1076 | 697 | if ((diffs & LUT_CPAL_CS) && (data & LUT_CPAL_CS) != 0) |
| 1077 | 698 | { |
| 1078 | | DLOG1(("writing Color Graphics Controller: LUT_CPAL_CS Disabled")); |
| 699 | MLOG1(("writing Color Graphics Controller: LUT_CPAL_CS Disabled")); |
| 1079 | 700 | while (!m_lut_fifo->is_empty()) |
| 1080 | 701 | { |
| 1081 | 702 | m_bt458->write(m_lut_fifo->get(), LUT_C1_C0(m_lut_control)); |
| r29175 | r29176 | |
| 1084 | 705 | |
| 1085 | 706 | if ((diffs & LUT_FIFO_RST) && (data & LUT_FIFO_RST) == 0) |
| 1086 | 707 | { |
| 1087 | | DLOG1(("writing Color Graphics Controller: LUT_FIFO_RST Active")); |
| 708 | MLOG1(("writing Color Graphics Controller: LUT_FIFO_RST Active")); |
| 1088 | 709 | m_lut_fifo->reset(); |
| 1089 | 710 | m_sr |= SR_LUT_OK; |
| 1090 | 711 | } |
| 1091 | 712 | |
| 1092 | 713 | if ((diffs & LUT_FIFO_CS) && (data & LUT_FIFO_CS) == 0) |
| 1093 | 714 | { |
| 1094 | | DLOG1(("writing Color Graphics Controller: LUT_FIFO_CS Enabled")); |
| 715 | MLOG1(("writing Color Graphics Controller: LUT_FIFO_CS Enabled")); |
| 1095 | 716 | } |
| 1096 | 717 | |
| 1097 | 718 | if ((diffs & LUT_ST_LUK) && (data & LUT_ST_LUK) == 0) |
| 1098 | 719 | { |
| 1099 | | DLOG1(("writing Color Graphics Controller: LUT_ST_LUK Active")); |
| 720 | MLOG1(("writing Color Graphics Controller: LUT_ST_LUK Active")); |
| 1100 | 721 | m_sr &= ~SR_LUT_OK; |
| 1101 | 722 | } |
| 1102 | 723 | } |
| 1103 | 724 | |
| 1104 | | READ8_DEVICE_HANDLER( apollo_graphics::apollo_mcr_r ) |
| 725 | READ8_MEMBER( apollo_graphics_15i::apollo_mcr_r ) |
| 1105 | 726 | { |
| 1106 | 727 | UINT8 data; |
| 1107 | 728 | switch (offset & 0x407) |
| r29175 | r29176 | |
| 1140 | 761 | { |
| 1141 | 762 | if (offset == 0) |
| 1142 | 763 | status0 = data; |
| 1143 | | DLOG1(("reading Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 1))); |
| 764 | MLOG1(("reading Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 1))); |
| 1144 | 765 | } |
| 1145 | 766 | |
| 1146 | 767 | return data; |
| 1147 | 768 | } |
| 1148 | 769 | |
| 1149 | | WRITE8_DEVICE_HANDLER( apollo_graphics::apollo_mcr_w ) |
| 770 | WRITE8_MEMBER( apollo_graphics_15i::apollo_mcr_w ) |
| 1150 | 771 | { |
| 1151 | | DLOG1(("writing Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 0))); |
| 772 | MLOG1(("writing Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 0))); |
| 1152 | 773 | switch (offset & 0x407) |
| 1153 | 774 | { |
| 1154 | 775 | case 0: |
| r29175 | r29176 | |
| 1176 | 797 | m_cr0 = data; |
| 1177 | 798 | break; |
| 1178 | 799 | case 0x402: |
| 1179 | | set_cr1(device, data); |
| 800 | set_cr1(data); |
| 1180 | 801 | break; |
| 1181 | 802 | case 0x404: |
| 1182 | 803 | m_cr2 = data; |
| r29175 | r29176 | |
| 1187 | 808 | m_sr |= SR_R_M_W; |
| 1188 | 809 | break; |
| 1189 | 810 | case 0x406: |
| 1190 | | set_cr3a(device, data); |
| 811 | set_cr3a(data); |
| 1191 | 812 | break; |
| 1192 | 813 | case 0x407: // A/D Channel Register |
| 1193 | 814 | m_ad_pending = 1; |
| r29175 | r29176 | |
| 1196 | 817 | } |
| 1197 | 818 | } |
| 1198 | 819 | |
| 1199 | | void apollo_graphics::set_status_rmw() |
| 820 | void apollo_graphics_15i::set_status_rmw() |
| 1200 | 821 | { |
| 1201 | 822 | UINT8 plane, d_plane_bit; |
| 1202 | 823 | UINT32 rop_reg; |
| r29175 | r29176 | |
| 1225 | 846 | } |
| 1226 | 847 | } |
| 1227 | 848 | |
| 1228 | | UINT16 apollo_graphics::rop(UINT16 dest_data, UINT16 src_data, UINT8 plane) |
| 849 | UINT16 apollo_graphics_15i::rop(UINT16 dest_data, UINT16 src_data, UINT8 plane) |
| 1229 | 850 | { |
| 1230 | 851 | UINT16 src_data1 = src_data; |
| 1231 | 852 | if (m_cr1 & CR1_ROP_EN) |
| r29175 | r29176 | |
| 1285 | 906 | return src_data; |
| 1286 | 907 | } |
| 1287 | 908 | |
| 1288 | | void apollo_graphics::set_source_data(UINT32 offset) |
| 909 | void apollo_graphics_15i::set_source_data(UINT32 offset) |
| 1289 | 910 | { |
| 1290 | 911 | if (m_n_planes == 1 || (m_cr1 & CR1_AD_BIT)) |
| 1291 | 912 | { |
| r29175 | r29176 | |
| 1305 | 926 | } |
| 1306 | 927 | } |
| 1307 | 928 | |
| 1308 | | UINT32 apollo_graphics::get_source_data(UINT8 plane) |
| 929 | UINT32 apollo_graphics_15i::get_source_data(UINT8 plane) |
| 1309 | 930 | { |
| 1310 | 931 | UINT32 src_data; |
| 1311 | 932 | |
| r29175 | r29176 | |
| 1344 | 965 | return src_data; |
| 1345 | 966 | } |
| 1346 | 967 | |
| 1347 | | void apollo_graphics::blt(UINT32 dest_addr, UINT16 mem_mask) |
| 968 | void apollo_graphics_15i::blt(UINT32 dest_addr, UINT16 mem_mask) |
| 1348 | 969 | { |
| 1349 | 970 | UINT16 src_data, dest_data; |
| 1350 | 971 | UINT8 d_plane_bit; |
| r29175 | r29176 | |
| 1372 | 993 | Color graphics memory space at A0000 - BFFFF |
| 1373 | 994 | ***************************************************************************/ |
| 1374 | 995 | |
| 1375 | | READ16_DEVICE_HANDLER( apollo_graphics::apollo_mem_r ) |
| 996 | READ16_MEMBER( apollo_graphics_15i::apollo_mem_r ) |
| 1376 | 997 | { |
| 1377 | 998 | UINT16 data; |
| 1378 | 999 | UINT32 src_addr; |
| r29175 | r29176 | |
| 1380 | 1001 | if (offset >= m_image_memory_size) |
| 1381 | 1002 | { |
| 1382 | 1003 | // 128 kB display buffer of 15" screen seems to be shadowed from $fa0000 to $fc0000 |
| 1383 | | DLOG1(("reading Graphics Memory at invalid offset %05x", offset)); |
| 1004 | MLOG1(("reading Graphics Memory at invalid offset %05x", offset)); |
| 1384 | 1005 | offset %= m_image_memory_size; |
| 1385 | 1006 | } |
| 1386 | 1007 | |
| r29175 | r29176 | |
| 1402 | 1023 | // omit excessive logging |
| 1403 | 1024 | if ((offset & (m_image_plane_size - 1)) < 8) |
| 1404 | 1025 | { |
| 1405 | | DLOG1(("reading Graphics Memory with mode %d: src_addr %05x = %04x & %04x", CR0_MODE(m_cr0), src_addr, data, mem_mask)); |
| 1026 | MLOG1(("reading Graphics Memory with mode %d: src_addr %05x = %04x & %04x", CR0_MODE(m_cr0), src_addr, data, mem_mask)); |
| 1406 | 1027 | } |
| 1407 | 1028 | else if ((offset & (m_image_plane_size - 1)) == 8) |
| 1408 | 1029 | { |
| 1409 | | DLOG1(("...")); |
| 1030 | MLOG1(("...")); |
| 1410 | 1031 | } |
| 1411 | 1032 | return data; |
| 1412 | 1033 | } |
| 1413 | 1034 | |
| 1414 | | WRITE16_DEVICE_HANDLER( apollo_graphics::apollo_mem_w ) |
| 1035 | WRITE16_MEMBER( apollo_graphics_15i::apollo_mem_w ) |
| 1415 | 1036 | { |
| 1416 | 1037 | UINT32 dest_addr; |
| 1417 | 1038 | UINT32 src_addr; |
| r29175 | r29176 | |
| 1419 | 1040 | if (offset >= m_image_memory_size) |
| 1420 | 1041 | { |
| 1421 | 1042 | // 128 kB display buffer of 15" screen seems to be shadowed from $fa0000 to $fc0000 |
| 1422 | | DLOG1(("writing Graphics Memory at invalid offset %05x = %04x & %04x ", offset, data, mem_mask)); |
| 1043 | MLOG1(("writing Graphics Memory at invalid offset %05x = %04x & %04x ", offset, data, mem_mask)); |
| 1423 | 1044 | offset %= m_image_memory_size; |
| 1424 | 1045 | } |
| 1425 | 1046 | |
| 1426 | 1047 | // omit excessive logging |
| 1427 | 1048 | if (offset < 24) |
| 1428 | 1049 | { |
| 1429 | | DLOG1(("writing Graphics Memory with mode %d: offset=%04x data=%04x mask=%04x", CR0_MODE(m_cr0), offset, data, mem_mask)); |
| 1050 | MLOG1(("writing Graphics Memory with mode %d: offset=%04x data=%04x mask=%04x", CR0_MODE(m_cr0), offset, data, mem_mask)); |
| 1430 | 1051 | } |
| 1431 | 1052 | else if (offset == 24) |
| 1432 | 1053 | { |
| 1433 | | DLOG1(("...")); |
| 1054 | MLOG1(("...")); |
| 1434 | 1055 | } |
| 1435 | 1056 | |
| 1436 | 1057 | switch (CR0_MODE(m_cr0)) |
| r29175 | r29176 | |
| 1518 | 1139 | break; |
| 1519 | 1140 | |
| 1520 | 1141 | default: |
| 1521 | | DLOG(("writing Graphics Memory - unexpected cr0 mode %d", CR0_MODE(m_cr0))) |
| 1142 | MLOG(("writing Graphics Memory - unexpected cr0 mode %d", CR0_MODE(m_cr0))) |
| 1522 | 1143 | ; |
| 1523 | 1144 | break; |
| 1524 | 1145 | } |
| r29175 | r29176 | |
| 1529 | 1150 | Color Screen |
| 1530 | 1151 | ***************************************************************************/ |
| 1531 | 1152 | |
| 1532 | | READ8_DEVICE_HANDLER( apollo_graphics::apollo_ccr_r ) |
| 1153 | READ8_MEMBER( apollo_graphics_15i::apollo_ccr_r ) |
| 1533 | 1154 | { |
| 1534 | 1155 | UINT8 data; |
| 1535 | 1156 | |
| r29175 | r29176 | |
| 1544 | 1165 | data = m_ad_result; |
| 1545 | 1166 | break; |
| 1546 | 1167 | default: |
| 1547 | | return apollo_mcr_r(device, space, offset, mem_mask); |
| 1168 | return apollo_mcr_r(space, offset, mem_mask); |
| 1548 | 1169 | } |
| 1549 | 1170 | } |
| 1550 | 1171 | else if (m_n_planes == 8) |
| r29175 | r29176 | |
| 1569 | 1190 | } |
| 1570 | 1191 | else if ((m_lut_control & LUT_R_W) == 0) |
| 1571 | 1192 | { |
| 1572 | | DLOG1(("apollo_graphics::apollo_ccr_r: reading LUT data register with unexpected RW = 0 in LUT Control register")); |
| 1193 | MLOG1(("apollo_graphics_15i::apollo_ccr_r: reading LUT data register with unexpected RW = 0 in LUT Control register")); |
| 1573 | 1194 | data = m_lut_data; |
| 1574 | 1195 | } |
| 1575 | 1196 | else if ((m_lut_control & LUT_AD_CS) == 0) |
| r29175 | r29176 | |
| 1582 | 1203 | } |
| 1583 | 1204 | else |
| 1584 | 1205 | { |
| 1585 | | DLOG1(("apollo_graphics::apollo_ccr_r: reading LUT data register with unexpected CS in LUT Control register")); |
| 1206 | MLOG1(("apollo_graphics_15i::apollo_ccr_r: reading LUT data register with unexpected CS in LUT Control register")); |
| 1586 | 1207 | data = m_lut_data; |
| 1587 | 1208 | } |
| 1588 | 1209 | break; |
| r29175 | r29176 | |
| 1603 | 1224 | data = m_cr3b; |
| 1604 | 1225 | break; |
| 1605 | 1226 | default: |
| 1606 | | return apollo_mcr_r(device, space, offset, mem_mask); |
| 1227 | return apollo_mcr_r(space, offset, mem_mask); |
| 1607 | 1228 | } |
| 1608 | 1229 | } |
| 1609 | 1230 | else |
| r29175 | r29176 | |
| 1617 | 1238 | { |
| 1618 | 1239 | if (offset == 0) |
| 1619 | 1240 | status1 = data; |
| 1620 | | DLOG1(("reading Color Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 1))); |
| 1241 | MLOG1(("reading Color Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 1))); |
| 1621 | 1242 | } |
| 1622 | 1243 | |
| 1623 | 1244 | return data; |
| 1624 | 1245 | } |
| 1625 | 1246 | |
| 1626 | | UINT8 apollo_graphics::get_pixel(UINT32 offset, UINT16 mask) |
| 1247 | UINT8 apollo_graphics_15i::get_pixel(UINT32 offset, UINT16 mask) |
| 1627 | 1248 | { |
| 1628 | 1249 | UINT8 data = 0; |
| 1629 | 1250 | UINT16 *source_ptr = m_image_memory + offset; |
| r29175 | r29176 | |
| 1666 | 1287 | |
| 1667 | 1288 | // read the 4-plane ADC value for data |
| 1668 | 1289 | |
| 1669 | | UINT8 apollo_graphics::c4p_read_adc(UINT8 data) |
| 1290 | UINT8 apollo_graphics_15i::c4p_read_adc(UINT8 data) |
| 1670 | 1291 | { |
| 1671 | 1292 | UINT8 value = 0; |
| 1672 | 1293 | |
| r29175 | r29176 | |
| 1720 | 1341 | |
| 1721 | 1342 | // read the 8-plane ADC value for data |
| 1722 | 1343 | |
| 1723 | | UINT8 apollo_graphics::c8p_read_adc(UINT8 data) |
| 1344 | UINT8 apollo_graphics_15i::c8p_read_adc(UINT8 data) |
| 1724 | 1345 | { |
| 1725 | 1346 | UINT8 value = 0; |
| 1726 | 1347 | |
| r29175 | r29176 | |
| 1771 | 1392 | return value; |
| 1772 | 1393 | } |
| 1773 | 1394 | |
| 1774 | | WRITE8_DEVICE_HANDLER( apollo_graphics::apollo_ccr_w ) |
| 1395 | WRITE8_MEMBER( apollo_graphics_15i::apollo_ccr_w ) |
| 1775 | 1396 | { |
| 1776 | 1397 | static const UINT8 rgb_value[16] = |
| 1777 | 1398 | { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, |
| r29175 | r29176 | |
| 1812 | 1433 | m_sr |= SR_DONE; |
| 1813 | 1434 | break; |
| 1814 | 1435 | default: |
| 1815 | | apollo_mcr_w(device, space, offset, data, mem_mask); |
| 1436 | apollo_mcr_w(space, offset, data, mem_mask); |
| 1816 | 1437 | return; |
| 1817 | 1438 | } |
| 1818 | 1439 | } |
| r29175 | r29176 | |
| 1844 | 1465 | m_lut_data = data; |
| 1845 | 1466 | if ((m_lut_control & LUT_R_W) == 1) |
| 1846 | 1467 | { |
| 1847 | | DLOG1(("apollo_graphics::apollo_ccr_w: writing LUT data register with RW = 1 in LUT Control register")); |
| 1468 | MLOG1(("apollo_graphics_15i::apollo_ccr_w: writing LUT data register with RW = 1 in LUT Control register")); |
| 1848 | 1469 | } |
| 1849 | 1470 | else if ((m_lut_control & LUT_AD_CS) == 0) |
| 1850 | 1471 | { |
| r29175 | r29176 | |
| 1862 | 1483 | } |
| 1863 | 1484 | else |
| 1864 | 1485 | { |
| 1865 | | DLOG1(("apollo_graphics::apollo_ccr_w: writing LUT data register with unexpected CS in LUT Control register")); |
| 1486 | MLOG1(("apollo_graphics_15i::apollo_ccr_w: writing LUT data register with unexpected CS in LUT Control register")); |
| 1866 | 1487 | } |
| 1867 | 1488 | break; |
| 1868 | 1489 | case 0x403: |
| 1869 | 1490 | // LUT control register |
| 1870 | | set_lut_cr(device, data); |
| 1491 | set_lut_cr(data); |
| 1871 | 1492 | break; |
| 1872 | 1493 | case 0x404: |
| 1873 | 1494 | // cr2a |
| r29175 | r29176 | |
| 1883 | 1504 | break; |
| 1884 | 1505 | case 0x407: |
| 1885 | 1506 | // cr3b |
| 1886 | | set_cr3b(device, data); |
| 1507 | set_cr3b(data); |
| 1887 | 1508 | break; |
| 1888 | 1509 | default: |
| 1889 | | apollo_mcr_w(device, space, offset, data, mem_mask); |
| 1510 | apollo_mcr_w(space, offset, data, mem_mask); |
| 1890 | 1511 | return; |
| 1891 | 1512 | } |
| 1892 | 1513 | } |
| 1893 | 1514 | |
| 1894 | | DLOG1(("writing Color Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 0))); |
| 1515 | MLOG1(("writing Color Graphics Controller at offset %03x = %02x (%s)", offset, data, cr_text(offset, data, 0))); |
| 1895 | 1516 | } |
| 1896 | 1517 | |
| 1897 | | READ16_DEVICE_HANDLER( apollo_cgm_r ) |
| 1518 | READ16_MEMBER( apollo_graphics_15i::apollo_cgm_r ) |
| 1898 | 1519 | { |
| 1899 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 1900 | | if (!apollo_graphics->is_mono()) |
| 1520 | if (!is_mono()) |
| 1901 | 1521 | { |
| 1902 | | return apollo_graphics->apollo_mem_r(device, space, offset, mem_mask); |
| 1522 | return apollo_mem_r(space, offset, mem_mask); |
| 1903 | 1523 | } |
| 1904 | 1524 | else |
| 1905 | 1525 | { |
| r29175 | r29176 | |
| 1907 | 1527 | } |
| 1908 | 1528 | } |
| 1909 | 1529 | |
| 1910 | | WRITE16_DEVICE_HANDLER( apollo_cgm_w ) |
| 1530 | WRITE16_MEMBER( apollo_graphics_15i::apollo_cgm_w ) |
| 1911 | 1531 | { |
| 1912 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 1913 | | if (!apollo_graphics->is_mono()) |
| 1532 | if (!is_mono()) |
| 1914 | 1533 | { |
| 1915 | | apollo_graphics->apollo_mem_w(device, space, offset, data, mem_mask); |
| 1534 | apollo_mem_w(space, offset, data, mem_mask); |
| 1916 | 1535 | } |
| 1917 | 1536 | } |
| 1918 | 1537 | |
| r29175 | r29176 | |
| 1920 | 1539 | VIDEO HARDWARE |
| 1921 | 1540 | ***************************************************************************/ |
| 1922 | 1541 | |
| 1923 | | UINT32 apollo_graphics::screen_update(bitmap_rgb32 &bitmap, |
| 1924 | | const rectangle &cliprect) |
| 1542 | UINT32 apollo_graphics_15i::screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect) |
| 1925 | 1543 | { |
| 1926 | 1544 | int has_changed = 0; |
| 1927 | 1545 | |
| r29175 | r29176 | |
| 1936 | 1554 | return has_changed ? 0 : UPDATE_HAS_NOT_CHANGED; |
| 1937 | 1555 | } |
| 1938 | 1556 | |
| 1939 | | void apollo_graphics::screen_update1(bitmap_rgb32 &bitmap, |
| 1940 | | const rectangle &cliprect) |
| 1557 | void apollo_graphics_15i::screen_update1(bitmap_rgb32 &bitmap, const rectangle &cliprect) |
| 1941 | 1558 | { |
| 1942 | 1559 | UINT16 *source_ptr = m_image_memory; |
| 1943 | 1560 | int x, y; |
| r29175 | r29176 | |
| 2041 | 1658 | called on each state change of the VBLANK signal |
| 2042 | 1659 | -------------------------------------------------*/ |
| 2043 | 1660 | |
| 2044 | | void apollo_graphics::vblank_state_changed(device_t *device, |
| 2045 | | screen_device &screen, bool vblank_state) |
| 1661 | void apollo_graphics_15i::vblank_state_changed(screen_device &screen, bool vblank_state) |
| 2046 | 1662 | { |
| 2047 | 1663 | if ((m_cr1 & CR1_RESET) && (m_cr1 & CR1_SYNC_EN)) |
| 2048 | 1664 | { |
| r29175 | r29176 | |
| 2077 | 1693 | } |
| 2078 | 1694 | } |
| 2079 | 1695 | |
| 2080 | | void vblank_state_changed(device_t *device, screen_device &screen, |
| 2081 | | bool vblank_state) |
| 1696 | void apollo_graphics_15i::register_vblank_callback() |
| 2082 | 1697 | { |
| 2083 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 2084 | | apollo_graphics->vblank_state_changed(device, screen, vblank_state); |
| 2085 | | } |
| 1698 | MLOG1(("register_vblank_callback")); |
| 2086 | 1699 | |
| 2087 | | static void register_vblank_callback(device_t *device) |
| 2088 | | { |
| 2089 | | DLOG1(("register_vblank_callback")); |
| 2090 | | |
| 2091 | 1700 | /* register for VBLANK callbacks */ |
| 2092 | | screen_device *screen = (screen_device *) device->machine().device( |
| 2093 | | VIDEO_SCREEN_TAG); |
| 2094 | | screen->register_vblank_callback(vblank_state_delegate( |
| 2095 | | FUNC(vblank_state_changed),device) ); |
| 1701 | screen_device *screen = (screen_device *)machine().device(VIDEO_SCREEN_TAG); |
| 1702 | screen->register_vblank_callback(vblank_state_delegate(FUNC(apollo_graphics_15i::vblank_state_changed),this)); |
| 2096 | 1703 | } |
| 2097 | 1704 | |
| 2098 | | UINT32 apollo_graphics_15i::screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect) |
| 2099 | | { |
| 2100 | | apollo_graphics *apollo_graphics = get_safe_token(this); |
| 2101 | | return apollo_graphics->screen_update(bitmap, cliprect); |
| 2102 | | } |
| 2103 | 1705 | |
| 2104 | 1706 | /*************************************************************************** |
| 2105 | 1707 | MACHINE DRIVERS |
| r29175 | r29176 | |
| 2118 | 1720 | |
| 2119 | 1721 | const device_type APOLLO_GRAPHICS = &device_creator<apollo_graphics_15i> ; |
| 2120 | 1722 | |
| 2121 | | apollo_graphics_15i::apollo_graphics_15i(const machine_config &mconfig, |
| 2122 | | const char *tag, device_t *owner, UINT32 clock) : |
| 2123 | | device_t(mconfig, APOLLO_GRAPHICS, "Apollo Screen", tag, owner, clock, |
| 2124 | | "apollo_graphics_15i", __FILE__) |
| 1723 | apollo_graphics_15i::apollo_graphics_15i(const machine_config &mconfig,const char *tag, device_t *owner, UINT32 clock) : |
| 1724 | device_t(mconfig, APOLLO_GRAPHICS, "Apollo Screen", tag, owner, clock,"apollo_graphics_15i", __FILE__), |
| 1725 | m_lut_fifo(NULL), |
| 1726 | m_bt458(NULL) |
| 2125 | 1727 | { |
| 2126 | | m_token = new apollo_graphics; |
| 1728 | |
| 2127 | 1729 | } |
| 2128 | 1730 | |
| 2129 | | apollo_graphics_15i::apollo_graphics_15i(const machine_config &mconfig, |
| 2130 | | const char *tag, device_t *owner, UINT32 clock, device_type type, |
| 2131 | | const char *name, const char *shortname, const char *source) : |
| 2132 | | device_t(mconfig, type, name, tag, owner, clock, shortname, source) |
| 1731 | apollo_graphics_15i::apollo_graphics_15i(const machine_config &mconfig,const char *tag, device_t *owner, UINT32 clock, device_type type,const char *name, const char *shortname, const char *source) : |
| 1732 | device_t(mconfig, type, name, tag, owner, clock, shortname, source), |
| 1733 | m_lut_fifo(NULL), |
| 1734 | m_bt458(NULL) |
| 2133 | 1735 | { |
| 2134 | | m_token = new apollo_graphics; |
| 2135 | 1736 | } |
| 2136 | 1737 | |
| 2137 | 1738 | apollo_graphics_15i::~apollo_graphics_15i() |
| 2138 | 1739 | { |
| 2139 | | global_free(m_token); |
| 1740 | if (m_lut_fifo) global_free(m_lut_fifo); |
| 1741 | if (m_bt458) global_free(m_bt458); |
| 2140 | 1742 | } |
| 2141 | 1743 | |
| 2142 | 1744 | //------------------------------------------------- |
| r29175 | r29176 | |
| 2157 | 1759 | { |
| 2158 | 1760 | MLOG1(("apollo_graphics_15i::device_start")) |
| 2159 | 1761 | |
| 2160 | | apollo_graphics *apollo_graphics = get_safe_token(this); |
| 2161 | | apollo_graphics->device_start(machine()); |
| 1762 | m_n_planes = 0; |
| 1763 | m_width = 0; |
| 1764 | m_height = 0; |
| 1765 | m_buffer_width = 0; |
| 1766 | m_buffer_height = 0; |
| 1767 | |
| 1768 | m_sr = 0; |
| 1769 | m_device_id = 0; |
| 1770 | m_write_enable_register = 0; |
| 1771 | m_rop_register = 0; |
| 1772 | m_diag_mem_request = 0; |
| 1773 | m_cr0 = 0; |
| 1774 | m_cr1 = 0; |
| 1775 | m_cr2 = 0; |
| 1776 | m_cr2b = 0; |
| 1777 | m_cr2_s_data = 0; |
| 1778 | m_cr2_s_plane = 0x00; |
| 1779 | m_cr2_d_plane = 0x0e; |
| 1780 | m_cr3a = 0; |
| 1781 | m_cr3b = 0; |
| 1782 | m_ad_result = 0; |
| 1783 | m_ad_pending = 0; |
| 1784 | |
| 1785 | m_lut_control = 0; |
| 1786 | m_lut_data = 0; |
| 1787 | |
| 1788 | m_update_flag = 0; |
| 1789 | m_update_pending = 0; |
| 1790 | |
| 1791 | m_blt_cycle_count = 0; |
| 1792 | m_image_offset = 0; |
| 1793 | memset(m_guard_latch, 0, sizeof(m_guard_latch)); |
| 1794 | |
| 1795 | m_h_clock = 0; |
| 1796 | m_v_clock = 0; |
| 1797 | m_p_clock = 0; |
| 1798 | m_data_clock = 0; |
| 1799 | |
| 1800 | m_image_memory = 0; |
| 1801 | m_image_plane_size = 0; |
| 1802 | m_image_memory_size = 0; |
| 1803 | |
| 1804 | memset(m_color_lookup_table, 0, sizeof(m_color_lookup_table)); |
| 1805 | |
| 1806 | m_lut_fifo = NULL; |
| 1807 | m_bt458 = NULL; |
| 2162 | 1808 | } |
| 2163 | 1809 | |
| 2164 | 1810 | //------------------------------------------------- |
| r29175 | r29176 | |
| 2169 | 1815 | { |
| 2170 | 1816 | MLOG1(("apollo_graphics_15i::device_reset")); |
| 2171 | 1817 | |
| 2172 | | apollo_graphics *apollo_graphics = get_safe_token(this); |
| 2173 | | apollo_graphics->device_reset(); |
| 1818 | if (m_n_planes == 0) |
| 1819 | { |
| 1820 | if (apollo_config(APOLLO_CONF_MONO_19I)) |
| 1821 | { |
| 1822 | // monochrome 1280x1024 |
| 1823 | m_n_planes = 1; |
| 1824 | m_device_id = SCREEN_DEVICE_ID_19I; |
| 1825 | m_width = 1280; |
| 1826 | m_height = 1024; |
| 1827 | m_buffer_width = 2048; |
| 1828 | m_buffer_height = 1024; |
| 1829 | } |
| 1830 | else if (apollo_config(APOLLO_CONF_MONO_15I)) |
| 1831 | { |
| 1832 | // monochrome 1024x800 |
| 1833 | m_n_planes = 1; |
| 1834 | m_device_id = SCREEN_DEVICE_ID_15I; |
| 1835 | m_width = 1024; |
| 1836 | m_height = 800; |
| 1837 | m_buffer_width = 1024; |
| 1838 | m_buffer_height = 1024; |
| 1839 | } |
| 1840 | else if (apollo_config(APOLLO_CONF_4_PLANES)) |
| 1841 | { |
| 1842 | // 4-planes color 1024x800 |
| 1843 | m_n_planes = 4; |
| 1844 | m_device_id = SCREEN_DEVICE_ID_C4P; |
| 1845 | m_width = 1024; |
| 1846 | m_height = 800; |
| 1847 | m_buffer_width = 1024; |
| 1848 | m_buffer_height = 1024; |
| 1849 | } |
| 1850 | else |
| 1851 | { |
| 1852 | // 8-planes color 1024x800 |
| 1853 | m_n_planes = 8; |
| 1854 | m_device_id = SCREEN_DEVICE_ID_C8P; |
| 1855 | m_width = 1024; |
| 1856 | m_height = 800; |
| 1857 | m_buffer_width = 1024; |
| 1858 | m_buffer_height = 1024; |
| 2174 | 1859 | |
| 2175 | | /* FIXME: register for VBLANK callbacks */ |
| 2176 | | register_vblank_callback(this); |
| 2177 | | } |
| 1860 | if (m_lut_fifo) global_free(m_lut_fifo); |
| 1861 | if (m_bt458) global_free(m_bt458); |
| 2178 | 1862 | |
| 2179 | | READ8_DEVICE_HANDLER( apollo_ccr_r ) |
| 2180 | | { |
| 2181 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 2182 | | return apollo_graphics->apollo_ccr_r(device, space, offset, mem_mask); |
| 2183 | | } |
| 1863 | m_lut_fifo = global_alloc(lut_fifo); |
| 2184 | 1864 | |
| 2185 | | WRITE8_DEVICE_HANDLER( apollo_ccr_w ) |
| 2186 | | { |
| 2187 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 2188 | | apollo_graphics->apollo_ccr_w(device, space, offset, data, mem_mask); |
| 1865 | m_bt458 = global_alloc(bt458(machine())); |
| 1866 | m_bt458->start(); |
| 1867 | m_bt458->reset(); |
| 1868 | } |
| 1869 | } |
| 1870 | |
| 1871 | if (m_image_memory == NULL) |
| 1872 | { |
| 1873 | /* allocate the memory image */ |
| 1874 | m_image_plane_size = m_buffer_height * m_buffer_width / 16; |
| 1875 | m_image_memory_size = m_image_plane_size * m_n_planes; |
| 1876 | m_image_memory |
| 1877 | = auto_alloc_array(machine(), UINT16, m_image_memory_size); |
| 1878 | assert(m_image_memory != NULL); |
| 1879 | |
| 1880 | MLOG1(("device reset apollo graphics: buffer=%p size=%0x", m_image_memory, m_image_memory_size)); |
| 1881 | } |
| 1882 | |
| 1883 | memset(m_color_lookup_table, 0, sizeof(m_color_lookup_table)); |
| 1884 | memset(m_image_memory, 0, m_image_memory_size * 2); |
| 1885 | |
| 1886 | // register_vblank_callback(this); |
| 1887 | |
| 1888 | /* FIXME: register for VBLANK callbacks */ |
| 1889 | register_vblank_callback(); |
| 2189 | 1890 | } |
| 2190 | 1891 | |
| 2191 | 1892 | //------------------------------------------------- |
| r29175 | r29176 | |
| 2240 | 1941 | { |
| 2241 | 1942 | MLOG1(("apollo_graphics_19i::device_reset")); |
| 2242 | 1943 | |
| 2243 | | apollo_graphics *apollo_graphics = get_safe_token(this); |
| 2244 | | apollo_graphics->device_reset_mono19i(); |
| 1944 | if (m_n_planes == 0) |
| 1945 | { |
| 1946 | // monochrome 1280x1024 |
| 1947 | m_n_planes = 1; |
| 1948 | m_device_id = SCREEN_DEVICE_ID_19I; |
| 1949 | m_width = 1280; |
| 1950 | m_height = 1024; |
| 1951 | m_buffer_width = 2048; |
| 1952 | m_buffer_height = 1024; |
| 1953 | } |
| 2245 | 1954 | |
| 1955 | apollo_graphics_15i::device_reset(); |
| 1956 | |
| 2246 | 1957 | /* FIXME: register for VBLANK callbacks */ |
| 2247 | | register_vblank_callback(this); |
| 1958 | register_vblank_callback(); |
| 2248 | 1959 | } |
| 2249 | 1960 | |
| 2250 | | READ8_DEVICE_HANDLER( apollo_mcr_r ) |
| 2251 | | { |
| 2252 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 2253 | | return apollo_graphics->apollo_mcr_r(device, space, offset, mem_mask); |
| 2254 | | } |
| 2255 | 1961 | |
| 2256 | | WRITE8_DEVICE_HANDLER( apollo_mcr_w ) |
| 2257 | | { |
| 2258 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 2259 | | apollo_graphics->apollo_mcr_w(device, space, offset, data, mem_mask); |
| 2260 | | } |
| 2261 | | |
| 2262 | | READ16_DEVICE_HANDLER( apollo_mgm_r ) |
| 2263 | | { |
| 2264 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 2265 | | if (apollo_graphics->is_mono()) |
| 1962 | READ16_MEMBER( apollo_graphics_15i::apollo_mgm_r ) |
| 1963 | { |
| 1964 | if (is_mono()) |
| 2266 | 1965 | { |
| 2267 | | return apollo_graphics->apollo_mem_r(device, space, offset, mem_mask); |
| 1966 | return apollo_mem_r(space, offset, mem_mask); |
| 2268 | 1967 | } |
| 2269 | 1968 | else |
| 2270 | 1969 | { |
| r29175 | r29176 | |
| 2272 | 1971 | } |
| 2273 | 1972 | } |
| 2274 | 1973 | |
| 2275 | | WRITE16_DEVICE_HANDLER( apollo_mgm_w ) |
| 1974 | WRITE16_MEMBER( apollo_graphics_15i::apollo_mgm_w ) |
| 2276 | 1975 | { |
| 2277 | | apollo_graphics *apollo_graphics = get_safe_token(device); |
| 2278 | | if (apollo_graphics->is_mono()) |
| 1976 | if (is_mono()) |
| 2279 | 1977 | { |
| 2280 | | apollo_graphics->apollo_mem_w(device, space, offset, data, mem_mask); |
| 1978 | apollo_mem_w(space, offset, data, mem_mask); |
| 2281 | 1979 | } |
| 2282 | 1980 | } |