-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathindex.html
486 lines (460 loc) · 25.1 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
<!--
/**
* SPDX-FileCopyrightText: 2022-2023 Zeal 8-bit Computer <[email protected]>
*
* SPDX-License-Identifier: Apache-2.0
*/
-->
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Zeal 8-bit Computer Emulator</title>
<link rel="icon" href="imgs/zeal.png" sizes="16x16">
<!-- Emulator's stylesheet -->
<link rel="stylesheet" type="text/css" href="view/css/emulator.css" media="screen" />
<link rel="stylesheet" type="text/css" href="view/css/interface.css" media="screen" />
<!-- jQuery -->
<script src="component/jquery/jquery-3.6.0.min.js"></script>
<script src="component/jquery/extend.js"></script>
<!-- Xterm -->
<script src="component/xterm/xterm.js"></script>
<link rel="stylesheet" href="component/xterm/xterm.css" />
<!-- Hash value -->
<script src="component/crypto/sha256.js"></script>
<!-- Disassembler-related -->
<script src="component/disassembler/disassembler.js"></script>
<script src="component/disassembler/opcodes_cb.js"></script>
<script src="component/disassembler/opcodes_ed.js"></script>
<script src="component/disassembler/opcodes_ixiy.js"></script>
<!-- Debug related -->
<script src="component/debug/vcd.js"></script>
</head>
<body>
<section id="popup-message"></section>
<section id="blackbg"></section>
<section class="popup" id="about-message">
<h2>About Zeal 8-bit Computer emulator</h2>
<p>The purpose of this project is to provide an easy way to try Zeal 8-bit Computer, as well as develop and debug for it thanks to the embedded debugger. The emulation is <strong>cycle accurate</strong>, so the behavior of the programs run inside this emulator should be the exact same as on the real hardware.</p>
<figure>
<img src="imgs/help/motherboard.png" alt="Zeal 8-bit Motherboard" />
<figcaption>Zeal 8-bit Computer Motherboard</figcaption>
</figure>
<p>You can find more information about <a href="https://www.youtube.com/c/Zeal8bitComputer"><strong>Zeal 8-bit Computer on Youtube</strong></a> or on the project official website <a href="https://zeal8bit.com"><strong>zeal8bit.com</strong></a></p>
<h3>Source code</h3>
<p>The source code of the emulator is available on the official Github repository: <a href="https://github.com/Zeal8bit/Zeal-WebEmulator"><strong>https://github.com/Zeal8bit/Zeal-WebEmulator</strong></a></p>
<h3>Licence</h3>
<p>The CPU core (<code>Z80.js</code>) is distributed under the MIT license (originated from <a href="https://github.com/DrGoldfire/Z80.js">Molly Howell repository</a>)</p>
<p>All the other files of the project are distributed under the Apache 2.0 License.</p>
<h3>Credits</h3>
<p>People involved in the project:</p>
<ul>
<li><a href="https://github.com/Zeal8bit">Zeal8bit</a>: owner, main developer and maintainer</li>
<li><a href="https://github.com/JasonMo1">JasonMo</a>: contributor</li>
<li><a href="https://github.com/ZT-Pepite">ZT-Pepite</a>: contributor</li>
</ul>
<p>For more details about the contributors, <a href="https://github.com/Zeal8bit/Zeal-WebEmulator/graphs/contributors">follow this link</a>.</p>
</section>
<section class="popup" id="help-message" markdown="1">
<h2>Getting started with the emulator</h2>
<p>The interface of Zeal 8-bit Computer emulator is rich in tools. They make it possible to simulate almost every part of the actual computer.</p>
<figure>
<img src="imgs/help/gui.png" alt="GUI" />
<figcaption>Interface organization</figcaption>
</figure>
<ol>
<li>ROM/EEPROM loading</li>
<li>Emulated screen and PS/2 keyboard</li>
<li>Bottom views: disassembler, memory viewer and UART monitor</li>
<li>Debugging actions: start/resume CPU, step in, step over, stop, reset, clean</li>
<li>Breakpoint management</li>
<li>CPU registers value</li>
</ol>
<h3>Loading a ROM</h3>
<p>Loading a ROM can be done through the left panel section:</p>
<figure>
<img src="imgs/help/rom.png" alt="ROM Selection" />
<figcaption>ROM Selection</figcaption>
</figure>
<p>The emulator offers two ways to load code inside the ROM:</p>
<ul>
<li>Select a pre-built ROM image of Zeal 8-bit OS. This includes the latest version, nightly builds and the releases. All of them are compiled from <a href="https://github.com/Zeal8bit/Zeal-8-bit-OS">Zeal 8-bit OS official repository</a>.</li>
<li>Load your own image of the ROM, and an optional (64KB) EEPROM image. Since the images will directly be copied inside the emulated ROM and EEPROM respectively, this image <strong>does not</strong> necessarily contain Zeal 8-bit OS, it can contain any Z80 code. The <code>system map</code> file, as its name states, is the <code>.map</code> file generated by <code>z88dk-z80asm</code> when assembling a program. Providing this file will add symbols inside the disassembler.</li>
</ul>
<p>The first option is preferred if you want to quickly test Zeal 8-bit OS, or if you want to load your own programs, while the second option is preferred if you want to debug the operating system itself or a ROM image you have.</p>
<blockquote>
<p><strong>Note:</strong> when loading your own images and clicking <code>Read file(s)</code> button, it is necessary to press debugger's <code>Continue</code> button to start the CPU!</p>
</blockquote>
<h3>Emulated screen and PS/2 keyboard</h3>
<p>At the middle of the interface lies a 640x480px canvas that emulates Zeal 8-bit VGA video board. This interface will draw all the pixels that would be drawn by the VGA video board.</p>
<figure>
<img src="imgs/help/screen.png" alt="Screen" />
<figcaption>Screen emulation</figcaption>
</figure>
<p>This canvas also contains a keyboard listener that will send all the keys typed to the PS/2 protocol emulator. Therefore, the canvas <strong>must be focused first</strong> (by clicking on it) before trying to type anything.</p>
<h3>Disassembler</h3>
<p>The disassembler, as its name states, disassembles the binary code being executed by the Z80 CPU into assembly code. It also shows the current breakpoints with a small red dot on the left. It is possible to add or remove breakpoints from there by clicking on the corresponding instruction.</p>
<figure>
<img src="imgs/help/disassembler.png" alt="Disassembler" />
<figcaption>Disassembler view</figcaption>
</figure>
<p>The current instruction (current PC) will always be at the top of the disassembler view. The format of each line is as follows:</p>
<p><code>[dot] instruction ; [virtual address] raw bytes of the instruction</code></p>
<p>The code is only disassembled when the CPU is <strong>stopped</strong>, either because it encountered a breakpoint or when the <code>stop</code> button is manually pressed.</p>
<blockquote>
<p><strong>Note:</strong> If a <code>.map</code> file was provided when loading the ROM, the symbols, such as the routines or labels name, will also be shown. Constants are not replaced in <code>ld</code> or related instructions since these information are not provided by the map file.</p>
</blockquote>
<h3>Memory viewer</h3>
<p>The memory viewer tool is convenient to see the content of memory at any address. The address and size to dump can be provided via the text inputs. The address must be provided in <strong>hexadecimal</strong> whereas the size is provided in <strong>decimal</strong>.</p>
<figure>
<img src="imgs/help/memory.png" alt="Memory viewer" />
<figcaption>Memory viewer</figcaption>
</figure>
<p>The provided address is a <strong>virtual address</strong> and not physical address. This is important since Zeal 8-bit Computer has an MMU, so each 16KB virtual pages can be mapped to any 16KB physical page.</p>
<p>The dump memory lines are presented as follows:</p>
<p><code>virtual address (physical address) 32-byte dump ASCII representation</code></p>
<p>This view also provides two buttons to dump the current ROM and (I2C) EEPROM content respectively.</p>
<blockquote>
<p><strong>Note:</strong> This view is only updated when the <code>dump</code> button is pressed. If a byte in memory changes, the view won't show the new value until the view is refreshed (<code>dump</code> button pressed)</p>
</blockquote>
<h3>UART monitor</h3>
<p>Zeal 8-bit Computer provides has a UART interface. Even though it is a software UART implemented with the Z80 PIO, it can also be used on the emulator thanks to the cycle accurate emulation.</p>
<figure>
<img src="imgs/help/uart.png" alt="UART monitor" />
<figcaption>UART monitor</figcaption>
</figure>
<p>This tool can be used to see the data sent by the computer through UART, but also to send text, including files. The baudrate can be configured by using the option menu.</p>
<p>Keep in mind that if it seems like the monitor doesn't have any reaction when typing in the monitor, it is because the CPU is not currently listening on the UART, sending anything ot the UART.</p>
<h3>Debug actions</h3>
<p>The right panel is dedicated to debug actions. It contains the follow actions:</p>
<figure>
<img src="imgs/help/actions.png" alt="Debug actions" />
<figcaption>Debug actions</figcaption>
</figure>
<ul>
<li>Start/resume CPU execution (F9 shortcut)</li>
<li>Step into (F10): clicking this button when performing step by step debugging will follow the destination of jump instructions such as <code>rst</code>, <code>call</code>, <code>jp</code>, <code>jr</code>...</li>
<li>Step over (F11): clicking this button when performing step by step debugging will execute the following jump instructions but will break after it.</li>
<li>Stop: stop the CPU execution, showing the registers value</li>
<li>Reset: performs a CPU reset</li>
<li>Clean: completely cleans the ROM, RAM and EEPROM in order to load a new program to the board. This feature is used when switching between pre-built ROMs</li>
</ul>
<h3>Breakpoint management</h3>
<p>Just like a regular debugger, it is possible to put breakpoints that will stop the CPU execution, showing the current value of the CPU registers and code disassembly.</p>
<figure>
<img src="imgs/help/break.png" alt="Breakpoints" />
<figcaption>Breakpoints</figcaption>
</figure>
<p>The text entry accepts <strong>hexadecimal</strong> values, with or without <code>0x</code> prefix. Moreover, if a <code>.map</code> file is provided, it is possible to write the name of label to break on. This is convenient to debug a program's function/routine that often has a different address.</p>
<p>Breakpoints can be disabled by clicking on the red dot and re-enabled by clicking them again.</p>
<p>It is currently not possible to completely remove breakpoints.</p>
<h3>CPU registers</h3>
<p>The left panel present a direct way to see the CPU register value when the CPU stops because of a breakpoint or a manual stop.</p>
<figure>
<img src="imgs/help/registers.png" alt="CPU Registers" />
<figcaption>CPU Registers</figcaption>
</figure>
<p>The 16-bit registers, <code>BC</code>, <code>DE</code>, <code>HL</code>, <code>PC</code>, <code>SP</code> have an underlines value to show that they are clickable. By clinking on a value, the memory viewer will be opened and will show the content of the address.</p>
</section>
<section id="toppanel">
<section id="debug">
<table>
<tr><td>A</td><td id="rega"></td></tr>
<tr><td>B</td><td id="regb"></td></tr>
<tr><td>C</td><td id="regc"></td></tr>
<tr><td>D</td><td id="regd"></td></tr>
<tr><td>E</td><td id="rege"></td></tr>
<tr><td>H</td><td id="regh"></td></tr>
<tr><td>L</td><td id="regl"></td></tr>
<tr><td>IX</td><td id="regix" class="regaddr"></td></tr>
<tr><td>IY</td><td id="regiy" class="regaddr"></td></tr>
<tr><td>BC</td><td id="regbc" class="regaddr"></td></tr>
<tr><td>DE</td><td id="regde" class="regaddr"></td></tr>
<tr><td>HL</td><td id="reghl" class="regaddr"></td></tr>
<tr><td>PC</td><td id="regpc" class="regaddr"></td></tr>
<tr><td>SP</td><td id="regsp" class="regaddr"></td></tr>
<tr><td>Flags</td><td id="flags"></td></tr>
<tr><td>T-States</td><td id="tstates"></td></tr>
</table>
<section id="romload">
<label for="romchoice">Choose a pre-built ROM:</label>
<img src="imgs/loading.gif" id="loading_img" alt="loading..." />
<select name="romchoice" id="romchoice">
<option value="">Loading...</option>
</select>
<section id="romadvanced">
<a id="romload-advanced">Advanced...</a>
</section>
</section>
<section id="romfile">
<label for="file-rom">System image:</label>
<div class="help" title="File to load into the emulated ROM. It take be a single system binary or an image containing the system and a romdisk">?</div>
<input type="file" id="file-rom" placeholder="OS file" />
<label for="file-map">System map file:</label>
<div class="help" title="Map file (text) generated by z88dk-z80asm containing the symbols of the binary image/file">?</div>
<input type="file" id="file-map" placeholder="OS dump" />
<label for="file-eeprom">EEPROM image:</label>
<div class="help" title="Binary file to load into the emulated 64KB I2C EEPROM">?</div>
<input type="file" id="file-eeprom" placeholder="EEPROM image" />
<label for="file-cf">CompactFlash image:</label>
<div class="help" title="Binary file to load into the emulated CompactFlash">?</div>
<input type="file" id="file-cf" placeholder="CompactFlash image" />
<button id="read-button">Read file(s)</button>
<div id="statuspan">
<h4>Ready?</h4>
<div id="romready" class="status">System image</div>
<div id="symready" class="status">Symbols</div>
<div id="eepromready" class="status">EEPROM image</div>
<div id="cfready" class="status">CompactFlash image</div>
</div>
<pre id="file-contents"></pre>
</section>
</section>
<div id="container">
<div class="close">X</div>
<canvas id="screen" tabindex="1" style="outline: none;"></canvas>
</div>
<section id="rightpanel">
<section class="menu" id="menu-controls">
<img id="continue" title="Continue (F9)" src="imgs/continue.png" class="cpuexec" alt="Continue" style="display: none;"/>
<img id="pause" title="Pause (F9)" src="imgs/pause.png" alt="Pause" class="cpuexec hidden" />
<img id="step" title="Step (F10)" src="imgs/step.png" alt="Step" />
<img id="stepover" title="Step Over (F11)" src="imgs/stepover.png" alt="Step over" />
<img id="reset" title="Reset" src="imgs/restart.png" alt="Reset">
<img id="clean" title="Clean" src="imgs/clean.png" alt="Clean">
</section>
<section class="menu" id="menu-breakpoints">
<section class="menutitle">Breakpoints</section>
<section class="menucontent">
<section id="newbp">
<input type="text" id="bpaddr" />
<button id="addbp">Add</button>
</section>
<section id="breakpoints">
<ul id="bps">
</ul>
</section>
</section>
</section>
<section class="menu" id="menu-settings">
<section class="menutitle">Settings</section>
<section class="menucontent">
<label>
Switch theme:
<select id="theme" name="theme">
<option value="dark" selected>Dark (Default)</option>
<option value="light">Light</option>
</select>
</label>
<label>
Canvas Smoothing
<input type="checkbox" id="canvas-smooth-val" />
</label>
<label>
T-State Logger
<input type="checkbox" id="t-state-logger-val" />
</label>
<div id="web-serial-settings">
<label>Web Serial:</label>
<button id="web-serial-connect">Connect Serial</button>
</div>
<button id="screen-capture">Capture Screen</button>
<button id="theater-mode">Theater Mode</button>
<button id="fullscreen-mode" style="display: none;">Full Screen</button>
<button id="hostfs-mount">Mount HostFS</button>
<button id="console-paste">Paste to Console</button>
</section>
</section>
</section>
</section>
<section class="bottompanel">
<section class="tabs">
<div id="disassemble-tab" class="tab">Disassemble</div>
<div id="memory-tab" class="tab">Memory view</div>
<div id="uart-tab" class="tab">Terminal (UART)</div>
<div id="gamepad-tab" class="tab">Gamepad <span class="tab-status">🔴</span></div>
<div id="video-tab" class="tab">Video</div>
</section>
<section id="memdump" class="panel">
</section>
<section id="memview" class="panel">
<section class="panel-toolbar">
<input type="text" id="dumpaddr" placeholder="Hex address" />
<input type="text" id="dumpsize" placeholder="Size" value="256" />
<input type="button" id="dumpnow" value="Dump" />
<input type="button" id="dump-button" value="Dump ROM" />
<input type="button" id="dump-eeprom-button" value="Dump EEPROM" />
<a id="dump-link" download="rom_dump.bin" style="display: none;">Dump ROM</a>
<a id="dump-eeprom-link" download="eeprom_dump.bin" style="display: none;">Dump EEPROM</a>
</section>
<div class="sub-panel">
<section class="memline">
<section id="current_memaddr" class="memaddr"></section>
</section>
<section id="dumpcontent">
</section>
</div>
</section>
<section id="uartview" class="panel">
<div class="panel-toolbar">
<input type="button" id="clearterm" value="Clear" />
<label>
Baudrate:
<select id="baudrate">
<option value="57600">57600</option>
<option value="38400">38400 </option>
<option value="19200">19200</option>
<option value="9600">9600</option>
</select>
</label>
<label>
File:
<input type="file" id="uart-file" placeholder="Send a file through UART" />
</label>
<button id="uart-file-send">Send</button>
<input type="number" id="uart-char" value="21" class="short" />
<input type="button" id="uart-char-send" value="Send Byte" />
<label>
Cols: <input type="number" value="80" style="width: 5ch;" id="uart-cols" />
</label>
<label>
Rows: <input type="number" value="24" style="width: 5ch;" id="uart-rows" />
</label>
</div>
<div id="terminal"></div>
</section>
<section id="gamepad" class="panel">
<div class="panel-toolbar hidden">
</div>
<div id="gamepadview-start">Press a button on your controller to start</div>
<div id="gamepadview" class="sub-panel empty">
</div>
</section>
<section id="video" class="panel">
<div class="panel-toolbar">
<input type="button" id="video-dump" value="Dump" />
<label>
<input type="checkbox" id="video-palette" class="toggle" name="palette" checked />
Show Palette
</label>
<label>
<input type="checkbox" id="video-palette" class="toggle" name="fonts" />
Show Fonts
</label>
<label>
<input type="checkbox" id="video-tileset" class="toggle" name="tileset" checked />
Show Tileset
</label>
<label>
<input type="checkbox" id="video-sprites" class="toggle" name="sprites" />
Show Sprites
</label>
<label>
<input type="checkbox" id="video-tilemap" class="toggle" name="tilemap" />
Show Tilemap
</label>
</div>
<details class="sub-panel" name="palette" open>
<summary>Palette</summary>
<div class="palette"></div>
</details>
<details class="sub-panel" name="fonts">
<summary>Fonts</summary>
<div class="fonts"></div>
</details>
<details class="sub-panel" name="tileset" open>
<summary>Tileset</summary>
<div class="tileset"></div>
</details>
<details class="sub-panel" name="sprites" open>
<summary>Sprites</summary>
<div class="panel-toolbar">
<label>
<input type="checkbox" class="data" name="sprites-empty" />
Hide Empty
</label>
<label>
<input type="checkbox" class="data" name="sprites-details" />
Show Details
</label>
<label>
<input type="number" min="0" max="512" class="data" name="sprites-empty-index" value="0" />
Empty Index
</label>
</div>
<div class="sprites"></div>
</details>
<details class="sub-panel" name="tilemap">
<summary>Tilemap</summary>
<div class="panel-toolbar">
<label>
<input type="checkbox" class="data" name="tilemap-layer0" />
Layer0
</label>
<label>
<input type="checkbox" class="data" name="tilemap-layer1" />
Layer1
</label>
<label>
<input type="checkbox" class="data" name="tilemap-sprites" />
Sprites
</label>
<label>
<input type="checkbox" class="data" name="tilemap-grid" />
Show Grid
</label>
<label>
<input type="color" class="data" name="tilemap-grid-color" value="#ff0000" />
Grid Color
</label>
</div>
<div class="tilemap"></div>
</details>
</section>
</section>
<footer>
<ul>
<li><a id="about" data-target="about-message">About</a></li>
<li><a id="help" data-target="help-message">Help</a></li>
<li>©2022-2024 Zeal8bit</li>
<li>v1.0.0-dev</li>
</ul>
</footer>
<!-- Emulation-related -->
<script src="hardemu/characters.js"></script>
<script src="hardemu/rom.js"></script>
<script src="hardemu/pio.js"></script>
<script src="hardemu/uart.js"></script>
<script src="hardemu/uart-web-serial.js"></script>
<script src="hardemu/keyboard.js"></script>
<script src="hardemu/i2c.js"></script>
<script src="hardemu/ram.js"></script>
<script src="hardemu/mmu.js"></script>
<script src="hardemu/compactflash.js"></script>
<script src="hardemu/Z80.js"></script>
<script src="view/popup.js"></script>
<script src="hardemu/videoboard/crc32.js"></script>
<script src="hardemu/videoboard/sound.js"></script>
<script src="hardemu/screen.js"></script>
<script src="hardemu/hostfs.js"></script>
<script src="hardemu/machine.js"></script>
<script src="hardemu/zeal8bitcomputer.js"></script>
<!-- Emulated User Port -->
<script src="hardemu/user-port/snes-adapter.js"></script>
<!-- view scripts -->
<script src="view/utils.js"></script>
<script src="view/breakpoint.js"></script>
<script src="view/menus.js"></script>
<script src="view/screen.js"></script>
<script src="view/regs_panel.js"></script>
<script src="view/readrom.js"></script>
<script src="view/init.js"></script>
<!-- Tabs -->
<script src="view/tabs/tabs.js"></script>
<script src="view/tabs/disassemble.js"></script>
<script src="view/tabs/memdump.js"></script>
<script src="view/tabs/uart_terminal.js"></script>
<script src="view/tabs/gamepad.js"></script>
<script src="view/tabs/video.js"></script>
</body>
</html>