Previous 199869 Revisions Next

r32257 Sunday 21st September, 2014 at 17:11:36 UTC by Fabio Priuli
first round of svi318.c cleanup (with some tagmap reduction too). nw.
[src/mess/drivers]svi318.c
[src/mess/includes]svi318.h
[src/mess/machine]svi318.c

trunk/src/mess/machine/svi318.c
r32256r32257
2525
2626/* Serial ports */
2727
28WRITE_LINE_MEMBER(svi318_state::svi318_ins8250_interrupt)
28WRITE_LINE_MEMBER(svi318_state::ins8250_interrupt)
2929{
3030   if (m_svi.bankLow != SVI_CART)
3131   {
3232      m_maincpu->set_input_line(0, (state ? HOLD_LINE : CLEAR_LINE));
3333   }
3434}
35
3536#if 0
3637static INS8250_REFRESH_CONNECT( svi318_com_refresh_connected )
3738{
r32256r32257
8687  8  CASR     Cassette, Read data
8788*/
8889
89READ8_MEMBER(svi318_state::svi318_ppi_port_a_r)
90READ8_MEMBER(svi318_state::ppi_port_a_r)
9091{
9192   int data = 0x0f;
9293
9394   if (m_cassette->input() > 0.0038)
94   {
9595      data |= 0x80;
96   }
9796   if (!m_cassette->exists())
98   {
9997      data |= 0x40;
100   }
98
10199   data |= m_buttons->read() & 0x30;
102100
103101   return data;
r32256r32257
116114  8  IN7  Keyboard, Column status of selected line
117115*/
118116
119READ8_MEMBER(svi318_state::svi318_ppi_port_b_r)
117READ8_MEMBER(svi318_state::ppi_port_b_r)
120118{
121   switch (m_svi.keyboard_row)
122   {
123      case 0:  return m_line0->read();
124      case 1:  return m_line1->read();
125      case 2:  return m_line2->read();
126      case 3:  return m_line3->read();
127      case 4:  return m_line4->read();
128      case 5:  return m_line5->read();
129      case 6:  return m_line6->read();
130      case 7:  return m_line7->read();
131      case 8:  return m_line8->read();
132      case 9:  return m_line9->read();
133      case 10: return m_line10->read();
134   }
135
136   return 0xff;
119   if (m_svi.keyboard_row <= 10)
120      return m_line[m_svi.keyboard_row]->read();
121   else
122      return 0xff;
137123}
138124
139125/*
r32256r32257
149135  8  SOUND  Keyboard, Click sound bit (pulse)
150136*/
151137
152WRITE8_MEMBER(svi318_state::svi318_ppi_port_c_w)
138WRITE8_MEMBER(svi318_state::ppi_port_c_w)
153139{
154140   int val;
155141
r32256r32257
169155   /* cassette signal write */
170156   m_cassette->output((data & 0x20) ? -1.0 : +1.0);
171157
172   m_svi.keyboard_row = data & 0x0F;
158   m_svi.keyboard_row = data & 0x0f;
173159}
174160
175WRITE8_MEMBER(svi318_state::svi318_ppi_w)
161WRITE8_MEMBER(svi318_state::ppi_w)
176162{
177163   m_ppi->write(space, offset + 2, data);
178164}
r32256r32257
193179  8  RIGHT2 Joystick 2, Right
194180*/
195181
196READ8_MEMBER(svi318_state::svi318_psg_port_a_r)
182READ8_MEMBER(svi318_state::psg_port_a_r)
197183{
198184   return m_joysticks->read();
199185}
r32256r32257
214200 with RAM are disabled.
215201*/
216202
217WRITE8_MEMBER(svi318_state::svi318_psg_port_b_w)
203WRITE8_MEMBER(svi318_state::psg_port_b_w)
218204{
219205   if ( (m_svi.bank_switch ^ data) & 0x20)
220206      set_led_status (machine(), 0, !(data & 0x20) );
r32256r32257
225211
226212/* Disk drives  */
227213
228WRITE_LINE_MEMBER(svi318_state::svi_fdc_intrq_w)
214WRITE_LINE_MEMBER(svi318_state::fdc_intrq_w)
229215{
230216   m_fdc.irq = state;
231217}
232218
233WRITE_LINE_MEMBER(svi318_state::svi_fdc_drq_w)
219WRITE_LINE_MEMBER(svi318_state::fdc_drq_w)
234220{
235221   m_fdc.drq = state;
236222}
237223
238WRITE8_MEMBER(svi318_state::svi318_fdc_drive_motor_w)
224WRITE8_MEMBER(svi318_state::fdc_drive_motor_w)
239225{
240   fd1793_device *fdc = machine().device<fd1793_device>("wd179x");
241226   switch (data & 3)
242227   {
243228   case 1:
244      fdc->set_drive(0);
229      m_fd1793->set_drive(0);
245230      m_fdc.driveselect = 0;
246231      break;
247232   case 2:
248      fdc->set_drive(1);
233      m_fd1793->set_drive(1);
249234      m_fdc.driveselect = 1;
250235      break;
251236   }
252237}
253238
254WRITE8_MEMBER(svi318_state::svi318_fdc_density_side_w)
239WRITE8_MEMBER(svi318_state::fdc_density_side_w)
255240{
256   fd1793_device *fdc = machine().device<fd1793_device>("wd179x");
257
258   fdc->dden_w(BIT(data, 0));
259   fdc->set_side(BIT(data, 1));
241   m_fd1793->dden_w(BIT(data, 0));
242   m_fd1793->set_side(BIT(data, 1));
260243}
261244
262READ8_MEMBER(svi318_state::svi318_fdc_irqdrq_r)
245READ8_MEMBER(svi318_state::fdc_irqdrq_r)
263246{
264247   UINT8 result = 0;
265248
r32256r32257
272255MC6845_UPDATE_ROW( svi318_state::crtc_update_row )
273256{
274257   const rgb_t *palette = m_palette->palette()->entry_list_raw();
275   int i;
276258
277   for( i = 0; i < x_count; i++ )
259   for (int i = 0; i < x_count; i++)
278260   {
279      int j;
280      UINT8   data = m_svi.svi806_gfx[ m_svi.svi806_ram->u8(( ma + i ) & 0x7FF) * 16 + ra ];
261      UINT8 data = m_svi.svi806_gfx[m_svi.svi806_ram->u8((ma + i) & 0x7ff) * 16 + ra];
281262
282      if ( i == cursor_x )
263      if (i == cursor_x)
283264      {
284265         data = 0xFF;
285266      }
286267
287      for( j=0; j < 8; j++ )
268      for (int j = 0; j < 8; j++)
288269      {
289         bitmap.pix32(y, i * 8 + j ) = palette[TMS9928A_PALETTE_SIZE + ( ( data & 0x80 ) ? 1 : 0 )];
270         bitmap.pix32(y, i * 8 + j) = palette[TMS9928A_PALETTE_SIZE + BIT(data, 7)];
290271         data = data << 1;
291272      }
292273   }
r32256r32257
298279{
299280   /* 2K RAM, but allocating 4KB to make banking easier */
300281   /* The upper 2KB will be set to FFs and will never be written to */
301   m_svi.svi806_ram = machine().memory().region_alloc("gfx2", 0x1000, 1, ENDIANNESS_LITTLE );
302   memset( m_svi.svi806_ram->base(), 0x00, 0x800 );
303   memset( m_svi.svi806_ram->base() + 0x800, 0xFF, 0x800 );
282   m_svi.svi806_ram = machine().memory().region_alloc("gfx2", 0x1000, 1, ENDIANNESS_LITTLE);
283   memset(m_svi.svi806_ram->base(), 0x00, 0x800);
284   memset(m_svi.svi806_ram->base() + 0x800, 0xff, 0x800);
304285   m_svi.svi806_gfx = memregion("gfx1")->base();
305286}
306287
307288
308289WRITE8_MEMBER(svi318_state::svi806_ram_enable_w)
309290{
310   m_svi.svi806_ram_enabled = ( data & 0x01 );
291   m_svi.svi806_ram_enabled = (data & 0x01);
311292   svi318_set_banks();
312293}
313294
314VIDEO_START_MEMBER(svi318_state,svi328_806)
295VIDEO_START_MEMBER(svi318_state, svi328_806)
315296{
316297}
317298
318MACHINE_RESET_MEMBER(svi318_state,svi328_806)
299MACHINE_RESET_MEMBER(svi318_state, svi328_806)
319300{
320301   MACHINE_RESET_CALL_MEMBER(svi318);
321302
r32256r32257
324305   svi318_set_banks();
325306
326307   /* Set SVI-806 80 column card palette */
327   m_palette->set_pen_color( TMS9928A_PALETTE_SIZE, 0, 0, 0 );     /* Monochrome black */
328   m_palette->set_pen_color( TMS9928A_PALETTE_SIZE+1, 0, 224, 0 ); /* Monochrome green */
308   m_palette->set_pen_color(TMS9928A_PALETTE_SIZE, 0, 0, 0);     /* Monochrome black */
309   m_palette->set_pen_color(TMS9928A_PALETTE_SIZE+1, 0, 224, 0); /* Monochrome green */
329310}
330311
331312/* Init functions */
r32256r32257
452433};
453434
454435
455DRIVER_INIT_MEMBER(svi318_state,svi318)
436DRIVER_INIT_MEMBER(svi318_state, svi318)
456437{
457438   /* z80 stuff */
458   m_maincpu->z80_set_cycle_tables( cc_op, cc_cb, cc_ed, cc_xy, cc_xycb, cc_ex );
439   m_maincpu->z80_set_cycle_tables(cc_op, cc_cb, cc_ed, cc_xy, cc_xycb, cc_ex);
459440
460   memset(&m_svi, 0, sizeof (m_svi) );
441   memset(&m_svi, 0, sizeof(m_svi));
461442
462   if ( ! strcmp( machine().system().name, "svi318" ) || ! strcmp( machine().system().name, "svi318n" ) )
463   {
443   if (!strcmp(machine().system().name, "svi318") || !strcmp(machine().system().name, "svi318n"))
464444      m_svi.svi318 = 1;
465   }
466445
467446   m_maincpu->set_input_line_vector(0, 0xff);
468447
469448   /* memory */
470449   m_svi.empty_bank = auto_alloc_array(machine(), UINT8, 0x8000);
471   memset (m_svi.empty_bank, 0xff, 0x8000);
450   memset(m_svi.empty_bank, 0xff, 0x8000);
472451}
473452
474453MACHINE_START_MEMBER(svi318_state, svi318_ntsc)
r32256r32257
486465static void svi318_load_proc(device_image_interface &image)
487466{
488467   svi318_state *state = image.device().machine().driver_data<svi318_state>();
489   int size;
468   int size = image.length();
490469   int id = floppy_get_drive(&image.device());
491470
492   size = image.length();
493471   switch (size)
494472   {
495473   case 172032:    /* SVI-328 SSDD */
r32256r32257
504482   }
505483}
506484
507MACHINE_RESET_MEMBER(svi318_state,svi318)
485MACHINE_RESET_MEMBER(svi318_state, svi318)
508486{
509   int drive;
510
511487   m_svi.bank_switch = 0xff;
512488   svi318_set_banks();
513489
514   for(drive=0;drive<2;drive++)
490   for (int drive = 0; drive < 2; drive++)
515491   {
516492      floppy_get_device(machine(), drive)->floppy_install_load_proc(svi318_load_proc);
517493   }
r32256r32257
519495
520496/* Memory */
521497
522WRITE8_MEMBER(svi318_state::svi318_writemem1)
498WRITE8_MEMBER(svi318_state::writemem1)
523499{
524   if ( m_svi.bankLow_read_only )
500   if (m_svi.bankLow_read_only)
525501      return;
526502
527503   m_svi.bankLow_ptr[offset] = data;
528504}
529505
530WRITE8_MEMBER(svi318_state::svi318_writemem2)
506WRITE8_MEMBER(svi318_state::writemem2)
531507{
532   if ( m_svi.bankHigh1_read_only)
508   if (m_svi.bankHigh1_read_only)
533509      return;
534510
535511   m_svi.bankHigh1_ptr[offset] = data;
536512}
537513
538WRITE8_MEMBER(svi318_state::svi318_writemem3)
514WRITE8_MEMBER(svi318_state::writemem3)
539515{
540   if ( m_svi.bankHigh2_read_only)
516   if (m_svi.bankHigh2_read_only)
541517      return;
542518
543519   m_svi.bankHigh2_ptr[offset] = data;
544520}
545521
546WRITE8_MEMBER(svi318_state::svi318_writemem4)
522WRITE8_MEMBER(svi318_state::writemem4)
547523{
548   if ( m_svi.svi806_ram_enabled )
524   if (m_svi.svi806_ram_enabled)
549525   {
550      if ( offset < 0x800 )
526      if (offset < 0x800)
551527      {
552528         m_svi.svi806_ram->u8(offset) = data;
553529      }
554530   }
555531   else
556532   {
557      if ( m_svi.bankHigh2_read_only )
533      if (m_svi.bankHigh2_read_only)
558534         return;
559535
560      m_svi.bankHigh2_ptr[ 0x3000 + offset] = data;
536      m_svi.bankHigh2_ptr[0x3000 + offset] = data;
561537   }
562538}
563539
r32256r32257
650626         m_svi.bankHigh1_ptr = m_cart_rom->base();
651627   }
652628
653   membank("bank1")->set_base(m_svi.bankLow_ptr );
654   membank("bank2")->set_base(m_svi.bankHigh1_ptr );
655   membank("bank3")->set_base(m_svi.bankHigh2_ptr );
629   membank("bank1")->set_base(m_svi.bankLow_ptr);
630   membank("bank2")->set_base(m_svi.bankHigh1_ptr);
631   membank("bank3")->set_base(m_svi.bankHigh2_ptr);
656632
657633   /* SVI-806 80 column card specific banking */
658   if ( m_svi.svi806_present )
634   if (m_svi.svi806_present)
659635   {
660      if ( m_svi.svi806_ram_enabled )
636      if (m_svi.svi806_ram_enabled)
661637      {
662         membank("bank4")->set_base(m_svi.svi806_ram );
638         membank("bank4")->set_base(m_svi.svi806_ram);
663639      }
664640      else
665641      {
666         membank("bank4")->set_base(m_svi.bankHigh2_ptr + 0x3000 );
642         membank("bank4")->set_base(m_svi.bankHigh2_ptr + 0x3000);
667643      }
668644   }
669645}
r32256r32257
675651   m_centronics_busy = state;
676652}
677653
678READ8_MEMBER(svi318_state::svi318_io_ext_r)
654READ8_MEMBER(svi318_state::io_ext_r)
679655{
680   UINT8 data = 0xff;
681   device_t *device;
682
683656   if (m_svi.bankLow == SVI_CART)
684   {
685657      return 0xff;
686   }
687658
688   fd1793_device *fdc = machine().device<fd1793_device>("wd179x");
689
690   switch( offset )
659   switch (offset)
691660   {
692661   case 0x12:
693      data = 0xfe | m_centronics_busy;
694      break;
662      return 0xfe | m_centronics_busy;
695663
696664   case 0x20:
697665   case 0x21:
r32256r32257
701669   case 0x25:
702670   case 0x26:
703671   case 0x27:
704      data = m_ins8250_0->ins8250_r(space, offset & 7);
705      break;
672      return m_ins8250_0->ins8250_r(space, offset & 7);
706673
707674   case 0x28:
708675   case 0x29:
709   case 0x2A:
710   case 0x2B:
711   case 0x2C:
712   case 0x2D:
713   case 0x2E:
714   case 0x2F:
715      data = m_ins8250_1->ins8250_r(space, offset & 7);
716      break;
676   case 0x2a:
677   case 0x2b:
678   case 0x2c:
679   case 0x2d:
680   case 0x2e:
681   case 0x2f:
682      return m_ins8250_1->ins8250_r(space, offset & 7);
717683
718684   case 0x30:
719      data = fdc->status_r(space, 0);
720      break;
685      return m_fd1793->status_r(space, 0);
686
721687   case 0x31:
722      data = fdc->track_r(space, 0);
723      break;
688      return m_fd1793->track_r(space, 0);
689
724690   case 0x32:
725      data = fdc->sector_r(space, 0);
726      break;
691      return m_fd1793->sector_r(space, 0);
692
727693   case 0x33:
728      data = fdc->data_r(space, 0);
729      break;
694      return m_fd1793->data_r(space, 0);
695
730696   case 0x34:
731      data = svi318_fdc_irqdrq_r(space, 0);
732      break;
697      return fdc_irqdrq_r(space, 0);
698
733699   case 0x51:
734      device = machine().device("crtc");
735      data = downcast<mc6845_device *>(device)->register_r( space, offset );
736      break;
700      return m_crtc->register_r(space, offset);
737701   }
738702
739   return data;
703   return 0xff;
740704}
741705
742WRITE8_MEMBER(svi318_state::svi318_io_ext_w)
706WRITE8_MEMBER(svi318_state::io_ext_w)
743707{
744   device_t *device;
745
746708   if (m_svi.bankLow == SVI_CART)
747   {
748709      return;
749   }
750710
751   fd1793_device *fdc = machine().device<fd1793_device>("wd179x");
752
753   switch( offset )
711   switch (offset)
754712   {
755713   case 0x10:
756714      m_cent_data_out->write(space, 0, data);
r32256r32257
783741      break;
784742
785743   case 0x30:
786      fdc->command_w(space, 0, data);
744      m_fd1793->command_w(space, 0, data);
787745      break;
788746   case 0x31:
789      fdc->track_w(space, 0, data);
747      m_fd1793->track_w(space, 0, data);
790748      break;
791749   case 0x32:
792      fdc->sector_w(space, 0, data);
750      m_fd1793->sector_w(space, 0, data);
793751      break;
794752   case 0x33:
795      fdc->data_w(space, 0, data);
753      m_fd1793->data_w(space, 0, data);
796754      break;
797755   case 0x34:
798      svi318_fdc_drive_motor_w(space, 0, data);
756      fdc_drive_motor_w(space, 0, data);
799757      break;
800758   case 0x38:
801      svi318_fdc_density_side_w(space, 0, data);
759      fdc_density_side_w(space, 0, data);
802760      break;
803761
804762   case 0x50:
805      device = machine().device("crtc");
806      downcast<mc6845_device *>(device)->address_w(space, offset, data);
763      m_crtc->address_w(space, offset, data);
807764      break;
808765   case 0x51:
809      device = machine().device("crtc");
810      downcast<mc6845_device *>(device)->register_w(space, offset, data);
766      m_crtc->register_w(space, offset, data);
811767      break;
812768
813769   case 0x58:
trunk/src/mess/includes/svi318.h
r32256r32257
7474      m_ins8250_0(*this, "ins8250_0"),
7575      m_ins8250_1(*this, "ins8250_1"),
7676      m_cart(*this, "cartslot"),
77      m_line0(*this, "LINE0"),
78      m_line1(*this, "LINE1"),
79      m_line2(*this, "LINE2"),
80      m_line3(*this, "LINE3"),
81      m_line4(*this, "LINE4"),
82      m_line5(*this, "LINE5"),
83      m_line6(*this, "LINE6"),
84      m_line7(*this, "LINE7"),
85      m_line8(*this, "LINE8"),
86      m_line9(*this, "LINE9"),
87      m_line10(*this, "LINE10"),
77      m_fd1793(*this, "wd179x"),
78      m_crtc(*this, "crtc"),
79      m_line(*this, "LINE"),
8880      m_joysticks(*this, "JOYSTICKS"),
8981      m_buttons(*this, "BUTTONS"),
9082      m_palette(*this, "palette")  { }
r32256r32257
9284   SVI_318 m_svi;
9385   int m_centronics_busy;
9486   SVI318_FDC_STRUCT m_fdc;
95   DECLARE_WRITE8_MEMBER(svi318_ppi_w);
96   DECLARE_READ8_MEMBER(svi318_psg_port_a_r);
97   DECLARE_WRITE8_MEMBER(svi318_psg_port_b_w);
98   DECLARE_WRITE8_MEMBER(svi318_fdc_drive_motor_w);
99   DECLARE_WRITE8_MEMBER(svi318_fdc_density_side_w);
100   DECLARE_READ8_MEMBER(svi318_fdc_irqdrq_r);
87   DECLARE_WRITE8_MEMBER(ppi_w);
88   DECLARE_READ8_MEMBER(psg_port_a_r);
89   DECLARE_WRITE8_MEMBER(psg_port_b_w);
90   DECLARE_WRITE8_MEMBER(fdc_drive_motor_w);
91   DECLARE_WRITE8_MEMBER(fdc_density_side_w);
92   DECLARE_READ8_MEMBER(fdc_irqdrq_r);
10193   DECLARE_WRITE8_MEMBER(svi806_ram_enable_w);
102   DECLARE_WRITE8_MEMBER(svi318_writemem1);
103   DECLARE_WRITE8_MEMBER(svi318_writemem2);
104   DECLARE_WRITE8_MEMBER(svi318_writemem3);
105   DECLARE_WRITE8_MEMBER(svi318_writemem4);
106   DECLARE_READ8_MEMBER(svi318_io_ext_r);
107   DECLARE_WRITE8_MEMBER(svi318_io_ext_w);
94   DECLARE_WRITE8_MEMBER(writemem1);
95   DECLARE_WRITE8_MEMBER(writemem2);
96   DECLARE_WRITE8_MEMBER(writemem3);
97   DECLARE_WRITE8_MEMBER(writemem4);
98   DECLARE_READ8_MEMBER(io_ext_r);
99   DECLARE_WRITE8_MEMBER(io_ext_w);
108100   DECLARE_DRIVER_INIT(svi318);
109101   DECLARE_MACHINE_START(svi318_pal);
110102   DECLARE_MACHINE_RESET(svi318);
r32256r32257
112104   DECLARE_VIDEO_START(svi328_806);
113105   DECLARE_MACHINE_START(svi318_ntsc);
114106   DECLARE_WRITE_LINE_MEMBER(vdp_interrupt);
115   DECLARE_WRITE_LINE_MEMBER(svi318_ins8250_interrupt);
116   DECLARE_READ8_MEMBER(svi318_ppi_port_a_r);
117   DECLARE_READ8_MEMBER(svi318_ppi_port_b_r);
118   DECLARE_WRITE8_MEMBER(svi318_ppi_port_c_w);
119   DECLARE_WRITE_LINE_MEMBER(svi_fdc_intrq_w);
120   DECLARE_WRITE_LINE_MEMBER(svi_fdc_drq_w);
107   DECLARE_WRITE_LINE_MEMBER(ins8250_interrupt);
108   DECLARE_READ8_MEMBER(ppi_port_a_r);
109   DECLARE_READ8_MEMBER(ppi_port_b_r);
110   DECLARE_WRITE8_MEMBER(ppi_port_c_w);
111   DECLARE_WRITE_LINE_MEMBER(fdc_intrq_w);
112   DECLARE_WRITE_LINE_MEMBER(fdc_drq_w);
121113   bool cart_verify(UINT8 *ROM);
122114   DECLARE_DEVICE_IMAGE_LOAD_MEMBER(svi318_cart);
123115   DECLARE_WRITE_LINE_MEMBER(write_centronics_busy);
r32256r32257
136128   required_device<ins8250_device> m_ins8250_0;
137129   required_device<ins8250_device> m_ins8250_1;
138130   required_device<generic_slot_device> m_cart;
139   required_ioport m_line0;
140   required_ioport m_line1;
141   required_ioport m_line2;
142   required_ioport m_line3;
143   required_ioport m_line4;
144   required_ioport m_line5;
145   required_ioport m_line6;
146   required_ioport m_line7;
147   required_ioport m_line8;
148   required_ioport m_line9;
149   required_ioport m_line10;
131   required_device<fd1793_device> m_fd1793;
132   optional_device<mc6845_device> m_crtc;
133   required_ioport_array<11> m_line;
150134   required_ioport m_joysticks;
151135   required_ioport m_buttons;
152136public:
trunk/src/mess/drivers/svi318.c
r32256r32257
1717#include "rendlay.h"
1818
1919static ADDRESS_MAP_START( svi318_mem, AS_PROGRAM, 8, svi318_state )
20   AM_RANGE( 0x0000, 0x7fff) AM_READ_BANK("bank1") AM_WRITE(svi318_writemem1 )
21   AM_RANGE( 0x8000, 0xbfff) AM_READ_BANK("bank2") AM_WRITE(svi318_writemem2 )
22   AM_RANGE( 0xc000, 0xffff) AM_READ_BANK("bank3") AM_WRITE(svi318_writemem3 )
20   AM_RANGE(0x0000, 0x7fff) AM_READ_BANK("bank1") AM_WRITE(writemem1)
21   AM_RANGE(0x8000, 0xbfff) AM_READ_BANK("bank2") AM_WRITE(writemem2)
22   AM_RANGE(0xc000, 0xffff) AM_READ_BANK("bank3") AM_WRITE(writemem3)
2323ADDRESS_MAP_END
2424
2525static ADDRESS_MAP_START( svi328_806_mem, AS_PROGRAM, 8, svi318_state )
26   AM_RANGE( 0x0000, 0x7fff) AM_READ_BANK("bank1") AM_WRITE(svi318_writemem1 )
27   AM_RANGE( 0x8000, 0xbfff) AM_READ_BANK("bank2") AM_WRITE(svi318_writemem2 )
28   AM_RANGE( 0xc000, 0xefff) AM_READ_BANK("bank3") AM_WRITE(svi318_writemem3 )
29   AM_RANGE( 0xf000, 0xffff) AM_READ_BANK("bank4") AM_WRITE(svi318_writemem4 )
26   AM_RANGE(0x0000, 0x7fff) AM_READ_BANK("bank1") AM_WRITE(writemem1)
27   AM_RANGE(0x8000, 0xbfff) AM_READ_BANK("bank2") AM_WRITE(writemem2)
28   AM_RANGE(0xc000, 0xefff) AM_READ_BANK("bank3") AM_WRITE(writemem3)
29   AM_RANGE(0xf000, 0xffff) AM_READ_BANK("bank4") AM_WRITE(writemem4)
3030ADDRESS_MAP_END
3131
3232static ADDRESS_MAP_START( svi318_io, AS_IO, 8, svi318_state )
3333   ADDRESS_MAP_UNMAP_HIGH
3434   ADDRESS_MAP_GLOBAL_MASK(0xff)
35   AM_RANGE( 0x00, 0x38) AM_READWRITE(svi318_io_ext_r, svi318_io_ext_w )
36   AM_RANGE( 0x80, 0x80) AM_DEVWRITE( "tms9928a", tms9928a_device, vram_write )
37   AM_RANGE( 0x81, 0x81) AM_DEVWRITE( "tms9928a", tms9928a_device, register_write )
38   AM_RANGE( 0x84, 0x84) AM_DEVREAD( "tms9928a", tms9928a_device, vram_read )
39   AM_RANGE( 0x85, 0x85) AM_DEVREAD( "tms9928a", tms9928a_device, register_read )
40   AM_RANGE( 0x88, 0x88) AM_DEVWRITE("ay8910", ay8910_device, address_w )
41   AM_RANGE( 0x8c, 0x8c) AM_DEVWRITE("ay8910", ay8910_device, data_w )
42   AM_RANGE( 0x90, 0x90) AM_DEVREAD("ay8910", ay8910_device, data_r )
43   AM_RANGE( 0x96, 0x97) AM_WRITE(svi318_ppi_w)
44   AM_RANGE( 0x98, 0x9a) AM_DEVREAD("ppi8255", i8255_device, read)
35   AM_RANGE(0x00, 0x38) AM_READWRITE(io_ext_r, io_ext_w )
36   AM_RANGE(0x80, 0x80) AM_DEVWRITE("tms9928a", tms9928a_device, vram_write)
37   AM_RANGE(0x81, 0x81) AM_DEVWRITE("tms9928a", tms9928a_device, register_write)
38   AM_RANGE(0x84, 0x84) AM_DEVREAD("tms9928a", tms9928a_device, vram_read)
39   AM_RANGE(0x85, 0x85) AM_DEVREAD("tms9928a", tms9928a_device, register_read)
40   AM_RANGE(0x88, 0x88) AM_DEVWRITE("ay8910", ay8910_device, address_w)
41   AM_RANGE(0x8c, 0x8c) AM_DEVWRITE("ay8910", ay8910_device, data_w)
42   AM_RANGE(0x90, 0x90) AM_DEVREAD("ay8910", ay8910_device, data_r)
43   AM_RANGE(0x96, 0x97) AM_WRITE(ppi_w)
44   AM_RANGE(0x98, 0x9a) AM_DEVREAD("ppi8255", i8255_device, read)
4545ADDRESS_MAP_END
4646
4747static ADDRESS_MAP_START( svi328_806_io, AS_IO, 8, svi318_state )
4848   ADDRESS_MAP_UNMAP_HIGH
4949   ADDRESS_MAP_GLOBAL_MASK(0xff)
50   AM_RANGE( 0x00, 0x58) AM_READWRITE(svi318_io_ext_r, svi318_io_ext_w )
51   AM_RANGE( 0x80, 0x80) AM_DEVWRITE( "tms9928a", tms9928a_device, vram_write )
52   AM_RANGE( 0x81, 0x81) AM_DEVWRITE( "tms9928a", tms9928a_device, register_write )
53   AM_RANGE( 0x84, 0x84) AM_DEVREAD( "tms9928a", tms9928a_device, vram_read )
54   AM_RANGE( 0x85, 0x85) AM_DEVREAD( "tms9928a", tms9928a_device, register_read )
55   AM_RANGE( 0x88, 0x88) AM_DEVWRITE("ay8910", ay8910_device, address_w )
56   AM_RANGE( 0x8c, 0x8c) AM_DEVWRITE("ay8910", ay8910_device, data_w )
57   AM_RANGE( 0x90, 0x90) AM_DEVREAD("ay8910", ay8910_device, data_r )
58   AM_RANGE( 0x96, 0x97) AM_WRITE(svi318_ppi_w)
59   AM_RANGE( 0x98, 0x9a) AM_DEVREAD("ppi8255", i8255_device, read)
50   AM_RANGE(0x00, 0x58) AM_READWRITE(io_ext_r, io_ext_w )
51   AM_RANGE(0x80, 0x80) AM_DEVWRITE("tms9928a", tms9928a_device, vram_write)
52   AM_RANGE(0x81, 0x81) AM_DEVWRITE("tms9928a", tms9928a_device, register_write)
53   AM_RANGE(0x84, 0x84) AM_DEVREAD("tms9928a", tms9928a_device, vram_read)
54   AM_RANGE(0x85, 0x85) AM_DEVREAD("tms9928a", tms9928a_device, register_read)
55   AM_RANGE(0x88, 0x88) AM_DEVWRITE("ay8910", ay8910_device, address_w)
56   AM_RANGE(0x8c, 0x8c) AM_DEVWRITE("ay8910", ay8910_device, data_w)
57   AM_RANGE(0x90, 0x90) AM_DEVREAD("ay8910", ay8910_device, data_r)
58   AM_RANGE(0x96, 0x97) AM_WRITE(ppi_w)
59   AM_RANGE(0x98, 0x9a) AM_DEVREAD("ppi8255", i8255_device, read)
6060ADDRESS_MAP_END
6161
6262/*
r32256r32257
101101*/
102102
103103static INPUT_PORTS_START( svi318 )
104   PORT_START("LINE0")
104   PORT_START("LINE.0")
105105   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_0)           PORT_CHAR('0') PORT_CHAR(')')
106106   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_1)           PORT_CHAR('1') PORT_CHAR('!')
107107   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_2)           PORT_CHAR('2') PORT_CHAR('@')
r32256r32257
111111   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_6)           PORT_CHAR('6') PORT_CHAR('^')
112112   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_7)           PORT_CHAR('7') PORT_CHAR('&')
113113
114   PORT_START("LINE1")
114   PORT_START("LINE.1")
115115   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_8)           PORT_CHAR('8') PORT_CHAR('*')
116116   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_9)           PORT_CHAR('9') PORT_CHAR('(')
117117   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_COLON)       PORT_CHAR(':') PORT_CHAR(';')
r32256r32257
121121   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_STOP)        PORT_CHAR('.') PORT_CHAR('>')
122122   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_SLASH)       PORT_CHAR('/') PORT_CHAR('?')
123123
124   PORT_START("LINE2")
124   PORT_START("LINE.2")
125125   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_MINUS)       PORT_CHAR('-') PORT_CHAR('_')
126126   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_A)           PORT_CHAR('a') PORT_CHAR('A')
127127   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_B)           PORT_CHAR('b') PORT_CHAR('B')
r32256r32257
131131   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_F)           PORT_CHAR('f') PORT_CHAR('F')
132132   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_G)           PORT_CHAR('g') PORT_CHAR('G')
133133
134   PORT_START("LINE3")
134   PORT_START("LINE.3")
135135   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_H)           PORT_CHAR('h') PORT_CHAR('H')
136136   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_I)           PORT_CHAR('i') PORT_CHAR('I')
137137   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_J)           PORT_CHAR('0') PORT_CHAR('J')
r32256r32257
141141   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_N)           PORT_CHAR('n') PORT_CHAR('N')
142142   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_O)           PORT_CHAR('o') PORT_CHAR('O')
143143
144   PORT_START("LINE4")
144   PORT_START("LINE.4")
145145   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_P)           PORT_CHAR('p') PORT_CHAR('P')
146146   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_Q)           PORT_CHAR('q') PORT_CHAR('Q')
147147   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_R)           PORT_CHAR('r') PORT_CHAR('R')
r32256r32257
151151   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_V)           PORT_CHAR('v') PORT_CHAR('V')
152152   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_W)           PORT_CHAR('w') PORT_CHAR('W')
153153
154   PORT_START("LINE5")
154   PORT_START("LINE.5")
155155   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_X)           PORT_CHAR('x') PORT_CHAR('X')
156156   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_Y)           PORT_CHAR('y') PORT_CHAR('Y')
157157   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_Z)           PORT_CHAR('z') PORT_CHAR('Z')
r32256r32257
161161   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_BACKSPACE)   PORT_CHAR(8)
162162   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME(UTF8_UP) PORT_CODE(KEYCODE_UP)       PORT_CHAR(UCHAR_MAMEKEY(UP))
163163
164   PORT_START("LINE6")
164   PORT_START("LINE.6")
165165   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_LSHIFT) PORT_CODE(KEYCODE_RSHIFT)    PORT_CHAR(UCHAR_SHIFT_1)
166166   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Ctrl") PORT_CODE(KEYCODE_LCONTROL)          PORT_CHAR(UCHAR_SHIFT_2)
167167   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Left Grph") PORT_CODE(KEYCODE_LALT)         PORT_CHAR(UCHAR_MAMEKEY(PGUP))
r32256r32257
171171   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_ENTER)                               PORT_CHAR(13)
172172   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME(UTF8_LEFT) PORT_CODE(KEYCODE_LEFT)       PORT_CHAR(UCHAR_MAMEKEY(LEFT))
173173
174   PORT_START("LINE7")
174   PORT_START("LINE.7")
175175   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("F1  F6") PORT_CODE(KEYCODE_F1)              PORT_CHAR(UCHAR_MAMEKEY(F1)) PORT_CHAR(UCHAR_MAMEKEY(F6))
176176   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("F2  F7") PORT_CODE(KEYCODE_F2)              PORT_CHAR(UCHAR_MAMEKEY(F2)) PORT_CHAR(UCHAR_MAMEKEY(F7))
177177   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("F3  F8") PORT_CODE(KEYCODE_F3)              PORT_CHAR(UCHAR_MAMEKEY(F3)) PORT_CHAR(UCHAR_MAMEKEY(F8))
r32256r32257
181181   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Ins  Paste") PORT_CODE(KEYCODE_INSERT)      PORT_CHAR(UCHAR_MAMEKEY(INSERT))
182182   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME(UTF8_DOWN) PORT_CODE(KEYCODE_DOWN)       PORT_CHAR(UCHAR_MAMEKEY(DOWN))
183183
184   PORT_START("LINE8")
184   PORT_START("LINE.8")
185185   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_SPACE)                               PORT_CHAR(' ')
186186   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_TAB)                                 PORT_CHAR('\t')
187187   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Del  Cut") PORT_CODE(KEYCODE_DEL)           PORT_CHAR(UCHAR_MAMEKEY(DEL))
r32256r32257
191191   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_UNUSED)
192192   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME(UTF8_RIGHT) PORT_CODE(KEYCODE_RIGHT)     PORT_CHAR(UCHAR_MAMEKEY(RIGHT))
193193
194   PORT_START("LINE9")
194   PORT_START("LINE.9")
195195   PORT_BIT (0xff, IP_ACTIVE_LOW, IPT_UNUSED)
196196
197   PORT_START("LINE10")
197   PORT_START("LINE.10")
198198   PORT_BIT (0xff, IP_ACTIVE_LOW, IPT_UNUSED)
199199
200200   PORT_START("JOYSTICKS")
r32256r32257
217217
218218   PORT_INCLUDE( svi318 )
219219
220   PORT_MODIFY("LINE9")
220   PORT_MODIFY("LINE.9")
221221   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_0_PAD)           PORT_CHAR(UCHAR_MAMEKEY(0_PAD))
222222   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_1_PAD)           PORT_CHAR(UCHAR_MAMEKEY(1_PAD))
223223   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_2_PAD)           PORT_CHAR(UCHAR_MAMEKEY(2_PAD))
r32256r32257
227227   PORT_BIT (0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_6_PAD)           PORT_CHAR(UCHAR_MAMEKEY(6_PAD))
228228   PORT_BIT (0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_7_PAD)           PORT_CHAR(UCHAR_MAMEKEY(7_PAD))
229229
230   PORT_MODIFY("LINE10")
230   PORT_MODIFY("LINE.10")
231231   PORT_BIT (0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_8_PAD)           PORT_CHAR(UCHAR_MAMEKEY(8_PAD))
232232   PORT_BIT (0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_9_PAD)           PORT_CHAR(UCHAR_MAMEKEY(9_PAD))
233233   PORT_BIT (0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_PLUS_PAD)        PORT_CHAR(UCHAR_MAMEKEY(PLUS_PAD))
r32256r32257
261261
262262static MACHINE_CONFIG_START( svi318, svi318_state )
263263   /* Basic machine hardware */
264   MCFG_CPU_ADD( "maincpu", Z80, 3579545 ) /* 3.579545 MHz */
265   MCFG_CPU_PROGRAM_MAP( svi318_mem)
266   MCFG_CPU_IO_MAP( svi318_io)
264   MCFG_CPU_ADD("maincpu", Z80, 3579545) /* 3.579545 MHz */
265   MCFG_CPU_PROGRAM_MAP(svi318_mem)
266   MCFG_CPU_IO_MAP(svi318_io)
267267   MCFG_QUANTUM_TIME(attotime::from_hz(60))
268268
269   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_pal )
270   MCFG_MACHINE_RESET_OVERRIDE(svi318_state, svi318 )
269   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_pal)
270   MCFG_MACHINE_RESET_OVERRIDE(svi318_state, svi318)
271271
272272   MCFG_DEVICE_ADD("ppi8255", I8255, 0)
273   MCFG_I8255_IN_PORTA_CB(READ8(svi318_state, svi318_ppi_port_a_r))
274   MCFG_I8255_IN_PORTB_CB(READ8(svi318_state, svi318_ppi_port_b_r))
275   MCFG_I8255_OUT_PORTC_CB(WRITE8(svi318_state, svi318_ppi_port_c_w))
273   MCFG_I8255_IN_PORTA_CB(READ8(svi318_state, ppi_port_a_r))
274   MCFG_I8255_IN_PORTB_CB(READ8(svi318_state, ppi_port_b_r))
275   MCFG_I8255_OUT_PORTC_CB(WRITE8(svi318_state, ppi_port_c_w))
276276
277   MCFG_DEVICE_ADD( "ins8250_0", INS8250, 1000000 )
278   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, svi318_ins8250_interrupt))
279   MCFG_DEVICE_ADD( "ins8250_1", INS8250, 3072000 )
280   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, svi318_ins8250_interrupt))
277   MCFG_DEVICE_ADD("ins8250_0", INS8250, 1000000)
278   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, ins8250_interrupt))
279   MCFG_DEVICE_ADD("ins8250_1", INS8250, 3072000)
280   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, ins8250_interrupt))
281281
282282   /* Video hardware */
283   MCFG_DEVICE_ADD( "tms9928a", TMS9929A, XTAL_10_738635MHz / 2 )
283   MCFG_DEVICE_ADD("tms9928a", TMS9929A, XTAL_10_738635MHz / 2)
284284   MCFG_TMS9928A_VRAM_SIZE(0x4000)
285285   MCFG_TMS9928A_OUT_INT_LINE_CB(WRITELINE(svi318_state, vdp_interrupt))
286   MCFG_TMS9928A_SCREEN_ADD_PAL( "screen" )
287   MCFG_SCREEN_UPDATE_DEVICE( "tms9928a", tms9929a_device, screen_update )
286   MCFG_TMS9928A_SCREEN_ADD_PAL("screen")
287   MCFG_SCREEN_UPDATE_DEVICE("tms9928a", tms9929a_device, screen_update)
288288
289289   /* Sound hardware */
290290   MCFG_SPEAKER_STANDARD_MONO("mono")
r32256r32257
293293   MCFG_SOUND_WAVE_ADD(WAVE_TAG, "cassette")
294294   MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.25)
295295   MCFG_SOUND_ADD("ay8910", AY8910, 1789773)
296   MCFG_AY8910_PORT_A_READ_CB(READ8(svi318_state, svi318_psg_port_a_r))
297   MCFG_AY8910_PORT_B_WRITE_CB(WRITE8(svi318_state, svi318_psg_port_b_w))
296   MCFG_AY8910_PORT_A_READ_CB(READ8(svi318_state, psg_port_a_r))
297   MCFG_AY8910_PORT_B_WRITE_CB(WRITE8(svi318_state, psg_port_b_w))
298298   MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.75)
299299
300300   /* printer */
r32256r32257
303303
304304   MCFG_CENTRONICS_OUTPUT_LATCH_ADD("cent_data_out", "centronics")
305305
306   MCFG_CASSETTE_ADD( "cassette" )
306   MCFG_CASSETTE_ADD("cassette")
307307   MCFG_CASSETTE_FORMATS(svi_cassette_formats)
308308   MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_PLAY)
309309   MCFG_CASSETTE_INTERFACE("svi318_cass")
310310
311311   MCFG_DEVICE_ADD("wd179x", FD1793, 0)
312312   MCFG_WD17XX_DEFAULT_DRIVE2_TAGS
313   MCFG_WD17XX_INTRQ_CALLBACK(WRITELINE(svi318_state,svi_fdc_intrq_w))
314   MCFG_WD17XX_DRQ_CALLBACK(WRITELINE(svi318_state,svi_fdc_drq_w))
313   MCFG_WD17XX_INTRQ_CALLBACK(WRITELINE(svi318_state, fdc_intrq_w))
314   MCFG_WD17XX_DRQ_CALLBACK(WRITELINE(svi318_state, fdc_drq_w))
315315
316316   MCFG_LEGACY_FLOPPY_2_DRIVES_ADD(svi318_floppy_interface)
317317
318318   /* Software lists */
319   MCFG_SOFTWARE_LIST_ADD("cass_list","svi318_flop")
320   MCFG_SOFTWARE_LIST_ADD("disk_list","svi318_cass")
319   MCFG_SOFTWARE_LIST_ADD("cass_list", "svi318_flop")
320   MCFG_SOFTWARE_LIST_ADD("disk_list", "svi318_cass")
321321
322   MCFG_FRAGMENT_ADD( svi318_cartslot )
322   MCFG_FRAGMENT_ADD(svi318_cartslot)
323323
324324   /* internal ram */
325325   MCFG_RAM_ADD(RAM_TAG)
r32256r32257
331331
332332   MCFG_DEVICE_REMOVE("tms9928a")
333333   MCFG_DEVICE_REMOVE("screen")
334   MCFG_DEVICE_ADD( "tms9928a", TMS9928A, XTAL_10_738635MHz / 2 )
334   MCFG_DEVICE_ADD("tms9928a", TMS9928A, XTAL_10_738635MHz / 2)
335335   MCFG_TMS9928A_VRAM_SIZE(0x4000)
336336   MCFG_TMS9928A_OUT_INT_LINE_CB(WRITELINE(svi318_state, vdp_interrupt))
337   MCFG_TMS9928A_SCREEN_ADD_NTSC( "screen" )
338   MCFG_SCREEN_UPDATE_DEVICE( "tms9928a", tms9928a_device, screen_update )
337   MCFG_TMS9928A_SCREEN_ADD_NTSC("screen")
338   MCFG_SCREEN_UPDATE_DEVICE("tms9928a", tms9928a_device, screen_update)
339339
340   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_ntsc )
341   MCFG_MACHINE_RESET_OVERRIDE(svi318_state, svi318 )
340   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_ntsc)
341   MCFG_MACHINE_RESET_OVERRIDE(svi318_state, svi318)
342342MACHINE_CONFIG_END
343343
344344static MACHINE_CONFIG_DERIVED( svi328, svi318 )
r32256r32257
378378
379379static MACHINE_CONFIG_START( svi328_806, svi318_state )
380380   /* Basic machine hardware */
381   MCFG_CPU_ADD( "maincpu", Z80, 3579545 ) /* 3.579545 MHz */
382   MCFG_CPU_PROGRAM_MAP( svi328_806_mem)
383   MCFG_CPU_IO_MAP( svi328_806_io)
381   MCFG_CPU_ADD("maincpu", Z80, 3579545) /* 3.579545 MHz */
382   MCFG_CPU_PROGRAM_MAP(svi328_806_mem)
383   MCFG_CPU_IO_MAP(svi328_806_io)
384384   MCFG_QUANTUM_TIME(attotime::from_hz(60))
385385
386   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_pal )
387   MCFG_MACHINE_RESET_OVERRIDE(svi318_state, svi328_806 )
386   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_pal)
387   MCFG_MACHINE_RESET_OVERRIDE(svi318_state, svi328_806)
388388
389389   MCFG_DEVICE_ADD("ppi8255", I8255, 0)
390   MCFG_I8255_IN_PORTA_CB(READ8(svi318_state, svi318_ppi_port_a_r))
391   MCFG_I8255_IN_PORTB_CB(READ8(svi318_state, svi318_ppi_port_b_r))
392   MCFG_I8255_OUT_PORTC_CB(WRITE8(svi318_state, svi318_ppi_port_c_w))
390   MCFG_I8255_IN_PORTA_CB(READ8(svi318_state, ppi_port_a_r))
391   MCFG_I8255_IN_PORTB_CB(READ8(svi318_state, ppi_port_b_r))
392   MCFG_I8255_OUT_PORTC_CB(WRITE8(svi318_state, ppi_port_c_w))
393393
394   MCFG_DEVICE_ADD( "ins8250_0", INS8250, 1000000 )
395   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, svi318_ins8250_interrupt))
396   MCFG_DEVICE_ADD( "ins8250_1", INS8250, 3072000 )
397   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, svi318_ins8250_interrupt))
394   MCFG_DEVICE_ADD("ins8250_0", INS8250, 1000000)
395   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, ins8250_interrupt))
396   MCFG_DEVICE_ADD("ins8250_1", INS8250, 3072000)
397   MCFG_INS8250_OUT_INT_CB(WRITELINE(svi318_state, ins8250_interrupt))
398398
399399   /* Video hardware */
400   MCFG_DEFAULT_LAYOUT( layout_dualhsxs )
400   MCFG_DEFAULT_LAYOUT(layout_dualhsxs)
401401
402   MCFG_DEVICE_ADD( "tms9928a", TMS9929A, XTAL_10_738635MHz / 2 )
402   MCFG_DEVICE_ADD("tms9928a", TMS9929A, XTAL_10_738635MHz / 2)
403403   MCFG_TMS9928A_VRAM_SIZE(0x4000)
404404   MCFG_TMS9928A_OUT_INT_LINE_CB(WRITELINE(svi318_state, vdp_interrupt))
405   MCFG_TMS9928A_SET_SCREEN( "screen" )
406   MCFG_TMS9928A_SCREEN_ADD_PAL( "screen" )
407   MCFG_SCREEN_UPDATE_DEVICE( "tms9928a", tms9929a_device, screen_update )
405   MCFG_TMS9928A_SET_SCREEN("screen")
406   MCFG_TMS9928A_SCREEN_ADD_PAL("screen")
407   MCFG_SCREEN_UPDATE_DEVICE("tms9928a", tms9929a_device, screen_update)
408408   MCFG_PALETTE_ADD("palette", TMS9928A_PALETTE_SIZE + 2)  /* 2 additional entries for monochrome svi806 output */
409409
410410   MCFG_SCREEN_ADD("svi806", RASTER)
r32256r32257
421421   MCFG_MC6845_CHAR_WIDTH(8)   /* ? */
422422   MCFG_MC6845_UPDATE_ROW_CB(svi318_state, crtc_update_row)
423423
424   MCFG_VIDEO_START_OVERRIDE(svi318_state, svi328_806 )
424   MCFG_VIDEO_START_OVERRIDE(svi318_state, svi328_806)
425425
426426   /* Sound hardware */
427427   MCFG_SPEAKER_STANDARD_MONO("mono")
r32256r32257
430430   MCFG_SOUND_WAVE_ADD(WAVE_TAG, "cassette")
431431   MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.25)
432432   MCFG_SOUND_ADD("ay8910", AY8910, 1789773)
433   MCFG_AY8910_PORT_A_READ_CB(READ8(svi318_state, svi318_psg_port_a_r))
434   MCFG_AY8910_PORT_B_WRITE_CB(WRITE8(svi318_state, svi318_psg_port_b_w))
433   MCFG_AY8910_PORT_A_READ_CB(READ8(svi318_state, psg_port_a_r))
434   MCFG_AY8910_PORT_B_WRITE_CB(WRITE8(svi318_state, psg_port_b_w))
435435   MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.75)
436436
437437   /* printer */
r32256r32257
440440
441441   MCFG_CENTRONICS_OUTPUT_LATCH_ADD("cent_data_out", "centronics")
442442
443   MCFG_CASSETTE_ADD( "cassette" )
443   MCFG_CASSETTE_ADD("cassette")
444444   MCFG_CASSETTE_FORMATS(svi_cassette_formats)
445445   MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_PLAY)
446446   MCFG_CASSETTE_INTERFACE("svi318_cass")
447447
448448   MCFG_DEVICE_ADD("wd179x", FD1793, 0)
449449   MCFG_WD17XX_DEFAULT_DRIVE2_TAGS
450   MCFG_WD17XX_INTRQ_CALLBACK(WRITELINE(svi318_state,svi_fdc_intrq_w))
451   MCFG_WD17XX_DRQ_CALLBACK(WRITELINE(svi318_state,svi_fdc_drq_w))
450   MCFG_WD17XX_INTRQ_CALLBACK(WRITELINE(svi318_state, fdc_intrq_w))
451   MCFG_WD17XX_DRQ_CALLBACK(WRITELINE(svi318_state, fdc_drq_w))
452452
453453   MCFG_LEGACY_FLOPPY_2_DRIVES_ADD(svi318_floppy_interface)
454454
455   MCFG_FRAGMENT_ADD( svi318_cartslot )
455   MCFG_FRAGMENT_ADD(svi318_cartslot)
456456
457457   /* internal ram */
458458   MCFG_RAM_ADD(RAM_TAG)
r32256r32257
462462
463463static MACHINE_CONFIG_DERIVED( svi328n_806, svi328_806 )
464464
465   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_ntsc )
465   MCFG_MACHINE_START_OVERRIDE(svi318_state, svi318_ntsc)
466466
467467   MCFG_SCREEN_MODIFY("screen")
468468   MCFG_SCREEN_REFRESH_RATE(60)

Previous 199869 Revisions Next


© 1997-2024 The MAME Team