1 // license:BSD-3-Clause
2 // copyright-holders:AJR
3 /****************************************************************************
4 
5     Skeleton driver for AT&T Model 3B2 computer.
6 
7 ****************************************************************************/
8 
9 #include "emu.h"
10 #include "cpu/we32000/we32100.h"
11 #include "machine/am9517a.h"
12 #include "machine/mc68681.h"
13 #include "machine/pit8253.h"
14 //#include "machine/upd7261.h"
15 #include "machine/wd_fdc.h"
16 
17 class att3b2_state : public driver_device
18 {
19 public:
att3b2_state(const machine_config & mconfig,device_type type,const char * tag)20 	att3b2_state(const machine_config &mconfig, device_type type, const char *tag)
21 		: driver_device(mconfig, type, tag)
22 		, m_maincpu(*this, "maincpu")
23 	{
24 	}
25 
26 	void att3b2v2(machine_config &config);
27 	void att3b2v3(machine_config &config);
28 
29 private:
30 	void mem_map_300(address_map &map);
31 	void mem_map_600(address_map &map);
32 
33 	required_device<we32100_device> m_maincpu;
34 };
35 
36 
mem_map_300(address_map & map)37 void att3b2_state::mem_map_300(address_map &map)
38 {
39 	map.global_mask(0x07ffffff); // 27-bit physical addresses
40 	map(0x00000000, 0x00007fff).rom().region("bootstrap", 0);
41 	map(0x00042000, 0x0004200f).rw("pit", FUNC(pit8253_device::read), FUNC(pit8253_device::write)).umask32(0x000000ff);
42 	//map(0x00042013, 0x00042013).r(FUNC(att3b2_state::clear_csr6_r));
43 	//map(0x00043000, 0x00043fff).rw(FUNC(att3b2_state::nvram_nibble_r), FUNC(att3b2_state::nvram_nibble_w)).umask32(0x00ff00ff);
44 	//map(0x00044000, 0x0004403f).w(FUNC(att3b2_state::csr_w)).umask32(0x000000ff);
45 	//map(0x00044002, 0x00044003).r(FUNC(att3b2_state::csr_r));
46 	//map(0x00045003, 0x00045003).w(FUNC(att3b2_state::hard_disk_page_w));
47 	map(0x00048000, 0x0004800f).rw("dmac", FUNC(am9517a_device::read), FUNC(am9517a_device::write));
48 	map(0x00049000, 0x0004900f).rw("duart", FUNC(scn2681_device::read), FUNC(scn2681_device::write));
49 	//map(0x0004a000, 0x0004a001).rw("hdc", FUNC(upd7261_device::read), FUNC(upd7261_device::write));
50 	//map(0x0004c003, 0x0004c003).r(FUNC(att3b2_state::dpdram_size_r));
51 	map(0x0004d000, 0x0004d003).rw("fdc", FUNC(wd2797_device::read), FUNC(wd2797_device::write));
52 	map(0x02000000, 0x0203ffff).ram();
53 }
54 
mem_map_600(address_map & map)55 void att3b2_state::mem_map_600(address_map &map)
56 {
57 	map(0x00000000, 0x0001ffff).rom().region("bootstrap", 0);
58 	//map(0x00040003, 0x00040003).w(FUNC(att3b2_state::floppy_control_w));
59 	map(0x00041000, 0x0004100f).rw("pit", FUNC(pit8254_device::read), FUNC(pit8254_device::write)).umask32(0x000000ff);
60 	//map(0x00042000, 0x00043fff).rw(FUNC(att3b2_state::nvram_byte_r), FUNC(att3b2_state::nvram_byte_w)).umask32(0x00ff00ff);
61 	//map(0x00045002, 0x00045003).w(FUNC(att3b2_state::floppy_page_12bit_w));
62 	map(0x00048000, 0x0004800f).rw("dmac", FUNC(am9517a_device::read), FUNC(am9517a_device::write));
63 	map(0x00049000, 0x0004900f).rw("duart", FUNC(scn2681_device::read), FUNC(scn2681_device::write));
64 	map(0x0004a000, 0x0004a003).rw("fdc", FUNC(fd1793_device::read), FUNC(fd1793_device::write));
65 	map(0x02000000, 0x0203ffff).mirror(0x1000000).ram();
66 }
67 
68 
INPUT_PORTS_START(att3b2)69 static INPUT_PORTS_START(att3b2)
70 INPUT_PORTS_END
71 
72 void att3b2_state::att3b2v2(machine_config &config)
73 {
74 	WE32100(config, m_maincpu, 10_MHz_XTAL); // special WE32102 XTAL runs at 1x or 2x speed
75 	m_maincpu->set_addrmap(AS_PROGRAM, &att3b2_state::mem_map_300);
76 
77 	PIT8253(config, "pit"); // D8253C-5; unknown clocks
78 
79 	AM9517A(config, "dmac", 5'000'000); // AM9517A-5DC; unknown clock
80 
81 	SCN2681(config, "duart", 3'686'400); // MC2681P
82 
83 	// TODO: hard disk controller (NEC D7261AD)
84 
85 	WD2797(config, "fdc", 1'000'000); // TMS2797NL
86 
87 	// TODO: RTC (MM58174AN)
88 }
89 
att3b2v3(machine_config & config)90 void att3b2_state::att3b2v3(machine_config &config)
91 {
92 	att3b2v2(config);
93 	m_maincpu->set_clock(18'000'000);
94 	m_maincpu->set_addrmap(AS_PROGRAM, &att3b2_state::mem_map_600);
95 
96 	PIT8254(config.replace(), "pit"); // Intel 82C54
97 
98 	FD1793(config.replace(), "fdc", 1'000'000); // FD 1793-02
99 }
100 
101 ROM_START(3b2_300)
102 	ROM_REGION32_BE(0x8000, "bootstrap", 0)
103 	ROM_LOAD32_BYTE("3b2300-c.bin", 0x0000, 0x2000, CRC(b7f955c5) SHA1(54886c4fce5a5681af84538b65de1cc68d0f7af4))
104 	ROM_LOAD32_BYTE("3b2300-d.bin", 0x0001, 0x2000, CRC(5812e262) SHA1(5a69714c0c8f21d7655e43443dee0e76cf219403))
105 	ROM_LOAD32_BYTE("3b2300-e.bin", 0x0002, 0x2000, CRC(e28ca685) SHA1(a337a0480218db8c2d984442f7bc560834853152))
106 	ROM_LOAD32_BYTE("3b2300-f.bin", 0x0003, 0x2000, CRC(b8e138c4) SHA1(d2da4a7150150d0f9294814edb7ed357f9341858))
107 ROM_END
108 
109 ROM_START(3b2_310)
110 	ROM_REGION32_BE(0x8000, "bootstrap", 0)
111 	ROM_LOAD32_BYTE("aayyc.bin", 0x0000, 0x2000, CRC(b7f955c5) SHA1(54886c4fce5a5681af84538b65de1cc68d0f7af4))
112 	ROM_LOAD32_BYTE("aayyd.bin", 0x0001, 0x2000, CRC(5812e262) SHA1(5a69714c0c8f21d7655e43443dee0e76cf219403))
113 	ROM_LOAD32_BYTE("aayye.bin", 0x0002, 0x2000, CRC(e28ca685) SHA1(a337a0480218db8c2d984442f7bc560834853152))
114 	ROM_LOAD32_BYTE("aayyf.bin", 0x0003, 0x2000, CRC(39dcfd8c) SHA1(2e662b3811f78ab689bc2687b73e3158f33f7f89))
115 ROM_END
116 
117 ROM_START(3b2_400)
118 	ROM_REGION32_BE(0x8000, "bootstrap", 0)
119 	ROM_LOAD32_BYTE("3b2-aayyc.bin", 0x0000, 0x2000, CRC(b7f955c5) SHA1(54886c4fce5a5681af84538b65de1cc68d0f7af4))
120 	ROM_LOAD32_BYTE("3b2-aayyd.bin", 0x0001, 0x2000, CRC(5812e262) SHA1(5a69714c0c8f21d7655e43443dee0e76cf219403))
121 	ROM_LOAD32_BYTE("3b2-aayye.bin", 0x0002, 0x2000, CRC(e28ca685) SHA1(a337a0480218db8c2d984442f7bc560834853152))
122 	ROM_LOAD32_BYTE("3b2-aayyf-4.bin", 0x0003, 0x2000, CRC(85b8c5d3) SHA1(85bdf3f889f6c14cbf33ce81421f1f1d02328223))
123 ROM_END
124 
125 ROM_START(3b2_600)
126 	ROM_REGION32_BE(0x20000, "bootstrap", 0)
127 	ROM_LOAD32_BYTE("abtry.bin", 0x0000, 0x8000, CRC(fa8d488b) SHA1(2e169f4171bd30aba1a9cd550a418c943eb78ceb))
128 	ROM_LOAD32_BYTE("abtrw.bin", 0x0001, 0x8000, CRC(8705cb68) SHA1(f41365cd0b4f90d8ad0335655b0ac04a7d14d6c6))
129 	ROM_LOAD32_BYTE("abtru.bin", 0x0002, 0x8000, CRC(ea9e127b) SHA1(6618998ead5a5e07ead8c572619a6bcf71d84497))
130 	ROM_LOAD32_BYTE("abtrt.bin", 0x0003, 0x8000, CRC(0f075161) SHA1(b67c9c4549dc789df33b5a38e4b35fe26fdfbea6))
131 ROM_END
132 
133 COMP(1984, 3b2_300, 0,       0, att3b2v2, att3b2, att3b2_state, empty_init, "AT&T", "3B2/300", MACHINE_IS_SKELETON)
134 COMP(1985, 3b2_310, 3b2_300, 0, att3b2v2, att3b2, att3b2_state, empty_init, "AT&T", "3B2/310", MACHINE_IS_SKELETON)
135 COMP(1985, 3b2_400, 3b2_300, 0, att3b2v2, att3b2, att3b2_state, empty_init, "AT&T", "3B2/400", MACHINE_IS_SKELETON)
136 COMP(1987, 3b2_600, 0,       0, att3b2v3, att3b2, att3b2_state, empty_init, "AT&T", "3B2/600", MACHINE_IS_SKELETON)
137