From 880fda32f53c1af27beef8c82f0be7d31b03e821 Mon Sep 17 00:00:00 2001 From: Endprodukt Date: Wed, 3 Dec 2025 08:00:55 +0100 Subject: [PATCH 1/6] update --- src/mame/sega/model2.cpp | 133 +++++++++++++++++++++++++++++---------- src/mame/sega/model2.h | 8 ++- 2 files changed, 108 insertions(+), 33 deletions(-) diff --git a/src/mame/sega/model2.cpp b/src/mame/sega/model2.cpp index 0b290aa57e912..931533c72164b 100644 --- a/src/mame/sega/model2.cpp +++ b/src/mame/sega/model2.cpp @@ -143,6 +143,9 @@ void model2_state::machine_start() // initialize custom debugger pool, @see machine/model2.cpp debug_init(); + m_lamps.resolve(); + m_wheel_motor.resolve(); + save_item(NAME(m_intreq)); save_item(NAME(m_intena)); save_item(NAME(m_coproctl)); @@ -1172,48 +1175,92 @@ u8 model2_state::lightgun_offscreen_r(offs_t offset) //************************************************************************** // OUTPUTS //************************************************************************** - -void model2o_state::daytona_output_w(u8 data) -{ - // 7------- leader led - // -6------ vr4 led - // --5----- vr3 led - // ---4---- vr2 led - // ----3--- vr1 led - // -----2-- start led + // Daytona Output + // 7------- leader lamp + // -6------ vr4 lamp + // --5----- vr3 lamp + // ---4---- vr2 lamp + // ----3--- vr1 lamp + // -----2-- start lamp // ------1- coin counter 2 // -------0 coin counter 1 - machine().bookkeeping().coin_counter_w(1, BIT(data, 1)); - machine().bookkeeping().coin_counter_w(0, BIT(data, 0)); -} - -void model2o_state::desert_output_w(u8 data) -{ + // Desert Output // 7------- cannon motor // -6------ machine gun motor - // --5----- vr1 - // ---4---- vr2 - // ----3--- vr3 - // -----2-- start + // --5----- vr1 lamp + // ---4---- vr2 lamp + // ----3--- vr3 lamp + // -----2-- start lamp // ------1- coin counter 2 // -------0 coin counter 1 - machine().bookkeeping().coin_counter_w(1, BIT(data, 1)); - machine().bookkeeping().coin_counter_w(0, BIT(data, 0)); -} - -void model2o_state::vcop_output_w(u8 data) -{ + // Vcop Output // 7654---- unknown (not used?) - // ----32-- start leds (always set together) + // ----32-- start lamps (always set together) // ------1- coin counter 2 // -------0 coin counter 1 - machine().bookkeeping().coin_counter_w(1, BIT(~data, 1)); - machine().bookkeeping().coin_counter_w(0, BIT(~data, 0)); -} + // Srallyc Output + // 7------- leader lamp + // -6------ unknown + // --5----- vr lamp + // ---4---- unknown + // ----3--- unknown + // -----2-- start lamp + // ------1- coin counter 2 + // -------0 coin counter 1 + // STCC Output + // 7------- unknown + // -6------ unknown + // --5----- view 2 (zoom out) lamp + // ---4---- view 1 (zoom in) lamp + // ----3--- rev max lamp + // -----2-- start lamp + // ------1- coin counter 2 + // -------0 coin counter 1 + + // Indy500 Output + // 7------- race leader lamp + // -6------ unknown + // --5----- view 2 (zoom out) lamp + // ---4---- view 1 (zoom in) lamp + // ----3--- unknown + // -----2-- start lamp + // ------1- coin counter 2 + // -------0 coin counter 1 + + // Overrev Output + // 7------- unknown + // -6------ unknown + // --5----- view 2 lamp + // ---4---- view 1 lamp + // ----3--- unknown + // -----2-- start lamp + // ------1- coin counter 2 + // -------0 coin counter 1 + + // Sgt24h Output + // 7------- unknown + // -6------ unknown + // --5----- view 2 lamp + // ---4---- view 1 lamp + // ----3--- unknown + // -----2-- start lamp + // ------1- coin counter 2 + // -------0 coin counter 1 + +void model2_state::lamp_output_w(u8 data) +{ + // Coin counters + machine().bookkeeping().coin_counter_w(0, BIT(data, 0)); + machine().bookkeeping().coin_counter_w(1, BIT(data, 1)); + + // Lamps (bits 2–7) + for (int i = 0; i < 6; i++) + m_lamps[i] = BIT(data, i + 2); +} //************************************************************************** // I/O BOARD @@ -1527,6 +1574,7 @@ void model2_state::rchase2_drive_board_w(u8 data) void model2_state::drive_board_w(u8 data) { + m_wheel_motor = data; m_driveio_comm_data = data; m_drivecpu->set_input_line(0, HOLD_LINE); } @@ -2623,7 +2671,7 @@ void model2o_state::daytona(machine_config &config) ioboard.an_callback<0>().set_ioport("STEER"); ioboard.an_callback<1>().set_ioport("ACCEL"); ioboard.an_callback<2>().set_ioport("BRAKE"); - ioboard.output_callback().set(FUNC(model2o_state::daytona_output_w)); + ioboard.output_callback().set(FUNC(model2_state::lamp_output_w)); } void model2o_maxx_state::daytona_maxx(machine_config &config) @@ -2648,7 +2696,7 @@ void model2o_state::desert(machine_config &config) ioboard.an_callback<0>().set_ioport("STEER"); ioboard.an_callback<1>().set_ioport("ACCEL"); ioboard.an_callback<2>().set_ioport("BRAKE"); - ioboard.output_callback().set(FUNC(model2o_state::desert_output_w)); + ioboard.output_callback().set(FUNC(model2_state::lamp_output_w)); } void model2o_state::vcop(machine_config &config) @@ -2662,7 +2710,7 @@ void model2o_state::vcop(machine_config &config) ioboard.in_callback<0>().set_ioport("IN0"); ioboard.in_callback<1>().set_ioport("IN1"); ioboard.in_callback<2>().set_ioport("IN2"); - ioboard.output_callback().set(FUNC(model2o_state::vcop_output_w)); + ioboard.output_callback().set(FUNC(model2_state::lamp_output_w)); ioboard.set_lightgun_p1x_tag("P1_X"); ioboard.set_lightgun_p1y_tag("P1_Y"); ioboard.set_lightgun_p2x_tag("P2_X"); @@ -2748,6 +2796,7 @@ void model2a_state::srallyc(machine_config &config) sega_315_5649_device &io(*subdevice("io")); io.out_pe_callback().set(FUNC(model2a_state::drive_board_w)); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); @@ -2831,6 +2880,7 @@ void model2b_state::model2b(machine_config &config) io.in_pd_callback().set_ioport("IN2"); io.in_pg_callback().set_ioport("SW"); io.out_pe_callback().set([this] (u8 data) { m_billboard->write(data); }); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); model2_timers(config); model2_screen(config); @@ -2868,6 +2918,8 @@ void model2b_state::indy500(machine_config &config) model2b(config); sega_315_5649_device &io(*subdevice("io")); + io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); @@ -2878,6 +2930,20 @@ void model2b_state::overrev2b(machine_config &config) model2b(config); sega_315_5649_device &io(*subdevice("io")); + io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); + io.an_port_callback<0>().set_ioport("STEER"); + io.an_port_callback<1>().set_ioport("ACCEL"); + io.an_port_callback<2>().set_ioport("BRAKE"); +} + +void model2b_state::sgt24h(machine_config& config) +{ + model2b(config); + + sega_315_5649_device& io(*subdevice("io")); + io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); @@ -2979,6 +3045,7 @@ void model2c_state::model2c(machine_config &config) io.in_pc_callback().set_ioport("IN1"); io.in_pd_callback().set_ioport("IN2"); io.in_pg_callback().set_ioport("SW"); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); model2_timers(config); model2_screen(config); @@ -3001,6 +3068,7 @@ void model2c_state::stcc(machine_config &config) model2c(config); sega_315_5649_device &io(*subdevice("io")); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); @@ -3058,6 +3126,7 @@ void model2c_state::overrev2c(machine_config &config) model2c(config); sega_315_5649_device &io(*subdevice("io")); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); diff --git a/src/mame/sega/model2.h b/src/mame/sega/model2.h index 4d1fdfa67638a..6fefda1b43e14 100644 --- a/src/mame/sega/model2.h +++ b/src/mame/sega/model2.h @@ -72,7 +72,9 @@ class model2_state : public driver_device m_copro_data(*this, "copro_data"), m_in0(*this, "IN0"), m_gears(*this, "GEARS"), - m_lightgun_ports(*this, {"P1_Y", "P1_X", "P2_Y", "P2_X"}) + m_lightgun_ports(*this, {"P1_Y", "P1_X", "P2_Y", "P2_X"}), + m_lamps(*this, "lamp%u", 0U), + m_wheel_motor(*this, "wheel_motor") { } /* Public for access by the rendering functions */ @@ -101,6 +103,7 @@ class model2_state : public driver_device void init_sgt24h(); void init_srallyc(); void init_powsledm(); + void lamp_output_w(u8 data); protected: virtual void machine_start() override ATTR_COLD; @@ -135,6 +138,8 @@ class model2_state : public driver_device required_ioport m_in0; optional_ioport m_gears; optional_ioport_array<4> m_lightgun_ports; + output_finder<6> m_lamps; + output_finder<> m_wheel_motor; u32 m_timervals[4]{}; u32 m_timerorig[4]{}; @@ -531,6 +536,7 @@ class model2b_state : public model2_state void gunblade(machine_config &config); void dynabb(machine_config &config); void zerogun(machine_config &config); + void sgt24h(machine_config& config); protected: virtual void machine_start() override ATTR_COLD; From 20639b69bd00f42677f365d7939be16b2da6f5e1 Mon Sep 17 00:00:00 2001 From: Endprodukt Date: Wed, 3 Dec 2025 18:10:30 +0100 Subject: [PATCH 2/6] ffb --- src/mame/sega/model2.cpp | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/src/mame/sega/model2.cpp b/src/mame/sega/model2.cpp index 931533c72164b..2d0f346c09b13 100644 --- a/src/mame/sega/model2.cpp +++ b/src/mame/sega/model2.cpp @@ -1576,10 +1576,10 @@ void model2_state::drive_board_w(u8 data) { m_wheel_motor = data; m_driveio_comm_data = data; - m_drivecpu->set_input_line(0, HOLD_LINE); + if (m_drivecpu) + m_drivecpu->set_input_line(0, HOLD_LINE); } - //************************************************************************** // INPUT HANDLING //************************************************************************** @@ -2744,6 +2744,7 @@ void model2a_state::model2a(machine_config &config) io.in_pd_callback().set_ioport("IN2"); io.in_pg_callback().set_ioport("SW"); io.out_pe_callback().set([this] (u8 data) { m_billboard->write(data); }); + io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); model2_timers(config); model2_screen(config); @@ -2919,7 +2920,6 @@ void model2b_state::indy500(machine_config &config) sega_315_5649_device &io(*subdevice("io")); io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); - io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); @@ -2931,7 +2931,6 @@ void model2b_state::overrev2b(machine_config &config) sega_315_5649_device &io(*subdevice("io")); io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); - io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); @@ -2943,7 +2942,6 @@ void model2b_state::sgt24h(machine_config& config) sega_315_5649_device& io(*subdevice("io")); io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); - io.out_pf_callback().set(FUNC(model2_state::lamp_output_w)); io.an_port_callback<0>().set_ioport("STEER"); io.an_port_callback<1>().set_ioport("ACCEL"); io.an_port_callback<2>().set_ioport("BRAKE"); From fe3cfc62f2f2d7b592e612114b3cd62a69dfb86f Mon Sep 17 00:00:00 2001 From: Endprodukt Date: Wed, 3 Dec 2025 18:21:41 +0100 Subject: [PATCH 3/6] remove wheel, only lamps. --- src/mame/sega/model2.cpp | 4 +--- src/mame/sega/model2.h | 6 ++---- 2 files changed, 3 insertions(+), 7 deletions(-) diff --git a/src/mame/sega/model2.cpp b/src/mame/sega/model2.cpp index 2d0f346c09b13..9c165bde10ca8 100644 --- a/src/mame/sega/model2.cpp +++ b/src/mame/sega/model2.cpp @@ -144,8 +144,7 @@ void model2_state::machine_start() debug_init(); m_lamps.resolve(); - m_wheel_motor.resolve(); - + save_item(NAME(m_intreq)); save_item(NAME(m_intena)); save_item(NAME(m_coproctl)); @@ -1574,7 +1573,6 @@ void model2_state::rchase2_drive_board_w(u8 data) void model2_state::drive_board_w(u8 data) { - m_wheel_motor = data; m_driveio_comm_data = data; if (m_drivecpu) m_drivecpu->set_input_line(0, HOLD_LINE); diff --git a/src/mame/sega/model2.h b/src/mame/sega/model2.h index 6fefda1b43e14..0b540df7f4a59 100644 --- a/src/mame/sega/model2.h +++ b/src/mame/sega/model2.h @@ -73,8 +73,7 @@ class model2_state : public driver_device m_in0(*this, "IN0"), m_gears(*this, "GEARS"), m_lightgun_ports(*this, {"P1_Y", "P1_X", "P2_Y", "P2_X"}), - m_lamps(*this, "lamp%u", 0U), - m_wheel_motor(*this, "wheel_motor") + m_lamps(*this, "lamp%u", 0U) { } /* Public for access by the rendering functions */ @@ -139,8 +138,7 @@ class model2_state : public driver_device optional_ioport m_gears; optional_ioport_array<4> m_lightgun_ports; output_finder<6> m_lamps; - output_finder<> m_wheel_motor; - + u32 m_timervals[4]{}; u32 m_timerorig[4]{}; int m_timerrun[4]{}; From 185ce6993feb09326a1ffc4bd24eecbe8c9dbc82 Mon Sep 17 00:00:00 2001 From: hap Date: Thu, 4 Dec 2025 11:25:02 +0100 Subject: [PATCH 4/6] remove duplicated mcfg 1/2 --- src/mame/sega/model2.h | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/mame/sega/model2.h b/src/mame/sega/model2.h index 0b540df7f4a59..bd84f8d2e2367 100644 --- a/src/mame/sega/model2.h +++ b/src/mame/sega/model2.h @@ -528,13 +528,11 @@ class model2b_state : public model2_state void model2b_0229(machine_config &config); void model2b_5881(machine_config &config); void indy500(machine_config &config); - void overrev2b(machine_config &config); void powsled(machine_config &config); void rchase2(machine_config &config); void gunblade(machine_config &config); void dynabb(machine_config &config); void zerogun(machine_config &config); - void sgt24h(machine_config& config); protected: virtual void machine_start() override ATTR_COLD; From 5df3760526c5cc19611a92e4d6168dd080c8f380 Mon Sep 17 00:00:00 2001 From: hap Date: Thu, 4 Dec 2025 11:31:46 +0100 Subject: [PATCH 5/6] remove duplicated mcfg 2/2, small cleanup --- src/mame/sega/model2.cpp | 192 ++++++++++++++++++--------------------- 1 file changed, 86 insertions(+), 106 deletions(-) diff --git a/src/mame/sega/model2.cpp b/src/mame/sega/model2.cpp index 9c165bde10ca8..6c8c9228a4f84 100644 --- a/src/mame/sega/model2.cpp +++ b/src/mame/sega/model2.cpp @@ -1174,81 +1174,84 @@ u8 model2_state::lightgun_offscreen_r(offs_t offset) //************************************************************************** // OUTPUTS //************************************************************************** - // Daytona Output - // 7------- leader lamp - // -6------ vr4 lamp - // --5----- vr3 lamp - // ---4---- vr2 lamp - // ----3--- vr1 lamp - // -----2-- start lamp - // ------1- coin counter 2 - // -------0 coin counter 1 - - // Desert Output - // 7------- cannon motor - // -6------ machine gun motor - // --5----- vr1 lamp - // ---4---- vr2 lamp - // ----3--- vr3 lamp - // -----2-- start lamp - // ------1- coin counter 2 - // -------0 coin counter 1 - - // Vcop Output - // 7654---- unknown (not used?) - // ----32-- start lamps (always set together) - // ------1- coin counter 2 - // -------0 coin counter 1 - - // Srallyc Output - // 7------- leader lamp - // -6------ unknown - // --5----- vr lamp - // ---4---- unknown - // ----3--- unknown - // -----2-- start lamp - // ------1- coin counter 2 - // -------0 coin counter 1 - - // STCC Output - // 7------- unknown - // -6------ unknown - // --5----- view 2 (zoom out) lamp - // ---4---- view 1 (zoom in) lamp - // ----3--- rev max lamp - // -----2-- start lamp - // ------1- coin counter 2 - // -------0 coin counter 1 - - // Indy500 Output - // 7------- race leader lamp - // -6------ unknown - // --5----- view 2 (zoom out) lamp - // ---4---- view 1 (zoom in) lamp - // ----3--- unknown - // -----2-- start lamp - // ------1- coin counter 2 - // -------0 coin counter 1 - - // Overrev Output - // 7------- unknown - // -6------ unknown - // --5----- view 2 lamp - // ---4---- view 1 lamp - // ----3--- unknown - // -----2-- start lamp - // ------1- coin counter 2 - // -------0 coin counter 1 - - // Sgt24h Output - // 7------- unknown - // -6------ unknown - // --5----- view 2 lamp - // ---4---- view 1 lamp - // ----3--- unknown - // -----2-- start lamp - // ------1- coin counter 2 - // -------0 coin counter 1 + +/* + Daytona + 7------- leader lamp + -6------ vr4 lamp + --5----- vr3 lamp + ---4---- vr2 lamp + ----3--- vr1 lamp + -----2-- start lamp + ------1- coin counter 2 + -------0 coin counter 1 + + Desert + 7------- cannon motor + -6------ machine gun motor + --5----- vr1 lamp + ---4---- vr2 lamp + ----3--- vr3 lamp + -----2-- start lamp + ------1- coin counter 2 + -------0 coin counter 1 + + Vcop + 7654---- unknown (not used?) + ----32-- start lamps (always set together) + ------1- coin counter 2 + -------0 coin counter 1 + + Srallyc + 7------- leader lamp + -6------ unknown + --5----- vr lamp + ---4---- unknown + ----3--- unknown + -----2-- start lamp + ------1- coin counter 2 + -------0 coin counter 1 + + STCC + 7------- unknown + -6------ unknown + --5----- view 2 (zoom out) lamp + ---4---- view 1 (zoom in) lamp + ----3--- rev max lamp + -----2-- start lamp + ------1- coin counter 2 + -------0 coin counter 1 + + Indy500 + 7------- race leader lamp + -6------ unknown + --5----- view 2 (zoom out) lamp + ---4---- view 1 (zoom in) lamp + ----3--- unknown + -----2-- start lamp + ------1- coin counter 2 + -------0 coin counter 1 + + Overrev + 7------- unknown + -6------ unknown + --5----- view 2 lamp + ---4---- view 1 lamp + ----3--- unknown + -----2-- start lamp + ------1- coin counter 2 + -------0 coin counter 1 + + Sgt24h + 7------- unknown + -6------ unknown + --5----- view 2 lamp + ---4---- view 1 lamp + ----3--- unknown + -----2-- start lamp + ------1- coin counter 2 + -------0 coin counter 1 +*/ void model2_state::lamp_output_w(u8 data) { @@ -1578,6 +1581,7 @@ void model2_state::drive_board_w(u8 data) m_drivecpu->set_input_line(0, HOLD_LINE); } + //************************************************************************** // INPUT HANDLING //************************************************************************** @@ -1615,12 +1619,11 @@ u8 model2_state::in0_r() ioport_value model2_state::daytona_gearbox_r() { u8 res = m_gears.read_safe(0); - int i; const u8 gearvalue[5] = { 0, 2, 1, 6, 5 }; - for(i=0;i<5;i++) + for (int i = 0; i < 5; i++) { - if(res & 1<().set_ioport("STEER"); ioboard.an_callback<1>().set_ioport("ACCEL"); ioboard.an_callback<2>().set_ioport("BRAKE"); - ioboard.output_callback().set(FUNC(model2_state::lamp_output_w)); } void model2o_state::vcop(machine_config &config) @@ -2821,8 +2823,8 @@ void model2a_state::skytargt(machine_config &config) u16 model2_state::crypt_read_callback(u32 addr) { - u16 dat= m_maincpu->space().read_word((0x1d80000+2*addr)); - return ((dat&0xff00)>>8)|((dat&0x00ff)<<8); + u16 dat= m_maincpu->space().read_word((0x1d80000 + 2*addr)); + return ((dat & 0xff00) >> 8) | ((dat & 0x00ff) << 8); } void model2a_state::model2a_5881(machine_config &config) @@ -2923,28 +2925,6 @@ void model2b_state::indy500(machine_config &config) io.an_port_callback<2>().set_ioport("BRAKE"); } -void model2b_state::overrev2b(machine_config &config) -{ - model2b(config); - - sega_315_5649_device &io(*subdevice("io")); - io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); - io.an_port_callback<0>().set_ioport("STEER"); - io.an_port_callback<1>().set_ioport("ACCEL"); - io.an_port_callback<2>().set_ioport("BRAKE"); -} - -void model2b_state::sgt24h(machine_config& config) -{ - model2b(config); - - sega_315_5649_device& io(*subdevice("io")); - io.out_pe_callback().set(FUNC(model2b_state::drive_board_w)); - io.an_port_callback<0>().set_ioport("STEER"); - io.an_port_callback<1>().set_ioport("ACCEL"); - io.an_port_callback<2>().set_ioport("BRAKE"); -} - void model2b_state::powsled(machine_config &config) { model2b(config); @@ -7645,14 +7625,14 @@ GAME( 1996, lastbrnxu, lastbrnx, model2b, vf2, model2b_state, empty_ GAME( 1996, lastbrnxj, lastbrnx, model2b, vf2, model2b_state, empty_init, ROT0, "Sega", "Last Bronx: Tokyo Bangaichi (Japan, Revision A)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1996, doa, 0, model2b_0229, doa, model2b_state, init_doa, ROT0, "Tecmo", "Dead or Alive (Model 2B, Revision C)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) // Jan 10 1997 GAME( 1996, doab, doa, model2b_0229, doa, model2b_state, init_doa, ROT0, "Tecmo", "Dead or Alive (Model 2B, Revision B)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) // Dec 4 1996 -GAME( 1996, sgt24h, 0, overrev2b, sgt24h, model2b_state, init_sgt24h, ROT0, "Jaleco", "Super GT 24h", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) +GAME( 1996, sgt24h, 0, indy500, sgt24h, model2b_state, init_sgt24h, ROT0, "Jaleco", "Super GT 24h", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1996, powsled, 0, powsled, powsled, model2b_state, empty_init, ROT0, "Sega", "Power Sled (Slave, Revision A)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1996, powsledr, powsled, powsled, powsled, model2b_state, empty_init, ROT0, "Sega", "Power Sled (Relay, Revision A)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1996, powsledm, powsled, powsled, powsled, model2b_state, init_powsledm, ROT0, "Sega", "Power Sled (Main, hack of Relay)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1996, dynabb, 0, dynabb, dynabb, model2b_state, empty_init, ROT0, "Sega", "Dynamite Baseball", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1997, dynabb97, 0, dynabb, dynabb, model2b_state, empty_init, ROT0, "Sega", "Dynamite Baseball 97 (Revision A)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) -GAME( 1997, overrevb, overrev, overrev2b, overrev, model2b_state, empty_init, ROT0, "Jaleco", "Over Rev (Model 2B, Revision B)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) -GAME( 1997, overrevba, overrev, overrev2b, overrev, model2b_state, empty_init, ROT0, "Jaleco", "Over Rev (Model 2B, Revision A)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) +GAME( 1997, overrevb, overrev, indy500, overrev, model2b_state, empty_init, ROT0, "Jaleco", "Over Rev (Model 2B, Revision B)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) +GAME( 1997, overrevba, overrev, indy500, overrev, model2b_state, empty_init, ROT0, "Jaleco", "Over Rev (Model 2B, Revision A)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1997, zerogun, 0, zerogun, zerogun, model2b_state, init_zerogun, ROT0, "Psikyo", "Zero Gunner (Export, Model 2B)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1997, zerogunj, zerogun, zerogun, zerogun, model2b_state, init_zerogun, ROT0, "Psikyo", "Zero Gunner (Japan, Model 2B)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) GAME( 1998, dynamcopb, dynamcop, model2b_5881, dynamcop, model2b_state, empty_init, ROT0, "Sega", "Dynamite Cop (Export, Model 2B)", MACHINE_NOT_WORKING|MACHINE_IMPERFECT_GRAPHICS ) From 5421126ceefa03c98684b56760e68ab2f32ab4ad Mon Sep 17 00:00:00 2001 From: hap Date: Thu, 4 Dec 2025 11:37:48 +0100 Subject: [PATCH 6/6] re-add line removed by mistake --- src/mame/sega/model2.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/mame/sega/model2.cpp b/src/mame/sega/model2.cpp index 6c8c9228a4f84..a433e22c3cc50 100644 --- a/src/mame/sega/model2.cpp +++ b/src/mame/sega/model2.cpp @@ -1264,6 +1264,7 @@ void model2_state::lamp_output_w(u8 data) m_lamps[i] = BIT(data, i + 2); } + //************************************************************************** // I/O BOARD //************************************************************************** @@ -2697,6 +2698,7 @@ void model2o_state::desert(machine_config &config) ioboard.an_callback<0>().set_ioport("STEER"); ioboard.an_callback<1>().set_ioport("ACCEL"); ioboard.an_callback<2>().set_ioport("BRAKE"); + ioboard.output_callback().set(FUNC(model2_state::lamp_output_w)); } void model2o_state::vcop(machine_config &config)