]> git.ipfire.org Git - people/ms/u-boot.git/blame - doc/README.nios
* Patch by Rahul Shanbhag, 28 Jan 2004:
[people/ms/u-boot.git] / doc / README.nios
CommitLineData
4a551709
WD
1
2 U-Boot for Nios-32
3
180d3f74 4 Last Update: January 2, 2004
4a551709
WD
5====================================================================
6
7This file contains information regarding U-Boot and the Altera
8Nios CPU. For information regarding U-Boot and the Nios Development
c935d3bd
WD
9Kits see:
10
11 * Cyclone Edition (DK-1C20), see doc/README.dk1c20
12 * Stratix Edition (DK-1S10), see doc/README.dk1s10 (TODO)
13 * Stratix Edition (DK-1S40), see doc/README.dk1s40 (TODO)
14 * Stratix Edition (DK-20K200), see doc/README.dk20k200 (TODO)
15
16For informations regarding Nios Development Kit hardware overview
17and the NIOS CPU standard configuration of all known boards made by
18Altera see:
19
20 * Development Kit (DK) hardware overview, see doc/README.nios_DK
21 * NIOS CPU standard_32 at DK-1C20, see doc/README.dk1c20_std32
22 * NIOS CPU standard_32 at DK-1S10, see doc/README.dk1s10_std32
23 * NIOS CPU standard_32 at DK-1S40, see doc/README.dk1s40_std32
24 * NIOS CPU standard_32 at DK-20K200, see doc/README.dk20k200_std32
4a551709
WD
25
26For those interested in contributing ... see HELP WANTED below.
27
28
291. OVERVIEW
30------------
31
32U-Boot has been successfully tested on the Nios Cyclone development
33board using both the 'safe' and 'standard 32' configurations with
180d3f74 34Nios CPU revision 3.1 (CPU_ID = 0x3018). U-Boot can be used with
4a551709
WD
35or without the GERMS monitor. The initial version of U-Boot for the
36Cyclone development kit is about 60 Kbyte and will fit in a single
37sector of on-board FLASH. Only the Nios 32-bit CPU is supported.
38
391.1 GERMS Monitor
40------------------
41If GERMS is just not enough, then U-Boot is a great antibiotic.
42You will be very pleased with its high degree of configurability
43and its rich feature set.
44
45A few of the most obvious limitations of GERMS are overcome by
46using U-Boot (See 'Brain Damage'). Most notably, you can use
47minicom or Hyperterminal (duh).
48
491.2 Altera Source Code
50-----------------------
51The Nios port does NOT include ANY sources that Altera has the
52copyright. This was a conscious decision ... not an accident.
53The Altera license is not clear in terms of distributing Altera
54sources (when altera silicon is not involved). This isn't really
55a problem as little, if any, of the Altera source contains
56features that are not already available in U-Boot.
57
4a551709 58
4a551709
WD
592. CONFIGURATION OPTIONS/SETTINGS
60----------------------------------
61
622.1 Nios-specific Options/Settings
63-----------------------------------
64All configuration options/settings that are specific to Nios begin
c935d3bd
WD
65with "CONFIG_NIOS_", "CFG_NIOS_", or "CFG_NIOS_CPU_".
66
67The configuration follows a two-stage process. In the first stage
68the NIOS CPU core will defined like defined in Alteras SOPC Builder.
69At this point we use the "CFG_NIOS_CPU_" defines exclusively. For
70more informations about all the definitions you have to setup see
71into current board configurations and doc/README.nios_CFG_NIOS_CPU.
4a551709 72
c935d3bd
WD
73In second stage we bring the NIOS CPU configuration in relation to
74U-Boot configuration options/settings. The following is a list of
75currently defined Nios-specific options/parameters used inside of
76U-Boot. If any options are related to Standard-32 Nios SDK
77excalibur.h definitions, the related definition follows the
78description).
4a551709
WD
79
80CONFIG_NIOS -- defined for all Nios-32 boards.
81
82CFG_NIOS_CONSOLE -- the base address of the console UART.
c935d3bd 83 (standard-32: nasys_uart_0 resp. na_uart1_base).
4a551709
WD
84
85CFG_NIOS_FIXEDBAUD -- defined if the console UART PTF fixed_baud
86 parameter is set to '1'.
87
88CFG_NIOS_MULT_HW -- use full hardware multiply (not yet implemented).
89
90CFG_NIOS_MULT_MSTEP -- use hardware assisted multiply using the
91 MSTEP instruction (not yet implemented).
92
93CFG_NIOS_TMRBASE -- the base address of the timer used to support
94 xxx_timer routines (e.g. set_timer(), get_timer(), etc.).
c935d3bd 95 (standard-32: nasys_timer_1 resp. na_lo_priority_timer2_base).
4a551709
WD
96
97CFG_NIOS_TMRIRQ -- the interrupt request (vector number) assigned to
c935d3bd
WD
98 the timer. (standard-32: nasys_timer_1_irq resp.
99 na_low_priority_timer2_irq).
4a551709
WD
100
101CFG_NIOS_TMRMS -- the period of the timer in milliseconds.
102
180d3f74
WD
103CFG_NIOS_ASMIBASE -- the base address of the ASMI peripheral.
104 (standard-32: na_asmi_base).
105
4a551709
WD
1062.2 Differences in U-Boot Options/Settings
107-------------------------------------------
108Some 'standard' U-Boot options/settings are treated differently in
109the Nios port. These are described below.
110
111CFG_GBL_DATA_OFFSET -- in the Nios port, this is the offset of the
112 global data structure in the Nios memory space. More simply,
113 the address of global data.
114
115
1163. ASSEMBLY CODING
117-------------------
118
119In browsing the assembly source files, you may notice the absence
120of the 'magic macros' (e.g. MOVIA, MOVIP, ADDIP etc.). This is
121deliberate. The documentation for the magic macros is scant and
122it is hard to find ... it does not appear in the Nios programmer's
123manual, nor does it appear in the assembler manual. Regardless,
124the macros actually do very little to improve readability anyway.
125
126With this in mind, all assembler modules use only instructions that
127appear in the Nios programmer's manual OR are directly supported
128by the nios-elf toolchain. For example, the 'dec %rB' instruction
129is an alias for 'subi %rB,1' that is supported by the assembler
130but does not appear in the programmer's manual.
131
132
c935d3bd
WD
1334. BOOT PROCESS
134---------------
135
1364.1 Boot process over GERMS
137---------------------------
138When the NIOS CPU catch a reset signal it will begin to be running
139code from CFG_NIOS_CPU_RST_VECT. Normally at this place it will
140find the GERMS monitor. That's the case for the generic NIOS CPU
141configuration "standard_32". When the GERMS monitor starts running,
142it performs important system initializations and then looks for
143executable code in flash, using the following steps:
144
145 1. Examining the two bytes at CFG_NIOS_CPU_FLASH_BASE + 0x04000C.
146 2. Examining the button 0 on the PIO CFG_NIOS_CPU_BUTTON_PIO.
147 3. If the button is not pressed and the two bytes contain 'N'
148 and 'i', the monitor executes a CALL to location
149 CFG_NIOS_CPU_FLASH_BASE + 0x040000.
150 4. If the code is not executed in step 3 or the code returns,
151 then prints an 8-digit version number to STDOUT and waits for
152 user commands from STDIN.
153
154In normal case, for "standard_32", STDIN and STDOUT are the first
155serial port.
156
1574.2 Return to GERMS command line
158--------------------------------
159During the boot process, the GERMS monitor checks for the existence
160of application software in flash memory. If found, the processor
161immediately executes the code. To return program execution to the
162GERMS monitor (that is, avoid running code stored in flash memory):
163
164 1. Hold down CFG_NIOS_CPU_BUTTON_PIO, button number 0.
165 2. Press then release the CPU reset button.
166 3. Release CFG_NIOS_CPU_BUTTON_PIO, button number 0.
167
168
1695. BRAIN DAMAGE
4a551709
WD
170----------------
171
172This section describes some of the unfortunate and avoidable aspects
173of working with the Nios CPU ... and some things you can do to
174reduce your pain.
175
c935d3bd 1765.1 GERMS doesn't work with Hyperterminal
4a551709
WD
177------------------------------------------
178GERMS doesn't do CR/LF mapping that is compatible with Hyperterminal
179(or minicom) -- geez. Regardless of you opion of Hyperterminal, this
180sad design decision is remedied by using U-Boot.
181
c935d3bd 1825.2 cygwin Incompatibility
4a551709
WD
183---------------------------
184The version of cygwin distributed with the nios GNUPro toolchain is
185out-of-date and incompatible with the latest cygwin distributions.
186In addition, many of the standard utilities are very dated as well.
187If you try to download and build the lastest version of grep for
188example, you'll quickly realize that a native gcc is not available
189(the next topic) which leads to U-Boot build problems (following
190topic).
191
192The solution ... well, you can wait for Altera ... or build as
193set of tools for linux.
194
c935d3bd 1955.3 No native gcc
4a551709
WD
196------------------
197I'm not sure how this one slipped through the cracks ... but it is
198a real pain. Basically, if you want to build anything for the native
199environment -- forget it! A native (cygwin) gcc is not distributed,
200and the old version of cygwin makes locating one challenging.
201
202The solution ... same as above. Just download the gcc source from
203Altera and build up a set of cross tools for your favorite linux
c935d3bd
WD
204distro. Anybody who wants to use an already precompiled NIOS cross
205toolchain can it found in the CDK4NIOS project hosted by Source
206Forge at http://cdk4nios.sourceforge.net.
4a551709 207
c935d3bd 2085.4 Can't build default U-Boot
4a551709
WD
209-------------------------------
210By default, when you build U-Boot you will be building some native
211tools along with the target elf, bin, and srec files. Without a
212native gcc, this (obviously) causes problems.
213
214For developers using the Altera cygwin tools you can remove the
215'tools' directory from SUBDIRS in the top-level Makefile. You will
216also have to edit common/Makefile:
217
218Replace:
219environment.o: environment.c ../tools/envcrc
220 $(CC) $(AFLAGS) -Wa,--no-warn \
221 -DENV_CRC=$(shell ../tools/envcrc) \
222 -c -o $@ environment.c
223
224With:
225environment.o: environment.c ../tools/envcrc
226 $(CC) $(AFLAGS) -Wa,--no-warn \
227 -DENV_CRC=0 \
228 -c -o $@ environment.c
229
230BTW, thats a 'zero' ... not the letter 'O'.
231
232
c935d3bd 2336. HELP WANTED
4a551709
WD
234---------------
235
236There are plenty of areas where help is needed. Here's are some ideas
237for those interested in contributing:
238
4a551709
WD
239-CompactFlash. Port & test CF/FAT.
240
4a551709
WD
241-Bedbug. Develop bedbug for Nios ... or at least provide a disassemble
242 command.
243
244-Add boot support for ucLinux (niosnommu).
245
246-Implement (don't copy Altera code) the __mulxx routines using the
247 MSTEP and MUL instructions (e.g. CFG_NIOS_MULT_HW and CFG_NIOS_MULT_MSTEP).
248
249
4a551709
WD
250Regards,
251
252--Scott
253<smcnutt@psyent.com>
c935d3bd
WD
254
255--Stephan
256<linz@li-pro.net>