URL
https://opencores.org/ocsvn/tv80/tv80/trunk
Subversion Repositories tv80
[/] [tv80/] [branches/] [restruc2/] [doc/] [tv80_docs.xml] - Rev 46
Go to most recent revision | Compare with Previous | Blame | View Log
<?xml version="1.0"?><!DOCTYPE rfc SYSTEM "rfc2629.dtd"><?rfc toc="yes"?><?rfc private="$Revision: 1.4 $"?><?rfc compact="yes"?><rfc><front><title>tv80 Core Documentation</title><author initials="G." surname="Hutchison" fullname="Guy Hutchison"><organization>OpenCores.org</organization><address><email>ghutchis@opencores.org</email></address></author><date month="October" year="2004" /><area>General</area><keyword>private</keyword><keyword>XML</keyword><keyword>Extensible Markup Language</keyword><abstract><t>A synthesizable 8-bit microprocessor which is instruction-set compatablewith the Z80, targetted at embedded and system-on-a-chip designs.</t></abstract></front><middle><section title="Background"><t>The tv80 core was created as a Verilog port of the <xref target="t80">VHDL T80 core</xref>, for use as a maintenence processor inside an ASIC.The tv80 has been modified since then for better synthesistiming/area results, and to incorporate several bug-fixes.</t><t>The T80, and the tv80 derived from it, attempt to maintain theoriginal cycle timings of the Z80, but have radically differentinternal designs and timings. With its target being ASIC andembedded applications, the tv80 does not attempt to maintainthe original pinout of the Z80.</t></section><section title="Verification Environment"><section title="Memory Map"><t>Environment memory space is divided into a 32k ROM region and a 32k RAMregion, as follows:<figure><artwork>0000-7FFF: ROM8000-FFFF: RAM</artwork></figure><t>Environment I/O space is allocated as follows:</t><figure><artwork>00-0F: Unused10-1F: Test devices20-7F: Unused80-9F: Environment controlA0-FF: Unused</artwork></figure></t></section><section title="Control Registers">The tv80 environment is controlled by the program under simulation. Theprogram can affect the environment through a set of control registers,which are mapped into I/O space.<section title="Simulation control (0x80)"><list style="symbols"><t> Write '01' to end simulation with test passed</t><t> Write '02' to end with test failed</t><t> Write '03' to turn on dumping</t><t> Write '04' to turn off dumping</t></list></section><section title="Message output (0x81)"><t>Write characters to this port one at a time. When thenewline ('\n', ASCII 0x0A) character is written, theenvironment will print out the collected string.</t></section><section title="Timeout control (0x82)"><t>Bit[0] enables the timeout counter,Bit[1] resets the counter to 0.Timeout counter defaults to enabled at simulation start.</t></section><section title="Max timeout (0x84, 0x83)"><t>Holds 16-bit timeout value (amount of time in clocks beforetimeout error occurs).</t></section><section title="Interrupt countdown (0x90)"><t>When set, starts a countdown (in clocks) until assertion ofthe INT_N signal.</t></section><section title="Checksum value (0x91)"><t>This register holds the checksum value of all datawritten to the accumulate register. The checksum is a simpletwos-complement checksum, so it can be compared with a CPU-generatedchecksum.</t><t>This register is readable and writeable. Writing the register setsthe current checksum value.</t></section><section title="Checksum accumulate (0x92)"><t>This write-only register adds the written value to the valuecontained in the Checksum Value register.</t></section><section title="Increment on read (0x93)"><t>This register increments every time it is read, so reading itrepeatedly generates an incrementing sequence. It can be resetby writing it to a new starting value.</t></section></section><section title="Tool Chain"><t>The minimum toolchain required to simulate the tv80 is the<xref target="cver">CVer</xref> Verilog simulator, and the<xref target="sdcc">SDCC</xref> compiler/assembler/linker. Inaddition, to run the <xref target="tvs80">tvs80</xref> instructiontest suite, the <xref target="dosbox">DOSBox</xref> DOS emulatoris required.</t></section><section title="Tests"><t>Most of the tests in the tv80 environment are written in C, and shouldbe compiled with the <xref target="sdcc">sdcc</xref> compiler.</t><section anchor="tvs80" title="tvs80 test"><t>The tvs80 test is different than the rest of the tests, and iswritten in its own flavor of assembly language. This test providesa fairly comprehensive Z80 instruction test.</t><t>The assembler for this test only runs under DOS. To assembleunder Unix/Linux, the <xref target="dosbox">"dosbox" DOS emulator</xref> is required. A scriptto run the assembler under dosbox, as well as the tvs80.asm source,is checked in under the "tests/tvs80" directory.</t></section></section></section></middle><back><references><reference anchor="t80" target="http://www.opencores.org/projects.cgi/web/t80/overview"><front><title>VHDL T80 Core</title><author initials="D." surname="Wallner" fullname="Daniel Wallner"><organization>OpenCores.org</organization></author></front></reference><reference anchor="sdcc" target="http://sdcc.sourceforge.net"><front><title>Small Device C Compiler</title></front></reference><reference anchor="cver" target="http://www.pragmatic-c.com/gpl-cver"><front><title>GPL Cver Simulator</title><author initials="A." surname="Vanvick" fullname="Andrew Vanvick"><organization>Pragmatic C Software</organization></author></front></reference><reference anchor="dosbox" target="http://dosbox.sourceforge.net"><front><title>DOSBox</title></front></reference></references></back></rfc>
Go to most recent revision | Compare with Previous | Blame | View Log
