OpenCores
URL https://opencores.org/ocsvn/openarty/openarty/trunk

Subversion Repositories openarty

[/] [openarty/] [trunk/] [doc/] [src/] [spec.tex] - Blame information for rev 58

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 dgisselq
\documentclass{gqtekspec}
2
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3
%%
4
%% Filename:    spec.tex
5
%%
6
%% Project:     OpenArty, an entirely open SoC based upon the Arty platform
7
%%
8
%% Purpose:
9
%%
10
%% Creator:     Dan Gisselquist, Ph.D.
11
%%              Gisselquist Technology, LLC
12
%%
13
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
14
%%
15
%% Copyright (C) 2015-2016, Gisselquist Technology, LLC
16
%%
17
%% This program is free software (firmware): you can redistribute it and/or
18
%% modify it under the terms of  the GNU General Public License as published
19
%% by the Free Software Foundation, either version 3 of the License, or (at
20
%% your option) any later version.
21
%%
22
%% This program is distributed in the hope that it will be useful, but WITHOUT
23
%% ANY WARRANTY; without even the implied warranty of MERCHANTIBILITY or
24
%% FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
25
%% for more details.
26
%%
27
%% You should have received a copy of the GNU General Public License along
28
%% with this program.  (It's in the $(ROOT)/doc directory, run make with no
29
%% target there if the PDF file isn't present.)  If not, see
30
%% <http://www.gnu.org/licenses/> for a copy.
31
%%
32
%% License:     GPL, v3, as defined and found on www.gnu.org,
33
%%              http://www.gnu.org/licenses/gpl.html
34
%%
35
%%
36
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
37
%%
38
%%
39
\usepackage{import}
40
\usepackage{bytefield}
41 48 dgisselq
\usepackage{listings}
42 2 dgisselq
\project{OpenArty}
43
\title{Specification}
44
\author{Dan Gisselquist, Ph.D.}
45 48 dgisselq
\email{dgisselq (at)  ieee.org}
46 2 dgisselq
\revision{Rev.~0.0}
47
\begin{document}
48
\pagestyle{gqtekspecplain}
49
\titlepage
50
\begin{license}
51
Copyright (C) \theyear\today, Gisselquist Technology, LLC
52
 
53
This project is free software (firmware): you can redistribute it and/or
54
modify it under the terms of  the GNU General Public License as published
55
by the Free Software Foundation, either version 3 of the License, or (at
56
your option) any later version.
57
 
58
This program is distributed in the hope that it will be useful, but WITHOUT
59
ANY WARRANTY; without even the implied warranty of MERCHANTIBILITY or
60
FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
61
for more details.
62
 
63
You should have received a copy of the GNU General Public License along
64
with this program.  If not, see \texttt{http://www.gnu.org/licenses/} for a copy.
65
\end{license}
66
\begin{revisionhistory}
67 36 dgisselq
0.0 &  6/20/2016 & Gisselquist & First Draft \\\hline
68
0.0 & 10/21/2016 & Gisselquist & More Comments Added\\\hline
69 48 dgisselq
0.0 & 11/18/2016 & Gisselquist & Added a getting started section\\\hline
70 2 dgisselq
\end{revisionhistory}
71
% Revision History
72
% Table of Contents, named Contents
73
\tableofcontents
74
\listoffigures
75
\listoftables
76
\begin{preface}
77
\end{preface}
78
 
79 36 dgisselq
\chapter{Introduction}\label{ch:intro}
80 2 dgisselq
\pagenumbering{arabic}
81
\setcounter{page}{1}
82
 
83 48 dgisselq
At {\$ 99}, the Arty is a very economical FPGA platform for doing
84
a lot of things.  It was designed to support the MicroBlaze soft CPU platform,
85
and as a result it has a lot more memory plus ethernet support.  Put together,
86
it feels like it was designed for soft--core CPU development.  Indeed, it has
87
an amazing capability for its price.
88
 
89
Instructions and examples for using the Arty, however, tend to focus on
90
schematic design development techniques.  While these may seem like an
91
appropriate way to introduce a beginner to hardware design, these techniques
92
introduce a whole host of problems.
93
 
94
The first and perhaps biggest problem is that it can be difficult to trouble
95
shoot what is going on.  This is a combination of two factors.  The first is
96
that many of the reference schematic designs make use of proprietary IP.  In
97
an effort to protect both their IP and themselves, companies providing such
98
IP resources often make them opaque, and difficult to see the internals of.
99
As a result, it can be difficult to understand why that IP isn't working in
100
your design.  Further, while many simulation tools exist, only the Xilinx tools
101
will allow full simulation of Xilinx proprietary IP.  Finally, while it may be
102
simple to select a part and ``wire'' it up within a schematic, most IP
103
components have many, many configuration options which are then hidden from the
104
user within the simplified component.  These options may be the difference
105
between successfully using the component and an exercise in frustration.
106
Put together, all of these features of schematic design make the design more
107
difficult to troubleshoot, and often even impossible to troubleshoot using
108
open source tools such as Verilator.
109
 
110
Another problem is that schematic based designs often hide their FPGA resource
111
usage.  They can easily become resource hogs, leaving the designer unaware
112
of the consequences of what he/she is implementing.  As an example, the memory
113
interface generated by Xilinx's Memory Interface Generator (MIG) consumes
114
nearly a full quarter of the Arty's FPGA resources, while delaying responses
115
to requests by upwards of 250~ns.  Further, while Xilinx touts its MicroBlaze
116
processor as only using 800--2500 LUTs, the MicroBlaze architecture requires
117
it be connected to four separate AXI busses, with each of those having
118
five channels, all with their requests and acknowledgement flags.  These
119
can therefore easily consume all of the resources within an architecture, before
120
providing any of the benefit the designer was looking for when they chose to
121
use an FPGA.
122
 
123
 
124 2 dgisselq
% What is old
125 48 dgisselq
%       Arty, XuLA, Learnables using schematic drawing techniques
126 2 dgisselq
% What does the old lack?
127
%       Arty lacks open interfaces, instead using MIG and CoreGen w/ AXI bus
128
% What is new
129
%       OpenArty has its own memory interface controller, and runs everything
130
%       off of an open Wishbone bus structure.
131
% What does the new have that the old lacks
132
%
133
% What performance gain can be expected?
134
%
135
 
136 48 dgisselq
Here in this project, we present another alternative.
137
 
138
First, the OpenArty is entirely built in Verilog, and (with the exception of
139
the MIG controller), it is entirely buit out of OpenSource IP.\footnote{I'm
140
still hoping to place an open memory controller into this design.  This
141
controller is written in logic, but does not yet connect to any hardware ports.}
142
 
143
Second, configuration options, such as cache sizes, can be fine tuned via a
144
CPU options file.
145
 
146
Third, as you will find from examining the RTL sources, this project uses only
147
one bus, and that bus has ony one channel associated with it: a Wishbone Bus.
148
This helps to limit the logic associated with trying to read and write from
149
the CPU, although it may increase problems with fanout.
150
 
151
Finally, because the OpenArty project is made from open source components, the
152
entire design, together with several of its peripherals, can be simulated using
153
Verilator.  This makes it possible to run programs on the ZipCPU within the
154
OpenArty design, and find and examine where such programs (or their peripherals)
155
fail.
156
 
157
Overall, the goals of this OpenArty project include:
158 2 dgisselq
\begin{enumerate}
159
\item Use entirely open interfaces
160
 
161
        This means not using the Memory Interface Generator (MIG), the
162 48 dgisselq
        Xilinx CoreGen IP, etc.
163 2 dgisselq
 
164 48 dgisselq
        (This goal has not yet been achieved.)
165
 
166
\item Use all of Arty's on--board hardware: Flash, DDR3-SDRAM, Ethernet, and
167
        everything else at their full and fastest speed(s).  For example, the
168
        flash will need to be clocked at 82~MHz, not the 50~MHz I've clocked
169
        it at in previous projects.  The DDR3 SDRAM memory should also be able
170
        to support pipelined 32--bit interactions over the Wishbone bus at a
171
        162~MHz clock.  Finally, the Ethernet controller should be supported
172
        by a DMA capable interface that can drive the ethernet at its full
173
        100Mbps rate.
174
 
175
        (Of these, only the ethernet goal has been met.)
176
 
177
\item Run using a 162.5~MHz system clock, if for no other reason than to gain
178
        the experience of building logic that can run that fast.\footnote{The
179 30 dgisselq
        original goal was to run at 200~MHz.  However, the memory controller
180 48 dgisselq
        cannot run faster than about 82~MHz.  If we run it at 81.25~MHz and
181
        double that clock to get our logic clock, that now places us at
182
        162.5~MHz.  200~MHz is \ldots too fast for DDR3 transfers using the
183
        Artix--7 chip on the Arty.}
184 2 dgisselq
 
185 48 dgisselq
        While the wishbone bus has been upgraded so that it may run at
186
        200~MHz, the CPU and memory controller cannot handle this speed (yet).
187
 
188 2 dgisselq
\item Modify the ZipCPU to support an MMU and a data cache, and perhaps even
189
        a floating point unit.
190
 
191 48 dgisselq
        (These are still in development.)
192
 
193
\item The default configuration will also include four Pmods: a USBUART,
194
        a GPS, an SDCard, and an OLEDrgb.
195
 
196
        (These have all been tested, and are known to work.)
197 2 dgisselq
\end{enumerate}
198
 
199
I intend to demonstrate this project with a couple programs:
200
\begin{enumerate}
201 48 dgisselq
\item An NTP Server
202 36 dgisselq
 
203 48 dgisselq
        While the GPS tracking circuit is in place, and while it appears to be
204
        able to track a GPS signal to within about 100ns or so, the
205
        network stack has yet to be built.
206
 
207
\item A ZipOS that can actually load and run programs from the SD Card, rather
208
        than just a static memory image stored in flash on start-up.
209
 
210 36 dgisselq
        This will require a functioning memory management unit (MMU), which
211
        will be a new addition to the ZipCPU created to support this project.
212 48 dgisselq
 
213 36 dgisselq
        For those not familiar with MMU's, an MMU translates memory addresses
214
        from a virtual address space to a physical address space.  This allows
215
        every program running on the ZipCPU to believe that they own the entire
216
        memory address space, while allowing the operating system to allocate
217
        actual physical memory addresses as necessary to support whatever
218
        program needs more (or less) memory.
219 48 dgisselq
 
220
        At this point, the MMU has been written and has passed its bench
221
        testing phase.  It has not (yet) been integrated with the CPU.
222 2 dgisselq
\end{enumerate}
223
 
224
 
225 48 dgisselq
\chapter{Getting Started}\label{ch:getting-started}
226
\section{Building the Core}
227
%
228
\section{Building the board support files}
229
The OpenArty project comes with a series of board support programs that are
230
designed to run from a Linux command line.  The C++ source code for these
231
programs can be found in the sw/host directory.  These programs have two
232
dependencies: the ZipCPU load program depends upon libelf, and the ZipCPU
233
debugger depends upon the ncurses library.  If you have these two libraries,
234 55 dgisselq
your build should proceed without problems.  If now, you may get them simply
235
by ussuing a:
236
\begin{lstlisting}[language=bash]
237
% sudo apt-get install ncurses-dev libelf-dev texinfo
238
\end{lstlisting}
239 2 dgisselq
 
240 55 dgisselq
 
241 48 dgisselq
% TODO: Remove the dependency on ZIPD.
242 36 dgisselq
 
243 48 dgisselq
A make in the sw/host directory should build all of these support programs.
244
These include:
245
\begin{itemize}
246
\item {\tt wbregs}: a program to read and write addresses on the wishbone bus,
247
        and hence to test peripherals independent of the CPU.
248
\item {\tt netuart}: a program to convert the UART device provided by the board
249
        to a TCP/IP device that can be connected to anywhere.
250
\item {\tt wbsettime}: a simple program to set the time on the real-time clock
251
        core within the board.
252
\item {\tt dumpflash}: reads the current contents from the flash memory into a
253
        local file
254
\item {\tt wbprogram}: programs new configuations into the flash
255
\item {\tt netsetup}: reads and decodes the MDIO interface from the ethernet
256
        PHY controller
257
\item {\tt manping}: pings a computer using the ethernet packet interface.
258
        This program does not have any ARP handling, so while it will wait
259
        for a reply, the reply typically comes back in the form of an ARP
260
        request rather than the ping response.
261
\item {\tt zipload}: Loads a program onto the ZipCPU, adjusting flash, block
262
        RAM, and or SDRAM memory to do so.  May also start the program running
263
        if requested.
264
\item {\tt zipstate}: Returns information about whether or not the CPU is
265
        running, is running in user mode, is waiting for an interrupt,
266
        has halted, etc.
267
\item {\tt zipdbg}: a debugger with the capability to halt, reset and step
268
        the CPU, as well as to inspect the state of the CPU following any
269
        unexpected halt.
270
\end{itemize}
271 36 dgisselq
 
272 55 dgisselq
\section{Building the Verilator Simulation}
273
If you are at all interested in building the verilator simulation, you will
274
also need Verilator and GTKMM-3.0.  To get these, you may type:
275
\begin{lstlisting}[language=bash]
276
% sudo apt-get install verilator libgtkmm-3.0-dev
277
\end{lstlisting}
278
At this point, a {\tt make} in the {\tt rtl} directory, followed by a
279
{\tt make} in the {\tt bench/cpp} directory will build a Verilator simulation
280
named {\tt busmaster\_tb}.  You may run this program in place of {\tt netuart},
281
and then access the simulated Arty using the regular board support packages.
282
This simulation will use the TCP/IP port given in {\tt bench/cpp/port.h}, which
283
should be set identically to the port given in {\tt sw/host/port.h} used by
284
{\tt netuart}.
285 48 dgisselq
 
286
 
287 55 dgisselq
 
288
 
289 48 dgisselq
\section{Initially installing the core}
290
The OpenArty core may be installed onto the board via the Xilinx Hardware
291
Manager.  If properly set up, you should be able to open the hardware
292
manager after you build an initial bit stream, open the Arty, select the
293
toplevel bit file, and request Xilinx to load the file.
294
 
295
If you are successful, the four color LEDs will blank while the hardware
296
manager is loading the hardware, and then turn to varying intensities of red.
297
 
298
\section{Connecting the PMods}
299
The OpenArty project is designed to work with four PMods: PModUSBUART,
300
PModGPS, PModSD, and PModOLEDrgb.  These four provide the device with
301
serial port access, absolute time and position information, access to an
302
SD card, and the ability to control a small display.
303
 
304
If you do not have any of these devices, and wish to recover the logic used
305
by them, you may comment out the defines for {\tt GPS\_CLOCK},
306
{\tt SDCARD\_ACCESS}, and {\tt OLEDRGBACCESS} found in the {\tt rtl/busmaster.v}
307
file.  This will recover all but the logic used by the PModUSBUART and PModGPS
308
serial ports, while replacing the registers with read--only memory values of
309
zero.
310
 
311 49 dgisselq
The {\tt arty.xdc} file is designed so that these PMods can be connected as
312
shown in Fig.~\ref{fig:pmod-pic}.
313
\begin{figure}\begin{center}
314
\includegraphics[width=4in]{../gfx/openarty.eps}
315
\caption{Showing how the PMods are Connected}\label{fig:pmod-pic}
316
\end{center}\end{figure}
317
In this example, the PModOLED is connected to PMod port JB, and the PModSD is
318
connected to PMod port JD.  Both the PModGPS and the PModUSBUART are both
319
connected to port JC, with the GPS connected on top and the USBUART on the
320
bottom.
321 48 dgisselq
 
322
\section{Testing the peripherals}
323
OpenArty has been designed so that all of the peripherals live on a
324
memory--mapped wishbone bus.  This bus can be accessed, either by the ZipCPU
325
or by the host controller.  Because of this model, peripherals may be tested
326
and known to work before the CPU is ever turned on.  Two programs make this
327
possible: netuart and wbregs.  Other programs may be built upon this model,
328
as long as they access the bus using the interface outlined in devbus.h.
329
 
330
Of the two programs, netuart simply turns the USB serial port interface of
331
the device into a TCP/IP interface.  Netuart takes one argument, the
332
name of the serial port device which the Arty USB driver has created.  In
333
my case, this tends to be /dev/ttyUSB1, although it has been known to change
334
from time to time:
335
 
336
\begin{lstlisting}[language=bash]
337
% netuart /dev/ttyUSB1
338
\end{lstlisting}
339
 
340
All of the other board support files connect to the TCP/IP port generated
341
by netuart.  The port.h file is a compiled-in file, outlining where this
342
port can be found.  By default, netuart listens to port {\tt 6510} on
343
{\tt localhost}, but it can be configured to listen to any port.  The other
344
board support files will try to connect to netuart at the host and port
345
listed in port.h.  Hence, if properly configured, you should be able to
346
access your Arty to command it, configure it, reload it, etc., from anywhere
347
you have internet access--in my case, from anywhere in the house.
348
 
349
Once you run netuart, you should then be able to watch, as a part of the
350
standard output stream of netuart, all of the interaction with the board.
351
While this may be useful for debugging, it's not all that legible to the
352
user.   Lines that start with \hbox{``\#''} are lines from the device that are not
353
going to any client.  A common line you will see is \hbox{``\# 0''}.  This is
354
just the device saying that its command capability is idle.  Lines that start
355
with \hbox{``< ''} are commands going to the device, and lines starting with
356
\hbox{``> ''} are responses from the core.  So, at this point, run netuart and
357
wait a couple of seconds.  If you do not see a \hbox{``\# 0''} line, then try a
358
different serial port, check that your core is properly configured, etc.  Once
359
you do see a \hbox{``\# 0''} line, then you are ready for the next step.
360
 
361
The easiest way to test the peripherals is via the wbregs command.  This
362
command is similar to the ancient peek and poke commands.  It takes one
363
or two arguments.  If given one argument, it reads from that address on the
364
bus.  If given two arguments, it writes the value of the second argument to
365
the bus location given by the first argument.  Hence one argument peeks
366
at the memory bus, two arguments pokes a value onto the memory bus.
367
 
368
Perhaps an example will help.  At this point, try typing:
369
 
370
\begin{lstlisting}[language=bash]
371
% wbregs version
372
\end{lstlisting}
373
 
374
This should return and print a 32-bit hexadecimal value to your screen,
375
indicating the date of when you last ran make in the root directory before
376
building and installing your configuration into the device.  This can be
377
very useful to know what configuration you are running, and whether or not
378
you have made the changes you thought you had made.
379
 
380
You may have noticed that wbregs read from address 0x0100, but did so by name.
381
Most of the peripherals have names for their addresses.  The C language
382
names for these addresses can be found in regdefs.h, and a mapping to
383
wbregs address names can be found in regdefs.cpp.
384
 
385
Shall we try another?  Let's try adjusting the LEDs.  To turn all the LEDs off,
386
\begin{lstlisting}[language=bash]
387
% wbregs leds 0x0f0
388
\end{lstlisting}
389
To turn them all back on again,
390
\begin{lstlisting}[language=bash]
391
% wbregs leds 0x0ff
392
\end{lstlisting}
393
To turn the low order LED off without changing any others, write
394
\begin{lstlisting}[language=bash]
395
% wbregs leds 0x010
396
\end{lstlisting}
397
 
398
Having fun?  Try running the program startupex.sh from the sw directory.
399
This will set some LEDs and Color LEDs in a fun, startup--looking, pattern.
400
 
401
Ready to test the UART?   Using minicom, connect to the PModUSBUART.  It
402
should also be connected to a /dev/ttyUSBx serial port device.  If you aren't
403
sure, start minicom with:
404
\begin{lstlisting}[language=bash]
405
% minicom -D /dev/ttyUSB2
406
\end{lstlisting}
407
Then, configure minicom to use 115,200 Baud, 8-data bits, one stop bit, and
408
no parity.
409
 
410
Once you've done that, we can test it by sending a character across the UART
411
port:
412
\begin{lstlisting}[language=bash]
413
% wbregs tx 90
414
\end{lstlisting}
415
This should send a `Z' over the UART port.  Did you see a `Z' in minicom?
416
If not, did you set the baud rate right?  The UART is supposed to be set
417
for 115,200 Baud, 8N1 by default.  If not, you can set it to that by writing
418
wbregs setup 705.  The 705 comes from the clock rate, in Hz, divided by
419
115200.  By leaving other higher order bits at zero, this becomes the default
420
baud rate of an 8N1 serial port channel.
421
 
422
Another fun program to run is {\tt netsetup}.  This program takes no arguments,
423
and just reads and decodes the network registers via the MDIO port.  The
424
decoded result will be sent to the screen.
425
 
426
\section{Subsequent Core Updates}
427
The board support file {\tt wbprogram} can be used to write .bit or .bin
428
files to the flash, so that the core can be updated once an initial core
429
is installed and running.
430
Although wbprogram expects the filename to end in either '.bit' or '.bin',
431
this is primarily to keep a user from doing something they don't intend to
432
do.
433
 
434
The basic usage of the wbprogram command is:
435
\begin{lstlisting}[language=bash]
436
% wbprogram [@address] file
437
\end{lstlisting}
438
wbprogram then copies the file to the flash, starting at the Arty address
439
of {\tt @address}.  If no address is given, wbprogram writes the file at the
440
beginning of flash.
441
 
442
An example of how to do this can be found in the {\tt program.sh}.
443
{\tt program.sh} places the new configuration file into the alternate
444
configuration location.  (An alternate script, zprog.sh, places the new
445
configuration at the beginning of the flash, where the FPGA loader will look
446
for it upon power up.)  Once {\tt program.sh} places the new configuration
447
into flash, it then commands the FPGA via the ICAPE2 interface and an IPROG
448
command to reconfigure itself using this new configuration.  As a result, this
449
can be used to load subsequent configurations into the FLASH.
450
 
451
\section{Building the ZipCPU tool-chain}
452
At this point, you should have some confidence that your configuration and
453
hardware are working.  Therefore, let's transition to getting the ZipCPU
454 55 dgisselq
on the hardware up and running.
455
To do this, we'll start with getting a copy
456 48 dgisselq
of the ZipCPU toolchain and building it.  Pick a directory to work in, and
457
then issue:
458
\begin{lstlisting}[language=bash]
459
% git clone https://github.com/ZipCPU/zipcpu
460
\end{lstlisting}
461 55 dgisselq
to get a copy of the ZipCPU project, together with toolchain.  You'll also
462
need to double check that you have the pre-requisite packages to build this
463
tool chain, so on an Ubuntu~14 machine you would issue:
464 48 dgisselq
\begin{lstlisting}[language=bash]
465 55 dgisselq
% sudo apt-get install flex bison libbison-dev
466
% sudo apt-get install libgmp10 libgmp-dev libmpfr-dev libmpc-dev libelf-dev
467
% sudo apt-get install libisl-dev
468
\end{lstlisting}
469
Once these are all in place, you can then switch to the master ZipCPU
470
directory and type,
471
\begin{lstlisting}[language=bash]
472 48 dgisselq
% cd zipcpu; make
473
\end{lstlisting}
474
(you may need to issue the make command a couple of times \ldots)
475
 
476
This will build the GCC compiler for the ZipCPU from source.
477
It will also install this new compiler into the zipcpu/sw/install/cross-tools.
478
This new compiler will be called zip-gcc.
479
 
480
This will also build a copy of the binutils programs for the ZipCPU.  These
481
include the assembler, {\tt zip-gas}, linker, {\tt zip-ld}, disassembler,
482
{\tt zip-objdump}, and many more useful programs.
483
 
484
The next step to using this toolchain is to place it into your path.
485
\begin{lstlisting}[language=bash]
486
% export PATH=$PATH:$PWD/zipcpu/install/cross-tools/bin
487
\end{lstlisting}
488
Once the toolchain is in your path,
489
\begin{lstlisting}[language=bash]
490
% which zip-gcc
491
/home/.../zipcpu/sw/install/cross-tools/bin/zip-gcc
492
\end{lstlisting}
493
should return the location of where this toolchain exists in your path.
494
 
495
\section{Building your first ZipCPU program}
496
Several example programs for the OpenArty project can be found in the
497
{\tt sw/board} directory.  These can be used to test various peripherals from
498
the perspective of the CPU itself.
499
 
500
As a test of the build process, a good first progam to build would be
501
{\tt exstartup}.  This program is very similar to the {\tt startupex.sh} shell
502
script you tried earlier.  It simply plays with the color LEDs and some
503
on board timers.   Once that is finished, it goes into a loop controlling
504
both the normal and the color LEDs based upon the button state and the switch
505
settings.
506
 
507
To build {\tt exstartup}, simply type {\tt make exstartup} from the
508
{\tt sw/board} directory of the {\tt openarty} project.  (Don't forget to
509
include the ZipCPU toolchain into your path before you do this!)
510
 
511
\section{Loading a program}
512
Now that you have built your {\tt exstartup} program, it's time to load it
513
onto the board and start it up.  The {\tt zipload} program can be used to
514
do this.  {\tt zipload} can be found in the sw/host directory.  To load a
515
ZipCPU program into the Arty, just type {\tt zipload} and the program name,
516
such as {\tt exstartup} in this case.  To start the program immediately
517
after loading it, pass the `-r' option to {\tt zipload}.  In our case, you
518
would type:
519
\begin{lstlisting}[language=bash]
520
% zipload -r exstartup
521
\end{lstlisting}
522
 
523
Hopefully, you can see the {\tt exstartup} program now toggling the LED's.
524
Once the initial display stops, you can adjust the switches and press buttons
525
to see how that affects the result.
526
 
527
If you wish to restart the {\tt exstartup} program, or indeed to run another
528
program, you can just run {\tt zipload} again with the new program name.  This
529
will halt the previous program, and then load the new one into memory.  As
530
before, if you use the `-r' option, the program will be started automatically.
531
 
532
\section{Some other test programs}
533
If you have the PModUSBUART, you might wish to try running a ``Hello, World''
534
program.  This can be found in the hello.c file.  It prints ``Hello, World''
535
to the PModUSBUART once every ten seconds.  Had enough of it?  You can stop
536
the CPU by typing {\tt wbregs cpu 0x0400}.  This sends a halt command to the
537
debug register of the ZipCPU.  More information about this debug register, and
538
other things that can be done via the debug register, can be found in the
539
ZipCPU specification.
540
 
541
If you have both the PModUSBUART as well as the PModGPS, the {\tt gpsdump.c}
542
program can be used to forward the NMEA stream from the GPS to the USBUART.
543
This should give you some confidence that the PModGPS is working.
544
 
545
As a third test, {\tt oledtest.c} will initialize the OLEDrgb device and cause
546
it to display one of two images in an alternating fashion.
547
 
548 36 dgisselq
\chapter{Architecture}\label{ch:architecture}
549
My philosophy in peripherals is to keep them simple.  If there is a default
550
mode on the peripheral, setting that mode should not require turning any bits
551
on.  If a peripheral encounters an error condition, a bit may be turned on to
552
indicate this fact, otherwise status bits will be left in the off position.
553
 
554
\subsection{Bus Structure}
555
The OpenArty project contains four bus masters, three of them within the CPU.
556
These masters are the instruction fetch unit, the data read/write unit,
557
and the direct memory access peripheral within the ZipCPU, as well as an
558
external debug port which can be commanded from over the main UART port
559
connecting the Arty to its host.
560
 
561
There is also a second minor peripheral bus located within the ZipCPU
562
ZipSystem.  This bus provides access to a number of peripherals within the
563
ZipSystem, such as timers, counters, and the direct memory access controller.
564
This bus will also be used to configure the memory management unit once
565
integrated.  This bus is only visible to the CPU, and located starting at
566
address {\tt 0xc0000000}.
567
 
568
The ZipCPU debug port is also available on the bus.  This port, however, is
569
only visible to the external debug port.  It can be found at address
570
{\tt 0x08000000} for the control register, and {\tt 0x08000001} for the
571
data register.
572
 
573
Once the MMU has been integrated, it will be placed between the instruction
574
fetch unit, data read/write unit, and the rest of the peripheral bus.
575
 
576
The actual bus chosen for this design is the Wishbone Bus, based upon the
577
pipeline mode defined in the B4 specification.  All optional wires required
578
by this bus structure have been removed, such as the tag lines, the cycle
579
type identifier, the burst type, and so forth.  This was done to simplify
580
the logic within the core.
581
 
582
However, because of the complicated bus structure--particularly because of the
583
number of masters and slaves on the bus and the speed for which the bus is
584
defined, there are a number of delays and arbiters placed on the bus.  As a
585
result, the stall wire which is supposed to be depend upon combinational logic
586
only, has been registered at a number of locations.  What this means is that
587
there are a variety of delays as commands propagate through the bus structure.
588
Most of these are variable, in that they can be turned on or off at build time,
589
or even that the stall line may (or may not) be registered as configured.
590
 
591
All interactions between bus masters and any peripherals passes through the
592
interconnect, located in {\tt busmaster.v}.  This interconnect divides the
593
slaves into separate groups.  The first group of slaves are those for which the
594
bus is supposed to provide fast access to.  These are the DDR3 SDRAM, the
595
flash, the block RAM, and the network.  The next group of slaves will have their
596
acknowledgements delayed by an additional clock.  The final group of slaves
597
are those single register slaves whose results may be known ahead of any read,
598
and who only require one clock to access.  These are grouped together and
599
controlled from within {\tt fastio.v}.
600
 
601
Further information about the Wishbone bus structure found within this core
602
can be found either on the Wishbone datasheet (Ch.~\ref{ch:wishbone}), or in
603
the memory map table in the Registers chapter (Ch.~\ref{ch:registers}).
604
 
605
\subsection{DDR3 SDRAM}
606
 
607
{\em It is the intention of this project to use a completely open source
608
DDR3 SDRAM controller.  While the controller has been written, it has yet to
609
be successfully connected to the physical pins of the port.  Until that time,
610
the design is running using a Wishbone to AXI bus bridge.  Memory may still
611
be read or written, after an initial pipeline delay of roughly 27~clocks per
612
access, at one access per clock.}
613
 
614
{\em The open source SDRAM controller should be able to achieve a delay closer
615
to 9~clocks per access--once I figure out how to connect it to the PHY.}
616
 
617
\subsection{Flash}
618
\subsection{Block RAM}
619
 
620
The block RAM on this board has been arranged into one 32kW section.
621
Programs that use block RAM will run fastest using the block RAM, both for
622
instructions as well as for memory.
623
 
624
\subsection{Ethernet}
625
 
626
The ether net controller has been split into three parts.  The first part is
627
an area of packet memory.  This part is simple: it acts like memory.  The
628
receive memory is read only, whereas the transmit memory is both read and
629
write.  Packets received by the controller will be found in the receive memory,
630
packets transmitted must be in the transmit area of memory.  The octets
631
may be found in memory with the first octet in the most significant byte.
632
This is the easy part.
633
 
634
The format of the packets within this memory is a touch more interesting.
635
With no options turned on, the first 6~bytes are the destination MAC
636
address, the next 6~bytes will be the source MAC address, and the {\em next
637
4~bytes} will be the EtherType repeated twice.  This was done to align the
638
packet, and particularly the IP header, onto word boundaries.  If the hardware
639
CRC has been turned off, the packet must contain its own CRC as well as
640
ensuring that it has a minimum packet length (64 octets) when including that
641
CRC.
642
 
643
With all options turned on, however, things are a touch simpler.  The first
644
two words of the packet contain the destination MAC (for a transmit packet)
645
or the source MAC (for a received packet), followed by the two--octet
646
EtherType.  At this point the packet is word--aligned prior to the IP header.
647
Since broadcast packets are sent to a special destination MAC other than
648
our own, a flag in the command register will indicate this fact.
649
 
650
 
651
The second part of the controller is the MDIO interface.  This follows from
652
the specification, and can be used to toggle the LED's on the ethernet,
653
to force the ethernet into a particular mode, either 10M or 100M, to control
654
auto--negotiation of the speed, and more.  Reads or writes to MDIO memory
655
addresses will command reads or writes via the MDIO port from the FPGA to the
656
ethernet PHY.  As the PHY can only handle 16--bit words, only 16~bits will
657
ever be transferred as a result of any read/write command, the top 16~bits
658
are automatically set to zero.  Further details of this capability may be
659
found within the specification for the chip.
660
 
661
The MDIO interface may be ignored.  If ignored, the defaults within the
662
interface will naturally set up the network connection in full duplex mode (if
663
your hardware supports it), at the highest speed the network will support.
664
However, if you ignore this interface you may not know what problems you are
665
suffering from this interface, if any.  The {\tt netsetup} program has been
666
provided, among the host software, to help diagnose how the various MDIO
667
registers have been set, and what the status is that is being reported from
668
the PHY.
669
 
670
The third part of the controller is the packet command interface.  This
671
consists of two command registers, one for reading and one for writing.
672
Before doing anything with the network, it must first be taken out of
673
reset.  According to the specification for the network chip, this must
674
happen a minimum of one second after power up.  This may be done by simply
675
writing to the transmit command register with the reset bit turned off.
676
 
677
To send a packet, simply write the number of octets in the packet to the
678
transmit control register and set the GO bit ({\tt 0x04000}).  Other bits
679
in this control register can be used to turn off the hardware MAC generation
680
(and removal upon receive), the hardware CRC checking, and/or the hardware
681
IP header checksum validation (but not generation).  The GO bit will remain
682
high while the packet is being sent, and only transition to low once the
683
packet is away.  While the packet is being sent, a zero may be written to the
684
command register to cancel the packet--although this is not recommended.
685
 
686
Packets are automatically received without intervention.  Once a packet has been
687
received, the available bit will be set in the receive command register and
688
a receive packet interrupt will be generated.  The ethernet port will then
689
halt/stall until a user has reset the receive interface so that it may
690
receive the next packet.  Without clearing this interface, the receive port
691
will not accept further packets.  Other status bits in this interface are
692
used to indicate whether packets have been missed (because the interface was
693
busy), or thrown out due to some error such as a CRC error or a more general
694
error.\footnote{It should be possible to extend this interface so that further
695
packets may be read as long as the memory isn't yet full.  This is left as an
696
exercise to others.}
697
 
698
\subsection{SD Card}
699
\subsection{GPS Tracking}
700
\subsection{Configuration port}
701
 
702
The registers associated with the ICAPE2 port have been made accessible
703
to the core via the {\tt wbicapetwo} core.  More information about the meaning
704
of these registers can be found in Xilinx's ``7--Series FPGAs Configuration
705
User's Guide''.
706
 
707
Testing with the OpenArty board has tended to focus on the warmboot capability.
708
Using this capability, a user is able to command the FPGA to reload its
709
configuration.  In support of this, two configuration areas have been
710
defined within memory.  The first is the default configuration, found at
711
the beginning of the flash.  This configuration is sometimes called the ``golden
712
configuration'' within Xilinx's documentation because it is the configuration
713
that the Xilinx device will always start up from after a power on reset.  On
714
the OpenArty, a second configuration may immediately follow the first in flash.
715
Commanding the FPGA to reload it's configuration is as simple as
716
setting the WBSTAR (warm boot start address) register to the location of the
717
new configuration within the flash, and then writing a 15 (a.k.a. IPROG)
718
to the FPGA command register (offset 4 from the beginning of the ICAPE2
719
addresses).  Examples of doing this are found in the
720
{\tt sw/host/zprog.sh} and {\tt sw/host/program.sh} scripts.  The former
721
programs the default configuration and then switches to it,
722
 
723
This configuration capability makes it possible for a user to 1) reprogram
724
the flash with an experimental configuration in the second configuration
725
location, and 2) test the configuration without actually touching the board.
726
If the configuration doesn't work well enough to be communicated with, the
727
board may simply be powered down and it will come back up with the initial
728
or golden configuration.  If the golden configuration ever gets corrupted,
729
or loaded with a configuration that will not work, then the user will need to
730
reload the FPGA from the JTAG port.
731
 
732
\subsection{OLED}
733
\subsection{Real Time Clock}
734
 
735
The Arty board contains a real time clock core together with a companion
736
real time date/calendar core.  The clock core itself contains not only current
737
time, but also a stopwatch, seconds timer, and alarm.  The real time date core
738
can be used to maintain the current date.  The real--time clock core uses the
739
GPS PPS output, as schooled by the GPS tracking circuit, in order to synchronize
740
their subsecond timing to the GPS itself.  Further, the real--time clock core
741
then creates a synchronization wire for the real--time date core.
742
 
743
Neither of these cores exports its subsecond precision to the rest of the
744
design.  This must be done using either the internal GPS tracking wires, or
745
by reading the time information from the tracking test bench.
746
 
747
\subsection{LEDs}
748
 
749
The Arty board contains two sets of LEDs: a plain set of LEDs, and a colored
750
set of LEDs.
751
 
752
The plain set of LEDs is controlled simply from the LED register.  This register
753
can be used to turn these LEDs on and off, either individually or as a whole.
754
It has been designed for atomic access, so only one write to this register
755
is necessary to set any particular LED.
756
 
757
The color LEDs are slightly different.  Each color LED is supported by its
758
own register, which controls three pulse width modulation controllers.  Three
759
groups of eight bits within the color LED register control the PWM thresholds,
760
first for red, then green, and then in the lowest bits for blue.  These are
761
used to turn on and off the various color components of the LEDs.  Using this
762
method, there are $2^{24}$ different colors each of these LEDs may be set
763
to.
764
 
765
\subsection{Buttons}
766
\subsection{Switches}
767
\subsection{Startup counter}
768
 
769
A startup counter has been placed into the basic peripheral I/O area.  This
770
counter simply counts the clocks since startup.  Upon rollover, the high
771
order bit remains set.  This can be used to sequence the start up of components
772
within the design if so desired.
773
 
774
\subsection{GPS UART}
775
The GPS UART, debug control UART, as well as the auxilliary UART, are all
776
based upon the same underlying UART IP core, sometimes known as the WBUART32
777
core.  The setup register is defined within the documentation for that core,
778
and provides for a large baud rate selection, 5-8 data bits, 1-2 stop bits,
779
and several parity choices.  Within OpenArty, the GPS core is initialized
780
to 9.6~kBaud, 8 data bits, no parity, and one stop bit.
781
 
782
When a value is ready to be read from the GPS uart, the GPS interrupt line
783
will go high.  Once read, and only when read, will this interrupt line reset.
784
If the read is successful, only bits within the bottom eight will be set.
785
If a read is attempted when there is no data, when the UART is in a reset
786
condition, or when there has been a framing or parity error (were parity
787
to be turned on), the upper bits of the UART port will be set.
788
 
789
In a like manner, the GPS device can be written to.  Certain strings, if sent
790
to the UART, can be used to change the UARTs baud rate, its serial port
791
settings, or even its reporting interval.  As with the read port, the transmit
792
port will interrupt the CPU when it is idle.  Writing a character to this
793
port will reset the interrupt.  Setting bits other than the bottom eight may
794
result in a break condition being set on this port as well.
795
 
796
Interacting with a controller can therefore be somewhat tricky.  The
797
interrupt controller will trigger whenever the port is ready to be read from,
798
and will re--trigger every clock until the port has been read from.  At this
799
point, the interrupt controller may be reset.  If this is an auxilliary
800
interrupt controller, such as the bus interrupt controller or the ZipSystem's
801
auxiliary controller, the auxiliary controller will then need to be reset,
802
and the bit in the primary controller associated with the auxiliary controller
803
as well.  It is for this reason that the UARTs have been placed on the
804
primary controller only.
805
 
806
It should also be possible to use the DMA to read from (or write to) either
807
UART port.
808
 
809
\subsection{Auxilliary UART}
810
 
811
The Auxilliary UART has roughly the same structure as the GPS UART, save that
812
it's default configuration is for a 115,200~Baud configuration with 8~data bits,
813
no stop bits, and no parity.  Reads, writes, and interrupts are treated in
814
the same fashion.
815
 
816
\subsection{GPIO}
817
 
818
A General Purpose I/O controller has been placed within the design as well.
819
This controller can handle 16--generic input wires, and set 16--generic output
820
wires.  A single register is used to read both input and output wire values,
821
as well as to set output values when written to.
822
 
823
However, to use this controller, you will need to manually configure it
824
(i.e.~change the Verilog source) within the core, in order to wire the various
825
GPIO values up to a device of interest.  This was done for the simple reason
826
that wiring anything new up to the controller will require Verilog changes
827
anyway.  For this reason, the controller has no way of setting wires to high
828
impedence, or pulling them up or down.  Such control may be done within the
829
top level design if necessary.
830
 
831
This controller will set an interrupt if ever any of the input wires within
832
it are changed.  The interrupt may be cleared in the interrupt controller.
833
 
834
\subsection{Linker Script}
835
 
836
A linker script has been created to capture the memory structure needed by
837
a program.  This script may be found in {\tt sw/board/arty.ld}.  It is a
838
sample script, using it is not required.
839
 
840
The script defines three types of memory to the linker: flash, block RAM, and
841
SDRAM.  Programs using this script will naturally start in flash (acting as
842
a ROM memory).  A bootloader must then be used to copy, from flash, those
843
sections of the program that are to be placed in block RAM or SDRAM into
844
their particular memory locations.
845
 
846
The block RAM locations are reserved for the user kernel, and specifically for
847
any part of the code in the {\tt .kernel} section.  C attributes, or assembly
848
{\tt .section} commands, must be used to place items within this section.
849
A final symbol within this section, {\_top\_of\_stack}, is used so that the
850
initial boot loader knows what to set the initial kernel stack to.
851
 
852
The rest of the initial program's memory is placed into
853
SDRAM.\footnote{Hopefully,
854
I'll get a data cache running on the ZipCPU to speed this up.}  At the end,
855
a {\tt \_top\_of\_heap} symbol is set to reference the final location in the
856
setup.  This symbol can then be used as a starting point for a memory allocator.
857
 
858
An example bootloader is provided in {\tt sw/board} that can be linked with
859
any (bare metal, supervisor) program in order to properly load it into memory.
860
 
861 2 dgisselq
\chapter{Software}
862
\section{Directory Structure}
863
\section{Zip CPU Tool Chain}
864
\section{Bench Test Software}
865
\section{Host Software}
866
\begin{itemize}
867
\item {\tt readflash}: As I am loathe to remove anything from
868
        a device that came factory installed, the
869
        {\tt readflash} program reads the original installed
870
        configuration from the flash and dumps it to a file.
871
 
872
\item {\tt wbregs}: This program offers a capability very similar to the
873
        PEEK and POKE capability Apple user's may remember from before the
874
        days of Macintosh.  {\tt wbregs <address>} will read from the
875
        Wishbone bus the value at the given address.  Likewise
876
        {\tt wbregs <address> <value>} will write the given value into the
877
        given address.  While both address and value have the semantics of
878
        numbers acceptable to {\tt strtoul()}, the address can also be a named
879
        address.  Supported names can be found in {\tt regdefs.cpp}, and their
880
        register mapping in {\tt regdefs.h}.
881
\item {\tt ziprun}:
882
\item {\tt zipload}:
883
\end{itemize}
884
 
885
\section{Zip CPU Programs}
886
\begin{itemize}
887
\item {\tt ntpserver}:
888
\item {\tt goldenstart}:
889
\end{itemize}
890
\section{ZipOS}
891
\subsection{System Calls}
892
\begin{itemize}
893
\item {\tt int wait(unsigned event\_mask, int timeout)}
894
\item {\tt int clear(unsigned event\_mask, int timeout)}
895
\item {\tt void post(unsigned event\_mask)}
896
\item {\tt void yield(void) }
897
\item {\tt int read(int fid, void *buf, int len)}
898
\item {\tt int write(int fid, void *buf, int len)}
899
\item {\tt unsigned time(void) }
900
% \item SEMGET
901
% \item SEMPUT
902
\item {\tt void *malloc(void)}
903
\item {\tt void free(void *buf)}
904
% \item FORK
905
% \item opendir
906
% \item EXEC
907
% \item OPEN
908
\end{itemize}
909
\subsection{Scheduler}
910
 
911 36 dgisselq
\chapter{Operation}\label{ch:operation}
912 2 dgisselq
 
913 36 dgisselq
\chapter{Registers}\label{ch:registers}
914 48 dgisselq
There are several address regions within the {\tt OpenArty}, as shown in
915 2 dgisselq
Tbl.~\ref{tbl:memregions}.
916
\begin{table}[htbp]
917 55 dgisselq
\begin{center}\begin{tabular}{|p{2.25in}|p{0.6in}|p{0.35in}|p{2.0in}|}\hline
918
\rowcolor[gray]{0.85} Binary Address & \multicolumn{1}{c|}{Base} & \multicolumn{1}{c|}{Size} & Purpose \\\hline\hline
919
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0100 0xxx xx--} & \scalebox{0.9}{\tt 0x00000400} & \hfill 128 & Peripheral I/O Control \\\hline
920
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0100 100y yx--} & \scalebox{0.9}{\tt 0x00000480} & \hfill 32& Debug scope control\\\hline
921
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0100 1010 xx--} & \scalebox{0.9}{\tt 0x000004a0} & \hfill 16 & RTC control\\\hline
922
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0100 1011 xx--} & \scalebox{0.9}{\tt 0x000004b0} & \hfill 16 & OLEDrgb control\\\hline
923
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0100 1100 xx--} & \scalebox{0.9}{\tt 0x000004c0} & \hfill 16 & AUX UART\\\hline
924
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0100 1101 xx--} & \scalebox{0.9}{\tt 0x000004d0} & \hfill 16 & GPS UART\\\hline
925
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0100 1110 xx--} & \scalebox{0.9}{\tt 0x000004e0} & \hfill 16 & SDCard controller\\\hline
926
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0101 0000 xx--} & \scalebox{0.9}{\tt 0x00000500} & \hfill 16 & GPS Clock loop control\\\hline
927
%\scalebox{0.8}{\tt 00 0000 0000 0000 0001 0101 0001 ----} & \scalebox{0.9}{\tt 0x00000148} & \hfill 16 & {\em Unused}\\\hline
928
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0101 001x xx--} & \scalebox{0.9}{\tt 0x00000520} & \hfill 32 & GPS Testbench\\\hline
929
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0101 010x xx--} & \scalebox{0.9}{\tt 0x00000540} & \hfill 32 & Network packet interface\\\hline
930
%\scalebox{0.8}{\tt 00 0000 0000 0000 0001 0101 011- ----} & \scalebox{0.9}{\tt 0x00000150} & \hfill 16 & {\em Unused}\\\hline
931
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0101 1xxx xx--} & \scalebox{0.9}{\tt 0x00000580} & \hfill 128 & Ethernet MIO configuration\\\hline
932
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0110 0xxx xx--} & \scalebox{0.9}{\tt 0x00000600} & \hfill 128 & Extended Flash Control Port\\\hline
933
\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0110 1xxx xx--} & \scalebox{0.9}{\tt 0x00000680} & \hfill 128 & ICAPE2 Configuration Port\\\hline
934
%\scalebox{0.8}{\tt 00 0000 0000 0000 0000 0111 ---- ----} & \scalebox{0.9}{\tt 0x00000150} & \hfill 16 & {\em Unused}\\\hline
935
%\scalebox{0.8}{\tt 00 0000 0000 0000 0000 1--- ---- ----} & \scalebox{0.9}{\tt 0x00000150} & \hfill 16 & {\em Unused}\\\hline
936
%\scalebox{0.8}{\tt 00 0000 0000 0000 0001 ---- ---- ----} & \scalebox{0.9}{\tt 0x00000150} & \hfill 16 & {\em Unused}\\\hline
937
\scalebox{0.8}{\tt 00 0000 0000 0000 0010 xxxx xxxx xxxx} & \scalebox{0.9}{\tt 0x00002000} & \hfill 4k & Ethernet RX Buffer\\\hline
938
\scalebox{0.8}{\tt 00 0000 0000 0000 0011 xxxx xxxx xxxx} & \scalebox{0.9}{\tt 0x00003000} & \hfill 4k & Ethernet TX Buffer\\\hline
939
\scalebox{0.8}{\tt 00 0000 0000 001x xxxx xxxx xxxx xxxx} & \scalebox{0.9}{\tt 0x00020000} & \hfill 128k & On-chip Block RAM\\\hline
940
\scalebox{0.8}{\tt 00 0001 xxxx xxxx xxxx xxxx xxxx xxxx} & \scalebox{0.9}{\tt 0x01000000} & \hfill 16M & QuadSPI Flash\\\hline
941
\scalebox{0.8}{\tt 00 0001 0000 0000 0000 0000 0000 0000} & \scalebox{0.9}{\tt 0x01000000} & & Configuration Start\\\hline
942
\scalebox{0.8}{\tt 00 0001 0100 0111 0000 0000 0000 0000} & \scalebox{0.9}{\tt 0x011c0000} & & Alternate Configuration\\\hline
943
\scalebox{0.8}{\tt 00 0001 0000 1110 0000 0000 0000 0000} & \scalebox{0.9}{\tt 0x01380000} & & CPU Reset Address\\\hline
944
\scalebox{0.8}{\tt 01 xxxx xxxx xxxx xxxx xxxx xxxx xxxx} & \scalebox{0.9}{\tt 0x10000000} & \hfill 256M & DDR3 SDRAM\\\hline
945
\scalebox{0.8}{\tt 10 0000 0000 0000 0000 0000 0000 0x00} & \scalebox{0.9}{\tt 0x20000000} & \hfill 8 & ZipCPU debug control port---only visible to debug WB master\\\hline
946 2 dgisselq
\end{tabular}
947
\caption{Address Regions}\label{tbl:memregions}
948
\end{center}\end{table}
949 48 dgisselq
These address regions include both read and write memory regions, such as the
950
block RAM, the SDRAM, and the Ethernet TX buffer, as well as read only memory
951
regions, such as the flash memory and the Ethernet RX buffer, as well as a
952
whole lot of memory mapped peripherals.  The purpose of this chapter will be
953
to describe how these memory mapped peripherals are organized, as well as
954
the specific details of how they may be used.
955 2 dgisselq
 
956 48 dgisselq
This address map information is also contained in a couple other locations.
957
First, {\tt sw/host/regdefs.h} maps all of the OpenArty registers to
958
C++ names, whereas {\tt sw/host/regdefs.cpp} maps these C++ names to a more
959
human readable form which is used by {\tt wbregs}.  Second, these registers
960
are also given names as part of several various structures within
961
{\tt sw/board/artyboard.h}.  And then, of course, they are also listed here.
962
 
963
\section{ZipSystem}
964
The ZipSystem wrapper around the ZipCPU provides access to roughly twenty
965
registers that are tightly integrated with the ZipCPU.  These registers are
966
shown in Tbl.~\ref{tbl:zipio}
967 2 dgisselq
\begin{table}[htbp]
968 55 dgisselq
\begin{center}\begin{tabular}{|p{0.9in}|p{0.35in}|p{2.5in}|}\hline
969
\rowcolor[gray]{0.85} Address & \multicolumn{1}{c|}{Size} & Purpose \\\hline\hline
970
\scalebox{0.9}{\tt 0xff000000} & 4 & Primary Zip PIC\\\hline
971
\scalebox{0.9}{\tt 0xff000004} & 4 & Watchdog Timer\\\hline
972
\scalebox{0.9}{\tt 0xff000008} & 4 & Bus Watchdog Timer\\\hline
973
\scalebox{0.9}{\tt 0xff00000c} & 4 & Alternate Zip PIC\\\hline
974
\scalebox{0.9}{\tt 0xff000010} & 4 & ZipTimer-A\\\hline
975
\scalebox{0.9}{\tt 0xff000014} & 4 & ZipTimer-B\\\hline
976
\scalebox{0.9}{\tt 0xff000018} & 4 & ZipTimer-C\\\hline
977
\scalebox{0.9}{\tt 0xff00001c} & 4 & ZipJiffies\\\hline
978
%
979
\scalebox{0.9}{\tt 0xff000020} & 4 & Master task counter\\\hline
980
\scalebox{0.9}{\tt 0xff000024} & 4 & Master prefetch stall counter\\\hline
981
\scalebox{0.9}{\tt 0xff000028} & 4 & Master memory stall counter\\\hline
982
\scalebox{0.9}{\tt 0xff00002c} & 4 & Master instruction counter\\\hline
983
\scalebox{0.9}{\tt 0xff000030} & 4 & User task counter\\\hline
984
\scalebox{0.9}{\tt 0xff000034} & 4 & User prefetch stall counter\\\hline
985
\scalebox{0.9}{\tt 0xff000038} & 4 & User memory stall counter\\\hline
986
\scalebox{0.9}{\tt 0xff00003c} & 4 & User instruction counter\\\hline
987
%
988
\scalebox{0.9}{\tt 0xff000040} & 4 & DMA command register\\\hline
989
\scalebox{0.9}{\tt 0xff000044} & 4 & DMA length\\\hline
990
\scalebox{0.9}{\tt 0xff000048} & 4 & DMA source address\\\hline
991
\scalebox{0.9}{\tt 0xff00004c} & 4 & DMA destination address\\\hline
992
%
993
\scalebox{0.9}{\tt 0xff000050} & 8 & {\em Reserved for MMU context register}\\\hline
994
\scalebox{0.9}{\tt 0xff8xxxxx} & ? & {\em Reserved for MMU TLB}\\\hline
995 2 dgisselq
\end{tabular}
996
\caption{ZipSystem Addresses}\label{tbl:zipio}
997
\end{center}\end{table}
998 48 dgisselq
and described in detail within the ZipCPU specification.
999 2 dgisselq
 
1000 48 dgisselq
Unlike the rest of the address map, these registers are only visible to the
1001
ZipCPU.  While many of them may be read via the debug port, in general accessing
1002
these registers via the {\tt wbregs} command is not so straight forward.
1003
 
1004 2 dgisselq
\section{Peripheral I/O Control}
1005 48 dgisselq
The first section of memory--mapped I/O for the ZipCPU is found near address
1006
{\tt 0x100}.  These peripherals are specifically peripherals that can be
1007
accessed without ever stalling the bus, and with a known and fixed (minimum)
1008
delay.  Tbl.~\ref{tbl:ioregs}
1009 2 dgisselq
\begin{table}[htbp]
1010
\begin{center}\begin{reglist}
1011 55 dgisselq
VERSION  &\scalebox{0.8}{\tt 0x0400} & 32 & R & Build date\\\hline
1012
PIC      &\scalebox{0.8}{\tt 0x0404} & 32 & R/W & Bus Interrupt Controller \\\hline
1013
BUSERR   &\scalebox{0.8}{\tt 0x0408} & 32 & R & Last Bus Error Address\\\hline
1014
PWRCOUNT &\scalebox{0.8}{\tt 0x040c} & 32 & R & Ticks since startup (roughly)\\\hline
1015
BTNSW    &\scalebox{0.8}{\tt 0x0410} & 32 & R/W & Button/Switch controller\\\hline
1016
LEDCTRL  &\scalebox{0.8}{\tt 0x0414} & 32 & R/W & LED Controller \\\hline
1017
RTCDATE  &\scalebox{0.8}{\tt 0x0418} & 32 & R/W & BCD Calendar Date\\\hline
1018
GPIO     &\scalebox{0.8}{\tt 0x041c} & 32 & R/W & GPIO controller\\\hline
1019
CLR-LEDx &\scalebox{0.8}{\tt 0x0420-c} & 32 & R/W & Color LED controller\\\hline
1020
GPSSECS  &\scalebox{0.8}{\tt 0x0430} & 32 & R/W & {\em Reserved for a one-up seconds counter}\\\hline
1021
GPSSUB   &\scalebox{0.8}{\tt 0x0414} & 32 & R/W & GPS PPS tracking subsecond info\\\hline
1022
GPSSTEP  &\scalebox{0.8}{\tt 0x0418} & 32 & R/W & Current GPS step size, units TBD\\\hline
1023
% Unused  &\scalebox{0.8}{\tt 0x041c--0x047f} & 32 & {\em Unused, writes ignored, returns zero upon read}\\\hline
1024 2 dgisselq
% 0x010c-0x010f
1025
\end{reglist}
1026 55 dgisselq
% UARTRX   &\scalebox{0.8}{\tt 0x0430} & 32 & R/W & Aux UART receive byte\\\hline
1027
% UARTTX   &\scalebox{0.8}{\tt 0x0434} & 32 & R/W & Aux UART transmit byte\\\hline
1028
% GPSRX    &\scalebox{0.8}{\tt 0x0438} & 32 & R/W & GPS UART receive byte\\\hline
1029
% GPSTX    &\scalebox{0.8}{\tt 0x0411} & 32 & R/W & GPS UART transmit byte\\\hline
1030
% AUXSETUP &\scalebox{0.8}{\tt 0x0418} & 29 & R/W & Auxilliary UART config\\\hline
1031
% GPSSETUP &\scalebox{0.8}{\tt 0x041c} & 29 & R/W & GPS UART config\\\hline
1032 2 dgisselq
\caption{I/O Peripheral Registers}\label{tbl:ioregs}
1033
\end{center}\end{table}
1034 48 dgisselq
shows the addresses of these I/O peripherals included as part of OpenArty.
1035 2 dgisselq
We'll walk through each of these peripherals in turn, describing how they work.
1036
 
1037 48 dgisselq
\subsection{Version}
1038
One of the simpler peripherals on the board is the {\tt VERSION} peripheral.
1039
This simple returns the date stamp found within {\tt rtl/builddate.v}.  This
1040
stamp is updated any time a {\tt make} command is issued in the main OpenArty
1041
project directory.  Reads from this address return this value, writes to this
1042
address are ignored.
1043
 
1044
This peripheral is {\em very} useful, especially when trying to determine which
1045
version of your configuration you are using, and whether or not the
1046
configuration has been changed or updated as you had intended by loading a new
1047
configuration, by writing a configuration to the flash and issuing an IPROG
1048
command, etc.
1049
 
1050 2 dgisselq
\subsection{Interrupt Controller}
1051
The OpenArty design maintains three interrupt controllers.  Two of them
1052 48 dgisselq
(a primary and an auxiliary) are found within the ZipSystem, and the third is
1053
located on the bus itself.  In terms of functionality, all three interrupt
1054
controllers are the same, and documented in the ZipCPU specification.  Of
1055
these, the primary interrupt controller for the
1056
entire design is the primary interrupt controller within the ZipSystem.
1057
This interrupt controller accepts as inputs, the output of the auxilliary
1058
interrupt controller.
1059
Hence, even though the CPU only supports a single interrupt line, by cascading
1060
it with a second controller, many more interrupts can be supported.
1061 2 dgisselq
 
1062 48 dgisselq
The third interrupt controller is the bus interrupt controller.  While the
1063
CPU can read and write this controller, the interrupt line from this controller
1064
goes to the host interface.  If you see, as an example, an \hbox{``> 4''} in
1065
your {\tt netuart} window, then you will know that OpenArty has sent an
1066
interrupt to a waiting host program.  If what you saw instead was a
1067
\hbox{``\# 4''}, then the interrupt was sent, but no one was listening.
1068
 
1069 2 dgisselq
The primary interrupt controller handles interrupts from the sources listed
1070 48 dgisselq
in Tbl.~\ref{tbl:sys-ints}.
1071 2 dgisselq
\begin{table}[htbp]
1072 55 dgisselq
\begin{center}\begin{tabular}{|p{1.0in}|c|r|p{3.00in}|}\hline
1073 2 dgisselq
\rowcolor[gray]{0.85} Name & Bit Mask & DMAC ID &Description \\\hline\hline
1074 36 dgisselq
SYS\_DMAC   & 0x0001 && The DMA controller is idle.\\\hline
1075
SYS\_JIF    & 0x0002 & 1 & A Jiffies timer has expired.\\\hline
1076
SYS\_TMC    & 0x0004 & 2 & Timer C has timed out.\\\hline
1077
SYS\_TMB    & 0x0008 & 3 & Timer C has timed out.\\\hline
1078
SYS\_TMA    & 0x0010 & 4 & Timer C has timed out.\\\hline
1079
SYS\_AUX    & 0x0020 & 5 & The auxilliary interrupt controller sends an interrupt\\\hline
1080
SYS\_PPS    & 0x0040 & 6 & An interrupt marking the top of the second\\\hline
1081
SYS\_NETRX  & 0x0080 & 7 & A packet has been received via the network\\\hline
1082
SYS\_NETTX  & 0x0100 & 8 & The network controller is idle, having sent its
1083 2 dgisselq
                        last packet\\\hline
1084 55 dgisselq
SYS\_UARTRXF & 0x0200 &  9 & The receive UART FIFO is half-full\\\hline
1085
SYS\_UARTTXF & 0x0400 & 10 & The transmit UART FIFO is less than half-full\\\hline
1086
SYS\_GPSRXF  & 0x0800 & 11 & The GPS receive UART FIFO is half-full\\\hline
1087
SYS\_GPSTXF  & 0x1000 & 12 & The GPS transmit UART FIFO is half-empty\\\hline
1088
SYS\_BUS    & 0x2000 & 13 & The BUS interrupt controller sends an interrupt\\\hline
1089 36 dgisselq
SYS\_OLED   & 0x4000 & 14 & The OLED port is idle\\\hline
1090 2 dgisselq
\end{tabular}
1091
\caption{Primary System Interrupts}\label{tbl:sys-ints}
1092
\end{center}\end{table}
1093 48 dgisselq
These interrupts are listed together with the
1094
mask that would need to be used when referencing them to the interrupt
1095
controller.  In a similar fashion, the auxilliary interrupt controller accepts
1096
inputs from the sources listed in Tbl.~\ref{tbl:aux-ints}.
1097 2 dgisselq
\begin{table}[htbp]
1098 55 dgisselq
\begin{center}\begin{tabular}{|p{0.9in}|c|r|p{3.00in}|}\hline
1099 2 dgisselq
\rowcolor[gray]{0.85} Name & Bit Mask & DMAC ID &Description \\\hline\hline
1100
AUX\_UIC & 0x0001 & 16 & The user instruction counter has overflowed.\\\hline
1101
AUX\_UPC & 0x0002 & 17 & The user prefetch stall counter has overflowed.\\\hline
1102
AUX\_UOC & 0x0004 & 18 & The user ops stall counter has overflowed.\\\hline
1103
AUX\_UTC & 0x0008 & 19 & The user clock tick counter has overflowed.\\\hline
1104
AUX\_MIC & 0x0010 & 20 & The supervisor instruction counter has overflowed.\\\hline
1105
AUX\_MPC & 0x0020 & 21 & The supervisor prefetch stall counter has overflowed.\\\hline
1106
AUX\_MOC & 0x0040 & 22 & The supervisor ops stall counter has overflowed.\\\hline
1107
AUX\_MTC & 0x0080 & 23 & The supervisor clock tick counter has overflowed.\\\hline
1108 55 dgisselq
%
1109
AUX\_PPD    & 0x0100 & 24& True at midnight\\\hline
1110
AUX\_UARTRX & 0x0200 & 25& A byte has been received from the AUX UART port and is ready to be read\\\hline
1111
AUX\_UARTTX & 0x0400 & 26& There's room for another byte in the TXFIFO queue\\\hline
1112
AUX\_GPSRX  & 0x0800 & 27& A byte has been received in the GPS UART interface, and is now ready to be read\\\hline
1113
AUX\_GPSTX  & 0x1000 & 28& There's room in the GPS UART transmit FIFO for another byte\\\hline
1114 2 dgisselq
\end{tabular}
1115
\caption{Auxilliary System Interrupts}\label{tbl:aux-ints}
1116
\end{center}\end{table}
1117 48 dgisselq
These interrupt mask constants are also defined in {\tt sw/board/artyboard.h}
1118
and {\tt sw/board/zipsys.h}.
1119 2 dgisselq
 
1120 48 dgisselq
Finally, the bus interrupt controller handles the interrupts from the sources
1121
listed in Tbl.~\ref{tbl:bus-ints}.
1122 2 dgisselq
\begin{table}[htbp]
1123 55 dgisselq
\begin{center}\begin{tabular}{|p{0.9in}|c|p{3.75in}|}\hline
1124 2 dgisselq
\rowcolor[gray]{0.85} Name & Bit Mask & Description \\\hline\hline
1125
BUS\_BUTTON & 0x0001 & A Button has been pressed. \\\hline
1126
BUS\_SWITCH & 0x0002 & The Scope has completed its collection\\\hline
1127
BUS\_PPS    & 0x0004 & Top of the second\\\hline
1128
BUS\_RTC    & 0x0008 & An alarm or timer has taken place (assuming the RTC
1129
                is installed, and includes both alarm or timer)\\\hline
1130
BUS\_NETRX & 0x0010 & A packet has been received via the network\\\hline
1131
BUS\_NETTX & 0x0020 & The network controller is idle, having sent its
1132
                        last packet\\\hline
1133
BUS\_UARTRX & 0x0040 & A character has been received via the UART\\\hline
1134
BUS\_UARTTX & 0x0080 & The transmit UART is idle, and ready for its next
1135
                character.\\\hline
1136
BUS\_GPIO   & 0x0100 & The GPIO input lines have changed values.\\\hline
1137
BUS\_FLASH  & 0x0200 & The flash device has finished either its erase or
1138
                write cycle, and is ready for its next command. (Alternate
1139
        config only.)\\\hline
1140
BUS\_SCOPE  & 0x0400 & A scope has completed collecting.\\\hline
1141
BUS\_GPSRX  & 0x0800 & A character has been received via GPS\\\hline
1142
BUS\_SDCARD & 0x1000 & The SD-Card controller has become idle\\\hline
1143
BUS\_OLED   & 0x2000 & The OLED interface has become idle\\\hline
1144
BUS\_ZIP    & 0x4000 & True if the ZipCPU has come to a halt\\\hline
1145
\end{tabular}
1146
\caption{Bus Interrupts}\label{tbl:bus-ints}
1147
\end{center}\end{table}
1148 48 dgisselq
You may notice that there is a lot of overlap between these interrupt sources.
1149
That is so that the host can also receive many of the same interrupts the ZipCPU
1150
can receive.
1151 2 dgisselq
 
1152
\subsection{Last Bus Error Address}
1153 48 dgisselq
Should an attempt be made to access a non--existant memory address, or should
1154
multiple devices all return their data at the same time on the bus, a bus
1155
error will be created.  When and if this happens, the address on the bus
1156
when this error was created will be placed into the last bus error address.
1157
This is the only way to set this address.
1158
 
1159
\subsection{Power counter}
1160
Some peripherals may require a certain amount of time from power up or startup
1161
until they can be accessed.  Guaranteeing this amount of time is the purpose
1162
of the power counter.  This simple read only register simply counts up from
1163
zero on every clock, with the exception that once the high order bit is set
1164
then it is never cleared.
1165
 
1166
\subsection{Button and Switch Register}
1167
btn-now / 4'h0 / btncfg / swcfg / btnstate / swstate
1168
The button and switch register includes a variety of fields for reading the
1169
current state of the buttons and switches, and for controlling the two related
1170
interrupts.  The register is separated into several fields, however, as shown
1171
in Fig.~\ref{fig:btnsw}.
1172
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1173
\bitheader{0-31}\\
1174
\bitbox{8}{\em Ignored}
1175
\bitbox{4}{BNOW}
1176
\bitbox{4}{4'h0}
1177
\bitbox{4}{BCFG}
1178
\bitbox{4}{SCFG}
1179
\bitbox{4}{BTN}
1180
\bitbox{4}{SW}
1181
\end{bytefield}
1182
\caption{Button/Switch register layout}\label{fig:btnsw}
1183
\end{center}\end{figure}
1184
The current state of the buttons and switches can be read through the {\tt BNOW}
1185
and {\tt SW} bit--fields.
1186
 
1187
The {\tt BTN} field contains one bit per button.  When a button is pressed,
1188
the respective bit in this field will be set.  It will then remain set until
1189
cleared.  To clear a value in this bit--field, write a `1' to the position you
1190
wish to clear.
1191
 
1192
Then {\tt BCFG} field controls which buttons will trigger a button interrupt.
1193
Should a button be pressed while its corresponding value within this field
1194
is a `1', a button interrupt pulse will be issued.  To set a bit within this
1195
field, you need to not only write the corresponding bit value, but you must
1196
also set an enable bit within the {\tt BTN} field.  Hence, writing a
1197
{\tt 0x0f0f0} will set all of the bits within this field, while {\tt 0x0f000}
1198
will have no effect, and {\tt 0x0030} will clear two bits.  Notice also that,
1199
when clearing a button press from the {\tt BTN} bits, the corresponding
1200
{\tt BCFG} bits will also be cleared.
1201
 
1202
Finally, the {\tt SCFG} field controls whether or not changing a switch value
1203
will cause an interrupt.  As with the {\tt BCFG} field, changing a value
1204
in this register requires writing to the {\tt SW} field as an enable.
1205
 
1206
The use of the enable bit--field lines was added so that reads and writes to
1207
this register wouldn't need special atomic access protections, so that some
1208
configuration bits could be changed without setting all of them, and so that
1209
changes during writes wouldn't go unnoticed.
1210
 
1211
\subsection{LED control register}
1212
The LED control register has a layout similar and enable field similar to that
1213
of the button/switch control register.  These fields can be seen in
1214
Fig.~\ref{fig:ledctrl}
1215
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1216
\bitheader{0-31}\\
1217
\bitbox{24}{\em Ignored}
1218
\bitbox{4}{ENB}
1219
\bitbox{4}{LED}
1220
\end{bytefield}
1221
\caption{LED control register layout}\label{fig:ledctrl}
1222
\end{center}\end{figure}
1223
The bottom four {\tt LED} bits of this register will always contain the current
1224
state of the LEDs.  To change an LED's state, write to this register the new
1225
state with the corresponding {\tt ENB} (enable) bit set.  Hence writing a
1226
{\tt 0x0c0} will turn off LED's two and three, while writing a {\tt 0x033} will
1227
set LED's zero and one, and writing a {\tt 0x0f} will be ignored.
1228
 
1229
\subsection{UART setup registers}
1230
There are two UART setup registers: one for controlling the PModUSBUART setup
1231
and the other for controlling the PMod GPS NMEA UART.  These follow the format
1232
given in the {\tt wbuart32} project, with a bit field shown in
1233
Fig.~\ref{fig:uartsetup}.
1234
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1235
\bitheader{0-31}\\
1236
\bitbox{2}{00}
1237
\bitbox{2}{N}
1238
\bitbox{1}{S}
1239
\bitbox{1}{P}
1240
\bitbox{1}{F}
1241
\bitbox{1}{T}
1242
\bitbox{24}{Clocks per Baud}
1243
\end{bytefield}
1244
\caption{UART setup register format}\label{fig:uartsetup}
1245
\end{center}\end{figure}
1246
In general, the only control needed to set these registers is to set their
1247
baud rate based upon the number of clocks per baud.  Hence, to set a
1248
9600~baud rate, given an 82.5~MHz clock rate, one would set this register to
1249
{\tt 8594}.  The high order bits are designed so that writing a zero to them
1250
sets the interface for 8--data bits, no parity, and one stop bit.
1251
 
1252
The number of data bits may be adjusted by changing the $N$ field from zero,
1253
for eight data bits, on up to three, for five data bits.
1254
 
1255
The $S$ bit determines whether or not the system will insert and require an
1256
extra stop bit.  Setting it to zero sets the system to require only a single
1257
stop bit.
1258
 
1259
The $P$ bit controls whether or not parity is enabled, and the $F$ bit controls
1260
whether or not the parity is fixed.  $T$ controls what type of parity is then
1261
used.  By setting $P$ to zero, parity checking and generation is turned off.
1262
 
1263
Finally, the auxiliary UART (i.e. the PMod USBUART) defaults to 115,200 Baud,
1264
8N1, whereas the GPS UART defaults to 9600 Baud, 8N1.  Both may be adjusted
1265
via this register.
1266
 
1267
\subsection{Color LED registers}
1268
 
1269
Since the Arty has four color LEDs, the OpenArty has four register words to
1270
control those LEDs.  These registers are split into three bit fields, an
1271
8--bit red, 8--bit green, and an 8--bit blue bit field.  The top eight bits
1272
are ignored.  Unlike many of the other OpenArty registers, these bit fields
1273
may be read or written with no special enable values.
1274
 
1275
\subsection{RTC date register}
1276
The real--time--clock date register format is shown in Fig.~\ref{fig:rtcdate}.
1277
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1278
\bitheader{0-31}\\
1279
\bitbox{16}{Year}
1280
        \bitbox{8}{Month}
1281
        \bitbox{8}{Day}\\
1282
\bitbox{4}{Y}
1283
        \bitbox{4}{Y} \bitbox{4}{Y} \bitbox{4}{Y}
1284
\bitbox{4}{M} \bitbox{4}{M}
1285
\bitbox{4}{D} \bitbox{4}{D}\\
1286
\end{bytefield}
1287
\caption{RTC Date register layout}\label{fig:rtcdate}
1288
\end{center}\end{figure}
1289
This is also a very simple register, containing eight binary coded decimal
1290
(BCD) digits.  Due to the nature of this setup, the date can be read quickly
1291
from the hexadecimal value of the register, and dates can be compared validly
1292
to determine if a date is earlier or later than any other.  Writes to the
1293
date register will set the date, otherwise the date will automatically
1294
increment whenever the Real Time Clock rolls over into the next day.
1295
 
1296
Unlike the Linux {\tt ctime} system call, the month value ranges from
1297
one to twelve.  The day of the month ranges from 1~to 31, or whatever is
1298
appropriate for the current month.
1299
 
1300 2 dgisselq
\subsection{General Purpose I/O}
1301 48 dgisselq
% TODO
1302
The General Purpose I/O controller will be the same as the controller from the
1303
S6~SoC once installed.
1304
 
1305
\subsection{UART Data Registers}
1306
Each of the two UARTs, PMod USBUART and PMod GPS, has two data registers and
1307
two interrupts associated with it: one for receive and one for transmit.
1308
As with the rest of the Arty I/O design, these are designed so that unused
1309
extra bits will be zero, and can (usually) quietly be ignored.
1310
 
1311
The receive UART register format is shown in Fig.~\ref{fig:rxuart}.
1312
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1313
\bitheader{0-31}\\
1314
\bitbox{20}{\em Always zero}
1315
\bitbox{1}{B} \bitbox{1}{F} \bitbox{1}{P} \bitbox{1}{I}
1316
\bitbox{8}{Data}\\
1317
\end{bytefield}
1318
\caption{Receive UART register layout}\label{fig:rxuart}
1319
\end{center}\end{figure}
1320
This register may only be read, writes are silently ignored.  If no receive
1321
value is present, the $I$ bit will be set.  If either a parity error, $P$, or
1322
frame error (stop bit not high), $F$, have occurred, those respective bits will
1323
be high.  The error bits are cleared upon successfully receiving a word across
1324
the interface.  Finally, the $B$ bit indicates the line is in a {\tt BREAK}
1325
condition.
1326
 
1327
The interface has been designed for one of two means of accessing it.  The
1328
interface may be polled.  In that case, anding the result with {\tt 0x0f00}
1329
will tell whether the result is invalid.  The interface may also be read upon
1330
a receive interrupt.  In that case, the same bit fields apply, but the $I$ bit
1331
will be guaranteed to be low.  Finally, the interrupt line will continue
1332
generating an interrupt input to the interrupt controller until it has been
1333
read.  Therefore, handling receive UART interrupts requires reading the receive
1334
data and then resetting the interrupt controller.  This also means, though, that
1335
the receive port should work quite well with the DMA controller.
1336
 
1337
As currently implemented, neither transmit nor receive UARTs have attached
1338
FIFOs.  Hence, once a value is ready to be read, it must be read before the
1339
next value is available to be read.
1340
 
1341
The transmit UART register is shown in Fig.~\ref{fig:txuart}.
1342
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1343
\bitheader{0-31}\\
1344
\bitbox{20}{\em Always zero}
1345
        \bitbox{1}{R}
1346
        \bitbox{1}{O}
1347
        \bitbox{1}{B}
1348
        \bitbox{1}{S}
1349
        \bitbox{8}{Data}\\
1350
\end{bytefield}
1351
\caption{Transmit UART register layout}\label{fig:txuart}
1352
\end{center}\end{figure}
1353
Of these bits, the data register is the most important.  Writes to the transmit
1354
UART, with only the bottom eight bits set, will send those bits out the
1355
data port.  Writes with the $B$, or {\tt BREAK} bit, set will place the
1356
transmitter into a {\tt BREAK} condition.  This condition is only cleared by
1357
writing with the $B$ bit clear.  The $S$ bit is a read-only busy bit, true if
1358
the device is still busy sending the last character.  Finally, the $R$ and $O$
1359
bits reflect the current value read on the receive port and the current value
1360
being placed onto the transmit port respectively.
1361
 
1362
As with the receive register, the transmit register has been designed to either
1363
be used in a polling or interrupt fashion.  When polled, the $S$ bit may be
1364
checked to determine if the transmitter is still busy sending the last
1365
character.  When the $S$ bit is clear, the UART transmitter will be responsive
1366
to another character written to it.  In interrupt mode, the device will
1367
constantly trigger an interrupt into the interrupt controller whenever  it is
1368
idle.  As with the receive, the only way to reset this interrupt is to send
1369
a character and then reset the bit in the interrupt controller.
1370
 
1371
\subsection{System seconds counter}
1372
As part of tracking the current time, it is important to have an accurate
1373
seconds counter that increments with every second.  That's what this register
1374
provides.  This plus the subsecond register should be the current time.
1375
 
1376
The problem is setting this register.  While the subsecond time register can be
1377
set using the PPS signal from the GPS, this seconds register will need to be
1378
calculated from the NMEA data stream.  To make this work, this register has been
1379
set up so that not only does it increment by one on the top of any second, but
1380
when written to the register will be bumped by whatever value is written to it.
1381
Hence, to step it forward by a second, write a {\tt 32'h1} to it.  To step it
1382
backwards, write a {\tt 32'hffffffff}.
1383
 
1384
\subsection{GPS Subsecond time}
1385
As part of being able to provide highly accurate time resolution, it is
1386
important to be able to read the current time at any given time.  This
1387
register provides the sub--seconds value associated with the current time.
1388
It is specifically the amount of time since the top of the last second
1389
times $2^{32}$.  As such, it rolls over at the top of each second.  The
1390
top bit can be used as an indication of the second half of the second, etc.
1391
 
1392
\subsection{GPS derived clock step}
1393
This 32--bit value is closely related to the sytem clock frequency.  It is a
1394
{\tt step} value designed so that a $2^{48}$ bit counter, incremented by this
1395
{\tt step} value on every clock tick, will roll over after one second.  To
1396
convert this to the GPS derived clock frequency, apply the formula:
1397
\begin{eqnarray}
1398
f_{\mbox{\tiny CLK}} &=& \frac{2^{48}}{\mbox{\tt STEP}}
1399
\end{eqnarray}
1400
 
1401 2 dgisselq
\section{Debugging Scopes}
1402 48 dgisselq
\section{Real--Time Clock}
1403
% TODO write something more meaningful
1404
The real--time clock controller is part of the {\tt rtcclock} project which
1405
should also be found near this distribution.  The manual for that project
1406
should describe the four registers, clock, timer, stopwatch, and alarm, that
1407
can be controlled herein.
1408
 
1409
\section{SD Card controller}
1410
% TODO write something more meaningful
1411
The SD card controller is part of the {\tt sdspi} project which
1412
should also be found near this distribution.  The manual for that project
1413
should describe the four registers, control, data, and the two FIFO's registers,
1414
that can be controlled herein.
1415
 
1416
\section{GPS PPS Tracking Loop control}
1417
The coefficients for the PLL that tracks the GPS PPS can be controlled via the
1418
registers listed in Tbl.~\ref{tbl:gpsctrl}.
1419
\begin{table}
1420
\begin{center}\begin{reglist}
1421 55 dgisselq
alpha  &\scalebox{0.8}{\tt 0x0500} & 8 & R/W & Recursive Error Averaging Coefficient\\\hline
1422
beta   &\scalebox{0.8}{\tt 0x0504} & 32 & R/W & Phase Tracking Coefficient\\\hline
1423
gamma  &\scalebox{0.8}{\tt 0x0508} & 32 & R/W & Frequency Tracking Coefficient\\\hline
1424
defstep&\scalebox{0.8}{\tt 0x050c} & 32 & R/W & Default clock step\\\hline
1425 48 dgisselq
\end{reglist}
1426
\caption{GPS PPS Tracking Control Registers}\label{tbl:gpsctrl}
1427
\end{center}\end{table}
1428
 
1429
\section{GPS testbench info}
1430
 
1431
The GPS PPS tracking core found within the Arty was originally tested using
1432
a GPS testbench.  Since simulation and performance measurement was a chalelnge,
1433
that testbench has been given a permanent place within the Arty.  Within it,
1434
there are eight registers, grouped into five variables.  These registers are
1435
designed so that, if read in a burst fashion, none of the registers will
1436
change during the burst--guaranteeing their coherency.
1437
 
1438
The first two registers will be ignored, unless specifically enabled by
1439
defining {\tt GPSTB} in busmaster.v.  They are designed to see how the
1440
GPS tracking circuit will respond to an absolutely accurate input.  The
1441
first, the {\tt tb\_maxcount} value, sets the number of clocks per simulated
1442
PPS tick.  The second, the {\tt tb\_jump} value, when written to will cause
1443
the PPS to suddenly be displaced in phase by the value written.  Both of these
1444
are ignored unless the test bench was configured to produce a simulated
1445
PPS signal.
1446
 
1447
The third register is the 64--bit error.  Specifically, this is the value of
1448
the GPS step counter at the top of the second.  In a perfect world, with
1449
perfect tracking, it should be zero.  In a wonderful world with nearly perfect
1450
tracking, this register should be less than the GPS step size.
1451
 
1452
The fourth register is the 64--bit count register.  This indicates the current
1453
time, in 64--bit precision.  The top 32--bits of this register are the same
1454
as the sub--seconds register presented earlier.
1455
 
1456
The final register is the 64--bit step register.  This register is very similar
1457
to the 32--bit {\tt STEP} register discussed earlier.  It is designed so that,
1458
when multiplied by the clock frequency in Hertz, the result should equal
1459
$2^{64}$.  The register, though, captures the current state of the GPS tracking
1460
circuit's estimate of the clock speed of the processor in this fashion.
1461
 
1462
\section{OLEDrgb control}
1463
The OLEDrgb can be controlled by four registers, listed in
1464
Tbl.~\ref{tbl:oledctrl}.
1465
\begin{table}
1466
\begin{center}\begin{reglist}
1467 55 dgisselq
CTRL &\scalebox{0.8}{\tt 0x04b0} & 32 & R/W & Control register\\\hline
1468
REGA &\scalebox{0.8}{\tt 0x04b4} & 32 & R/W & First excess control word\\\hline
1469
REGB &\scalebox{0.8}{\tt 0x04b8} & 32 & R/W & Second excess control word\\\hline
1470
DATA &\scalebox{0.8}{\tt 0x04bc} & 32 & R/W & Data and power register\\\hline
1471 48 dgisselq
\end{reglist}
1472
\caption{OLED Control Registers}\label{tbl:oledctrl}
1473
\end{center}\end{table}
1474
The first three are used to send information across the control port of the
1475
OLEDrgb, the last is used to adjust the power, reset, and I/O line voltage,
1476
as well as to send data values to the device.
1477
 
1478
Unlike the flash, network MDIO registers, or ICAPE port, reads and writes
1479
of this device will not stall the wishbone bus, and will complete immediately.
1480
Commands issued to the device while the controller is busy will therefore be
1481
quietly ignored.
1482
 
1483
Working with the device starts by powering it up.  This sequence is given
1484
by the manufacturer, and it requires the use of data register.  This data
1485
register has one of two interpretations, as shown in Fig.~\ref{fig:odata}.
1486
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1487
\bitheader{0-31}\\
1488
        \bitbox{16}{16'h00}
1489
        \bitbox{16}{Data}\\
1490
\bitbox{13}{13'h00}
1491
        \bitbox{1}{R} \bitbox{1}{V} \bitbox{1}{E}
1492
        \bitbox{13}{13'h00}
1493
        \bitbox{1}{R} \bitbox{1}{V} \bitbox{1}{E} \\
1494
\end{bytefield}
1495
\caption{OLED data register: Data write format, and power control read/write format}\label{fig:odata}
1496
\end{center}\end{figure}
1497
In the first interpretation, data may be sent to the port by simply
1498
writing that data to the port, while leaving the top sixteen bits zero.
1499
(We'll get to this later.)  In the second interpretation, the reset and
1500
power bits may be adjusted by setting the upper bit high (an enable bit),
1501
together with the corresponding lower bit to the value desired.
1502
 
1503
The $R$ bit will be zero if the device is in a reset state (an active low
1504
reset).  The $V$ bit is one if the VCC output is enabled.  The $E$ bit is one
1505
if the PMod is enabled, otherwise the power to the PMod is cut.  Adjusting
1506
these bits requires writing a `1' to the bit you wish to change, and then
1507
at the same time writing the value you wish to change it to in the lower order
1508
bits.  Hence writing a {\tt 0x010001} to the device will turn the power on,
1509
whereas a {\tt 0x010000} will turn it off.  Likewise {\tt 0x040000} will place
1510
the device into reset (active low), and {\tt 0x040004} will release the reset
1511
line.
1512
 
1513
Reads from this port simply return the current values of the $R$, $V$, and
1514
$E$ bits in the least significant 3--bits.
1515
 
1516
The power--up sequence for the device is shown below:
1517
\begin{enumerate}
1518
\item Wait a quarter second from configuration start
1519
\item Power up the device, writing a {\tt 0x050005} to the data port to
1520
        power up, but without setting the reset line yet.
1521
\item Wait four microseconds.
1522
\item Activate the reset line, by writing a {\tt 0x040000} to this data port.
1523
\item Wait another four microseconds.
1524
\item Clear the reset, by writing a {\tt 0x040004} to this data port.
1525
\item Wait another four microseconds.
1526
\item Initialize the display.
1527
\end{enumerate}
1528
 
1529
At this point, a series of commands need to be sent to the devices control
1530
port.  These commands are written to the control register.  The control
1531
register accepts several different types of writes, as shown in
1532
Fig.~\ref{fig:octrl}.
1533
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1534
\bitheader{0-31}\\
1535
        \bitbox{24}{24'h00}
1536
        \bitbox{8}{8'data}\\
1537
\bitbox{15}{15'h00}\bitbox{1}{1}\bitbox{16}{16'data} \\
1538
\bitbox{4}{4'h2}\bitbox{4}{}\bitbox{24}{24'data} \\
1539
\bitbox{4}{N-1}\bitbox{4}{}\bitbox{24}{24'data} \\
1540
\end{bytefield}
1541
\caption{Four separate OLED control register write formats}\label{fig:octrl}
1542
\end{center}\end{figure}
1543
To send a single byte of data, write that byte to the control port.
1544
Two bytes require setting bit sixteen, and they are sent high order byte first.
1545
Sending three or more bytes requires setting the number of bytes you wish to
1546
send, $N$, minus one to the top four bits, followed by the first three bytes,
1547
high order byte first.  To send longer commands, place the next four bytes
1548
into register {\tt A}, and the next four after that into register {\tt B}.
1549
In this manner, the device can send commands of up to 11~bytes in length,
1550
although most commands may be sent and received with writing only a single
1551
word to the control port.
1552
 
1553
The actual set of commands used to initialize the display is rather complex.
1554
Please examine the {\tt oledtest.c} ZipCPU program for an example of how
1555
this might be accomplished.  That program sends a series of commands to the
1556
control port, waiting for the port to become idle inbetween.  When using polled
1557
I/O, the low order bit of the control register will be `1' if the port is busy,
1558
zero if not.
1559
 
1560 2 dgisselq
\section{Internal Configuration Access Port}
1561 48 dgisselq
% TODO write something more meaningful
1562
The Xilinx ICAPE2 controller is part of the {\tt wbicapetwo} project which
1563
should also be found near this distribution.  The ICAPE port offers access to
1564
the internal Xilinx configuration registers.  The exact meaning of these registers is rather complex, and so users are referred to the Xilinx configuration
1565
user guide for more detail.
1566
 
1567
For now, two registers are worth mentioning.  The first is the WBSTAR register,
1568
{\tt 0x01f0}, and the second is the command register, {\tt 0x01e4}.
1569
Writes to the {\tt WBSTAR} register will set the address that the Xilinx
1570
chip will configure itself from upon any warm start configuration request.
1571
(Cold starts always configure from the beginning of flash.)  This address
1572
is relative to the start of the flash, and counted in octets rather than
1573
bus words.  Hence, to command the Xilinx chip to configure itself from an
1574
OpenArty address of {\tt 0x470000}, you would drop the four and multiply by
1575
four, and write {\tt 0x1c0000} to this register.
1576
 
1577
The second register worth mentioning is the command register.  Writing a
1578
15~to this register issues an {\tt IPROG} command, causing the FPGA to
1579
reload itself from the address given in the {\tt WBSTAR} register.
1580
 
1581
Put together, this is the meaning of the two lines in {\tt program.sh}:
1582
\begin{lstlisting}[language=bash]
1583
$WBREGS wbstar 0x01c00000
1584
$WBREGS fpgacmd 15
1585
\end{lstlisting}
1586
 
1587
The success of this configuration request may be determined from the
1588
{\tt BOOTSTS} register, as discussed in the Xilinx's
1589
{\em 7 Series FPGAs Configuration: User Guide}.
1590
 
1591
\section{Network Packet interface control}
1592
Tbl.~\ref{tbl:netpkt}
1593
\begin{table}
1594
\begin{center}\begin{reglist}
1595 55 dgisselq
NETRX  &\scalebox{0.8}{\tt 0x0540} & 32 & R/W & Packet receive control register\\\hline
1596
NETTX  &\scalebox{0.8}{\tt 0x0544} & 32 & R/W & Packet transmit control register\\\hline
1597
MACHI &\scalebox{0.8}{\tt 0x0548} & 16 & R/W & Ethernet MAC, hi order 16-bits\\\hline
1598
MACLO &\scalebox{0.8}{\tt 0x054c} & 32 & R/W & Ethernet MAC, low order 32-bits\\\hline
1599
RXMISS  &\scalebox{0.8}{\tt 0x0550} & 32 & R & Number of valid receive packets missed\\\hline
1600
RXERR&\scalebox{0.8}{\tt 0x0554} & 32 & R & Number of packets not properly received\\\hline
1601
RXCRC&\scalebox{0.8}{\tt 0x0558} & 32 & R & Packets received with CRC errors\\\hline
1602 48 dgisselq
{\em Unused} &\scalebox{0.8}{\tt 0x013f} & 32 & R & Reads zero (Reserved for transmit collision counting)\\\hline
1603
\end{reglist}
1604
\caption{Network Packet control registers}\label{tbl:netpkt}
1605
\end{center}\end{table}
1606 55 dgisselq
shows the eight registers used by the packet interface.  The first two of these
1607
are used for receiving and sending packets respectively.  We'll discuss these
1608
two in a moment.  The next two locations allow you to set your own MAC address.
1609
Doing so will allow the network interface, if so configured, to insert your
1610
MAC address into packets and filter incoming packets for only those containing
1611
your MAC.  The last four values are reserved for internal performance counters.
1612 48 dgisselq
 
1613
From the standpoint of configuring this interface, the network transmit
1614
control register needs to be configured first.  The bits in this register
1615
are shown in Fig.~\ref{fig:nettx}.
1616
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1617
\bitheader{0-31}\\
1618
        \bitbox{4}{0000}
1619
        \bitbox{4}{AW}
1620
        \bitbox{5}{00000}
1621
        \bitbox{1}{I}
1622
        \bitbox{1}{R}
1623
        \bitbox{1}{M}
1624
        \bitbox{1}{C}
1625
        \bitbox{1}{B}
1626
        \bitbox{4}{}
1627
        \bitbox{10}{Len}\\
1628
\end{bytefield}
1629
\caption{Network transmit control register, NETTX}\label{fig:nettx}
1630
\end{center}\end{figure}
1631
By default, the network device is held in a reset state until released by
1632
writing a `0' to the $R$ value of this register.  Other bits in this register
1633
include the $I$ bit, which turns off the hardware IP packet header checksum
1634
check when set, the $M$, which turns off hardware MAC filtering when set,
1635
and $C$, which turns off hardware CRC checking and filtering.  These bits
1636
are designed so that the natural state of the register is to set them to
1637
zero, enabling all hardware checking.  Finally, the $B$ bit will be set to
1638
indicate the interface is busy sending a packet.
1639
 
1640
The other field of this control register is the log address width field.
1641
This field specifies the size of the packet buffers, such that there are
1642
a maximum of $2^{\mbox{\tiny AW}}$ octets in each packet.
1643
 
1644
To use the network transmitter:
1645
\begin{enumerate}
1646
\item Set the $R$ bit to zero.  This will activate the interface,
1647
        removing it from reset.
1648
\item Set the local hardware MAC address into the {\tt MACHI}
1649
        and {\tt MACLO} registers.  (The {\tt MACHI} register holds the top
1650
        16~bits, in its lower 16~bits.)
1651
\item Write a packet into the transmit packet memory area, starting at the
1652
        zero address.
1653
        \begin{enumerate}
1654
        \item If the hardware MAC option, $M$ bit, is set to zero, then
1655
                hardware MAC generation is on.  Place bits {\tt 47\ldots 16}
1656
                of the destination MAC in the first word (address 0 of the
1657
                TX memory), and fill the next word with the last bits of the
1658
                destination MAC and the sixteen bits of the EtherType.
1659
        \item If the hardware MAC option is off, i.e. $M=0$, then the
1660
                first two words contain the destination MAC as before,
1661
                but the second word also contains the top 16--bits of the
1662
                source MAC.  The third word contains the bottom bits of the
1663
                source MAC.  The fourth word then contains the EtherType
1664
                field twice.  Any IP packet then begins on the fifth word.
1665
        \item If the hardware CRC option is off, $C=1$, then a CRC will need
1666
                to be generated and placed into the last 4--octets of the
1667
                message.
1668
        \item Octets are transmitted from from high order bits to low order
1669
                bits.  Hence the first octet transmitted will be from
1670
                bits 31--24 of a given word, the second octet from bits
1671
                23--16, etc.
1672
        \end{enumerate}
1673
\item Once the memory for the packet has been set, sending the packet
1674
        is as simple as writing the packet length (in octets), together with
1675
        any flag bits, to the network transmit control register.
1676
\item If using polled I/O, the transmit control register may be examined to
1677
        see when its busy bit clears.  At that point, another packet may be
1678
        loaded into memory.
1679
\item If using interrupt driven I/O, a network transmit idle interrupt will be
1680
        generated once the transmission is complete.  (This interrupt will
1681
        remain high until another packet transmit command is issued.)
1682
\item To send a subsequent packet, one need only set the memory and write
1683
        the transmit command to the control register.  This will reset the
1684
        interrupt input to the interrupt controller, so a transmit complete
1685
        interrupt may be noticed again.
1686
\end{enumerate}
1687
 
1688
The network receive command register is similar to the transmit
1689
command register.  It is shown in Fig.~\ref{fig:netrx}.
1690
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1691
\bitheader{0-31}\\
1692
        \bitbox{4}{0000}
1693
        \bitbox{4}{AW}
1694
        \bitbox{4}{0000}
1695
        \bitbox{1}{B}
1696
        \bitbox{1}{C}
1697
        \bitbox{1}{E}
1698
        \bitbox{1}{M}
1699
        \bitbox{1}{S}
1700
        \bitbox{1}{V}
1701
        \bitbox{4}{}
1702
        \bitbox{10}{Len}\\
1703
\end{bytefield}
1704
\caption{Network receive control register, NETRX}\label{fig:netrx}
1705
\end{center}\end{figure}
1706
Unlike the transmit command register, there are no configuration fields in
1707
the network receive command register.  The receive configuration bits,
1708
controlling such things as whether or not the device it in reset, or whether
1709
or not to have the hardware filter out bad
1710
CRC's, bad IP header checksums, or MAC addresses not for our machine---these
1711
bits are shared with the transmit configuration register.  On receive,
1712
bits are set to indicate the success or failure of a received packet.
1713
$C$ is set if a packet is received with a CRC error.  $E$ is set if there
1714
was some error in packet receiption.  $M$ is set if a packet is received
1715
and the memory still contains the last packet, causing a packet Miss.
1716
$S$ is set if the receive port is busy.  $V$ is set if a valid packet can be
1717
found in the receive memory.  Each of these status bits may be individually
1718
cleared by writing a `1' to that respective bit.  Writing a `1' to the valid
1719
bit, $V$, also clears the receive port so that another packet may be
1720
received.
1721
 
1722
If the interface is on and no valid packet has been received, then the
1723
packet receive logic is activated.  Any packet received with a valid length
1724
(64~bytes or more), a valid CRC (if hardware CRC checking is on), either our
1725
MAC address (as programmed into the configuration) or a broadcast address,
1726
and a valid IP header (if it's an IP packet), will be copied into the receive
1727
memory.  Once the packet has been received, the $V$ bit will be set high.
1728
If the packet was a broadcast packet, the $B$ bit will also be set.  Writing
1729
a `1' to the $V$ bit of this port will clear the packet firmware, and release
1730
it to receive another packet.
1731
 
1732
This port may be operated as either polled or interrupt drive I/O.  If polled,
1733
then check the $V$ bit.  Once the $V$ bit is one, a packet is ready to be
1734
read from the port.  At the same time $V$ is set to one, an interrupt will
1735
be generated.  This interrupt will not clear until $V$ is cleared.
1736
 
1737
 
1738
\section{Ethernet MDIO configuration registers}
1739
The ethernet PHY has 32~address configuration address registers available
1740
to the board via an MDIO interface.  These are 16--bit registers that may be
1741
read from, or written to the device.  The current implementation locks the
1742
bus while reading from or writing to the device until the operation is
1743
complete.
1744
 
1745
Using these registers, one can tell if the Ethernet is in 10Mbps mode, or
1746
100Mbps mode, or even whether or not a cable is connected.
1747
 
1748
A simple register to query to know if this interface is working is the LEDCR
1749
register, {\tt 0x01b8}.
1750
This register will be set to {\tt 0x0ffff} upon startup, and until the network
1751
port has been turned on.  Once turned on, this register will default to all
1752
zeros.  To manually turn both the LEDs on, write a {\tt 0x030} to the LEDCR
1753
register.  To manually turn them off, write a {\tt 0x036}.  A value of
1754
{\tt 0x00} will set them back to the default mode of indicating the link
1755
status and speed.
1756
 
1757
Please examine the specification for the ethernet PHY for more information
1758
about these registers, what their bits mean, and how the device can be
1759
controlled.
1760
 
1761 2 dgisselq
\section{Flash Memory}
1762 48 dgisselq
% \section{Extended Flash configuration port}
1763
From the standpoint of a user program, flash memory should just work.  This
1764
flash memory was designed with that purpose in mind.  Reads are designed to
1765
just work.
1766
 
1767
If only all that a flash required was reading, life would be good.  However,
1768
flash chips have a rather complex protocol for reading, erasing, and programming
1769
them.  This has made the interface more complex.
1770
 
1771
Still, reads are \ldots nearly simple.  Reads from the flash
1772
memory will automatically be done in Quad--SPI mode and leave the device in
1773
Execuste--In--Place (XIP) mode upon completion.  This means that any initial
1774
read burst will take $22+8N$ QSPI clocks for $N$ words, whereas subsequent
1775
reads will only require $14+8N$ QSPI clocks.  Reading from any of the device
1776
registers will transition the device out of XIP mode, and back into the
1777
extended register mode.
1778
 
1779
Writes are more difficult.  Changing the contents of a flash chip requires
1780
either erasing a sector (or subsector) in order to turns all the zeros to ones
1781
in that sector (or subsector), or it requires writing a page in order to
1782
selectively turn some of the ones back to zeros.  The interface used in the
1783
OpenArty is designed to allow the user complete flexibility over the control
1784
of the flash device, without requiring the device to be commanded explicitly
1785
over a SPI (or QSPI) port.  (The device is connected via such a port, the
1786
interface tries to hide that fact.)
1787
 
1788
The result is that there are many registers used for reading, writing, and
1789
controlling the flash.  A quick list of these registers is shown in
1790
Tbl.~\ref{tbl:flctl}.
1791 2 dgisselq
\begin{table}
1792
\begin{center}\begin{reglist}
1793 55 dgisselq
EWREG  &\scalebox{0.8}{\tt 0x0600} & 32 & R & Erase/write control and status\\\hline
1794
ESTATUS      &\scalebox{0.8}{\tt 0x0604} & 8 & R/W & Bus Interrupt Controller \\\hline
1795
NVCONF   &\scalebox{0.8}{\tt 0x0608} & 16 & R & Last Bus Error Address\\\hline
1796
VCONF &\scalebox{0.8}{\tt 0x060c} & 8 & R & Ticks since startup\\\hline
1797
EVCONF    &\scalebox{0.8}{\tt 0x0610} & 8 & R/W & Button/Switch controller\\\hline
1798
LOCK  &\scalebox{0.8}{\tt 0x0614} & 8 & R/W & LED Controller \\\hline
1799
flagstatus&\scalebox{0.8}{\tt 0x0618} & 8 & R/W & Auxilliary UART config\\\hline
1800
CLEAR   &\scalebox{0.8}{\tt 0x061c} & 8 & R/W & Clear status on write\\\hline
1801
DevID &\scalebox{0.8}{\tt 0x0620-}\hfill & 5x32 & R & Device ID\\
1802
        &\scalebox{0.8}{\tt -0x0630}\hfill & & & \\\hline
1803 2 dgisselq
% asyncID &\scalebox{0.8}{\tt 0x018d} & 32 & R/W & Asynch Read ID.  Write starts the ASynch read, 0xff returned until complete\\\hline
1804 55 dgisselq
% asyncOTP  &\scalebox{0.8}{\tt 0x18e} & 32 & W & Asynch Read OTP.  Write starts the ASynch read, 0xff returned until complete\\\hline
1805
OTP     &\scalebox{0.8}{\tt 0x0640-}\hfill &16x32 & R/W & OTP Memory\\
1806 2 dgisselq
        &\scalebox{0.8}{\hfill\tt -0x19f} & & & \\\hline
1807
% 0x010c-0x010f
1808
\end{reglist}
1809
\caption{Flash control registers}\label{tbl:flctl}
1810
\end{center}\end{table}
1811 48 dgisselq
Many of these registers are defined by the flash itself, and the interface
1812
just provides access to them.  These include the status, non--volatile
1813
configuration, volatile configuration, the extended volatile configuration,
1814
and flag status registers.  In a similar fashion, the Device ID may be read
1815
from the device as well.  These registers are defined in the flash
1816
specification.
1817 2 dgisselq
 
1818 48 dgisselq
One piece of configuration is required, though, before this interface will work
1819
properly either reading or writing.  That is that the fast read (or write)
1820
delay must be set to eight clocks.  To do this, write a {\tt 0x08b} needs to be
1821
written to the volatile configuration register.\footnote{To get the ZipCPU to
1822
start automatically upon power up, or indeed to have the flash start up in a
1823
working mode, the non--volatile configuration register will need to be adjusted
1824
to contain this information on power up.  Please consult the chip specification
1825
to determine what to set that register to.}  To set the volatile configuration
1826
register, disable the write protect found in the erase/write control register,
1827
and then write the new value to the volatile configuration register.
1828
 
1829
Perhaps the most important register of this interface is the erase/write
1830
control register.  This register enables or disables the write protect for
1831
the flash, and issues any erase sector or subsector commands.  The register
1832
itself is a bitfield, shown in Fig.~\ref{fig:fewbits}.
1833
\begin{figure}\begin{center}\begin{bytefield}[endianness=big]{32}
1834
\bitheader{0-31}\\
1835
        \bitbox{1}{W}
1836
        \bitbox{1}{E}
1837
        \bitbox{1}{Q}
1838
        \bitbox{1}{S}
1839
        \bitbox{1}{I}
1840
        \bitbox{1}{V}
1841
        \bitbox{1}{X}
1842
        \bitbox{1}{}
1843
        \bitbox{10}{Sector}
1844
        \bitbox{4}{Sub}
1845
        \bitbox{10}{Key}\\
1846
\end{bytefield}
1847
\caption{Flash Erase/Write control register layout}\label{fig:fewbits}
1848
\end{center}\end{figure}
1849
The bits in this register are:
1850
 
1851
$W$ is a Write-In-Progress bit.  It will be one when read if the device
1852
is busy erasing or writing.  Upon any transition back to zero, the controller
1853
will issue an interrupt.  This bit is also the Erase Command bit.  Write a
1854
`1' to this bit to command the flash to erase either a sector or a subsector.
1855
 
1856
$E$ is a write--enable bit.  Write a `1' to this bit to disable write
1857
protection, and a `0' to this bit to re-enable write protection.  (I highly
1858
recommend keeping write protection enabled.  I had an error in one of my
1859
programs once that erroneously started walking through peripheral register
1860
space and \ldots)
1861
 
1862
$Q$ is set if Quad SPI mode is enabled.  This is currently hardwired to true
1863
within the design, so this bit will never change.
1864
 
1865
$S$ is the subsector erase bit.  Upon any command to erase the device, if this
1866
bit is set then only a subsector will be erased.  If this bit is cleared,
1867
the erase command will erase an entire sector.
1868
 
1869
The $I$ bit is set when the device ID has been read into a local RAM memory.
1870
Hence, reading from the device ID initially takes many clocks, but subsequent
1871
reads should be very fast.
1872
 
1873
The $V$ bit will be set upon any write violation, such as trying to write to
1874
the device with the write protect enabled.  This bit is cleared upon any
1875
write to the erase/write control register.
1876
 
1877
$X$ is the XIP mode.  This is set any time bit 3 of the volatile configuration
1878
register is set, and cleared upon any read from non--flash memory.
1879
 
1880
Twenty four bits constitute the sector address.  When commanding the device
1881
to erase a sector, the register neds to know the top 10 of them.  When
1882
commanding the device to erase a subsector, the controller needs the top
1883
14~bits.  The bottom 10~bits are a key.  Set these to {\tt 10'h1be} in order
1884
to command a (sub)sector erase, or even to just adjust the sector address
1885
kept and maintained in this register.
1886
 
1887
Erasing a sector requires two writes to the erase/write command register.
1888
The first write simply disables the write protect.  To do this, write a
1889
{\tt 0x40000000} to the register.  The second write must be the sector
1890
address added or OR'd to {\tt 0xc00001be}.  When erasing a subsector,
1891
set the subsector bit for these two commands.
1892
 
1893
Writing to a page is similar.  In that case, first disable the write protect
1894
as before, and then write (via burst mode) the new page values to the device.
1895
The actual write is sent to the device as soon as the burst mode is complete.
1896
Hence, writing in separate commands, or writing more than a page (64~words),
1897
will stall the bus.
1898
 
1899
While the write or erase is going on, the erase/write control register may be
1900
read.  Once the erase or write has completed, an interrupt will be generated.
1901
Unlike the UART interrupts, this interrupt does not perpetually generate itself
1902
until cleared.  Hence, you may wish to clear the flash interrupt before
1903
an erase/write operation, and then check for the interrupt upon completion.
1904
Further, while the erase/write operation is ongoing, you must not try to read
1905
from flash memory.  (It is likely to cause a bus error \ldots)
1906
 
1907
The EQSPI lock register returns the lock register value associated with the
1908
currently selected sector.
1909
 
1910
The OTP registers reference one--time--programmable memory on the flash.
1911
This memory, once programmed, {\em can not be cleared}!  Programming this
1912
memory constitues changing certain of the default `1's to zeros, depending
1913
upon the values you write to these registers.  They are written in a fashion
1914
similar to writing/programming a page as described above.
1915
 
1916 30 dgisselq
\chapter{Wishbone Datasheet}\label{ch:wishbone}
1917 2 dgisselq
 
1918
The master and slave interfaces have been simplified with the following
1919
requirement: the {\tt STB} line is not allowed to be high unless the {\tt CYC}
1920
line is high.  In this fashion, a slave may often be able to ignore {\tt CYC}
1921
and only act on the presence of {\tt STB}, knowing that {\tt CYC} must be
1922
active at the same time.
1923
 
1924 30 dgisselq
\chapter{Clocks}\label{ch:clocks}
1925 2 dgisselq
\begin{table}\begin{center}
1926
\begin{clocklist}
1927 30 dgisselq
{\tt i\_clk\_100mhz} & Ext & \multicolumn{2}{c|}{100} &
1928 2 dgisselq
        100~MHz Crystal Oscillator \\\hline
1929 30 dgisselq
{\em Future }{\tt s\_clk} & PLL & 152 & 166 & Internal Logic, Wishbone Clock \\\hline
1930
{\tt s\_clk} & PLL & 83.33 & 75.76& DDR3 SDRAM Controller Clock \\\hline
1931 48 dgisselq
\multicolumn{2}{|c|}{\tt mem\_clk\_200mhz} & 200~MHz & & MIG Reference clock for PHASER generation\\\hline
1932 30 dgisselq
{\tt ddr3\_ck\_}$x$ & DDR & 166.67 & 303 & DDR3 Command Clock\\\hline
1933
{\tt o\_qspi\_sck} & DDR & 95 & & QSPI Flash clock \\\hline
1934
{\tt o\_sd\_clk} & Logic & 50 & 0.100 & SD--Card clock \\\hline
1935
{\tt o\_oled\_sck} & Logic & 166 & & OLED SPI clock \\\hline
1936
{\tt o\_eth\_mdclk} & Logic & 25 & 2.5 & Ethernet MDIO controller clock\\\hline
1937 2 dgisselq
\end{clocklist}
1938
\caption{OpenArty clocks}\label{tbl:clocks}
1939
\end{center}\end{table}
1940
 
1941
\chapter{I/O Ports}
1942
 
1943
Table.~\ref{tbl:ioports}
1944
\begin{table}[htbp]
1945
\begin{center}
1946
\begin{portlist}
1947
i\_clk\_100mhz & 1 & Input & Clock\\\hline
1948
o\_qspi\_cs\_n & 1 & Output & Quad SPI Flash chip select\\\hline
1949
o\_qspi\_sck & 1 & Output & Quad SPI Flash clock\\\hline
1950
io\_qspi\_dat & 4 & Input/Output & Four-wire SPI flash data bus\\\hline
1951
i\_btn & 4 & Input  & Inputs from the two on-board push-buttons\\\hline
1952
i\_sw  & 4 & Input  & Inputs from the two on-board push-buttons\\\hline
1953
o\_led & 4 & Output & Outputs controlling the four on-board LED's\\\hline
1954
o\_clr\_led0 & 3 & Output & \\\hline
1955
o\_clr\_led1 & 3 & Output & \\\hline
1956
o\_clr\_led2 & 3 & Output & \\\hline
1957
o\_clr\_led3 & 3 & Output & \\\hline
1958
i\_uart\_rx & 1 & Input &  UART receive input\\\hline
1959
o\_uart\_tx & 1 & Output & UART transmit output\\\hline\hline
1960
i\_aux\_rx & 1 & Input &  Auxiliary/Pmod UART receive input\\\hline
1961
o\_aux\_tx & 1 & Output & Auxiliary/Pmod UART transmit output\\\hline
1962 55 dgisselq
i\_aux\_rts & 1 & Input &  Auxiliary/Pmod UART ready--to--send\\\hline
1963
o\_aux\_cts & 1 & Output & Auxiliary/Pmod UART clear--to--send\\\hline\hline
1964 2 dgisselq
i\_gps\_rx & 1 & Input &  GPS/Pmod UART receive input\\\hline
1965
o\_gps\_tx & 1 & Output & GPS/Pmod UART transmit output\\\hline
1966
i\_gps\_pps & 1 & Input & GPS Part-per-second (PPS) signal\\\hline
1967
i\_gps\_3df & 1 & Input & GPS\\\hline\hline
1968
o\_oled\_cs\_n & 1 & Output & \\\hline
1969
o\_oled\_sck & 1 & Output & \\\hline
1970
o\_oled\_mosi & 1 & Output & \\\hline
1971
i\_oled\_miso & 1 & Input & \\\hline
1972
o\_oled\_reset & 1 & Output & \\\hline
1973
o\_oled\_dc & 1 & Output & \\\hline
1974
o\_oled\_en & 1 & Output & \\\hline
1975
o\_oled\_pmen & 1 & Output & \\\hline\hline
1976
o\_sd\_sck & 1 & Output & SD Clock\\\hline
1977
i\_sd\_cd & 1 & Input & Card Detect\\\hline
1978
i\_sd\_wp & 1 & Input & Write Protect\\\hline
1979
io\_cmd & 1 & In/Output & SD Bi-directional command wire\\\hline
1980
io\_sd & 4 & In/Output & SD Bi-directional data lines\\\hline\hline
1981
o\_cls\_cs\_n & 1 & Output & CLS Display chip select\\\hline
1982
o\_cls\_sck & 1 & Output & CLS Display clock\\\hline
1983
o\_cls\_mosi & 1 & Output & CLS Display MOSI\\\hline
1984
i\_cls\_miso & 1 & Input & CLS Display MISO\\\hline\hline
1985
\end{portlist}
1986
\caption{List of IO ports}\label{tbl:ioports}
1987
\end{center}\end{table}
1988
lists the various I/O ports associated with OpenArty.
1989
 
1990
 
1991
% Appendices
1992
% Index
1993
\end{document}
1994
 
1995
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.