mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 10:08:21 +01:00 
			
		
		
		
	1: - board/altera/common/flash.c:flash_erase():
     o allow interrupts befor get_timer() call
     o check-up each erased sector and avoid unexpected timeouts
   - board/altera/dk1c20/dk1s10.c:board_early_init_f():
     o enclose sevenseg_set() in cpp condition
   - remove the ASMI configuration for DK1S10_standard_32 (never present)
   - fix some typed in mistakes in the NIOS documentation
2: - split DK1C20 configuration into several header files:
     o two new files for each NIOS CPU description
     o U-Boot related part is remaining in DK1C20.h
3: - split DK1S10 configuration into several header files:
     o two new files for each NIOS CPU description
     o U-Boot related part is remaining in DK1S10.h
4: - Add support for the Microtronix Linux Development Kit
     NIOS CPU configuration at the Altera Nios Development Kit,
     Stratix Edition (DK-1S10)
5: - Add documentation for the Altera Nios Development Kit,
     Stratix Edition (DK-1S10)
6: - Add support for the Nios Serial Peripharel Interface (SPI)
     (master only)
7: - Add support for the common U-Boot SPI framework at
     RTC driver DS1306
		
	
			
		
			
				
	
	
		
			154 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
 | |
| 			 Nios Development Kit
 | |
| 			   Cyclone Editions
 | |
| 
 | |
| 		    Last Update: January 2, 2004
 | |
| ====================================================================
 | |
| 
 | |
| This file contains information regarding U-Boot and the Altera
 | |
| Nios Development Kit, Cyclone Edition (DK-1C20). For general Nios
 | |
| information see doc/README.nios.
 | |
| 
 | |
| For those interested in contributing ... see HELP WANTED section
 | |
| in doc/README.nios.
 | |
| 
 | |
| Contents:
 | |
| 
 | |
| 	1. Files
 | |
| 	2. Memory Organization
 | |
| 	3. Examples
 | |
| 	4. Programming U-Boot into FLASH with GERMS
 | |
| 	5. Active Serial Memory Interface (ASMI) Support
 | |
| 
 | |
| ====================================================================
 | |
| 
 | |
| 1. Files
 | |
| =========
 | |
| 	board/altera/dk1c20/*
 | |
| 	include/configs/DK1C20.h
 | |
| 
 | |
| 2. Memory Organization
 | |
| =======================
 | |
| 
 | |
| 	-The heap is placed below the monitor (U-Boot code).
 | |
| 	-Global data is placed below the heap.
 | |
| 	-The stack is placed below global data (&grows down).
 | |
| 
 | |
| 3. Examples
 | |
| ============
 | |
| 
 | |
| The hello_world example works fine. The default load address
 | |
| is 0x0100_0000 (the start of SDRAM).
 | |
| 
 | |
| 
 | |
| 4. Programming U-Boot into FLASH with GERMS
 | |
| ============================================
 | |
| The current version of the DK-1C20 port with the default
 | |
| configuration settings occupies about 81 KBytes of flash.
 | |
| A minimal configuration occupies less than 60 KByte (asmi
 | |
| and network support disabled).
 | |
| 
 | |
| To program U-Boot into the DK-1C20 flash using GERMS do the
 | |
| following:
 | |
| 
 | |
| 1. From the command line, download U-Boot using the nios-run:
 | |
| 
 | |
| 	$ nios-run -r u-boot.srec
 | |
| 
 | |
| This takes about 45 seconds (GERMS is not very speedy here).
 | |
| After u-boot is downloaded it will be executed. You should
 | |
| see the following:
 | |
| 
 | |
|     U-Boot 1.0.0-pre (Oct  4 2003 - 07:39:24)
 | |
| 
 | |
|     CPU: Nios-32 Rev. 3.3 (0x3038)
 | |
|     Reg file size: 256 LO_LIMIT/HI_LIMIT: 2/14
 | |
|     Board: Altera Nios 1C20 Development Kit
 | |
|     In:	   serial
 | |
|     Out:   serial
 | |
|     Err:   serial
 | |
|     ==>
 | |
| 
 | |
| 
 | |
| 2. Quit nios-run and start your terminal application (e.g. start
 | |
| Hyperterminal or minicom).
 | |
| 
 | |
| 3. Download the u-boot code to RAM. When using Hyperterminal, do the
 | |
| following:
 | |
| 
 | |
|    a.  From the u-boot command prompt start a binary download to SRAM:
 | |
| 
 | |
|     ==> loadb 800000
 | |
| 
 | |
|     b. Download u-boot.bin using kermit.
 | |
| 
 | |
| 4. From the U-Boot command prompt, erase flash 0x40000 to 0x5ffff:
 | |
| 
 | |
|     ==> erase 1:4-5
 | |
| 
 | |
| 5. Copy the binary image from SRAM to flash:
 | |
| 
 | |
|     ==> cp.b 800000 40000 10000
 | |
| 
 | |
| U-Boot will now automatically start when the board is powered on or
 | |
| reset using the Standard-32 configuration. To start U-Boot with the
 | |
| Safe-32 configuration, enter the following GERMS command:
 | |
| 
 | |
|     + g 40000
 | |
| 
 | |
| 5. Active Serial Memory Interface (ASMI) Support
 | |
| ================================================
 | |
| ASMI is fully supported in U-Boot. Please note that ASMI is supported
 | |
| only on Cyclone devices. Do not expect ASMI to work with Stratix or
 | |
| APEX devices.
 | |
| 
 | |
| 		 ************* IMPORTANT *************
 | |
| 	 ===================================================
 | |
| 	IN ORDER FOR THE NIOS ASMI TO OPERATE PROPERLY, THE
 | |
| 	CYCLONE DEVICE MUST BE CONFIGURED USING JTAG OR ASMI.
 | |
| 
 | |
| There are two techniques you can use to bootstrap the ASMI. The
 | |
| first is to use the program_epcs utility that is part of Altera's SDK.
 | |
| But I've found program_epcs to be slow and cumbersome at best.
 | |
| 
 | |
| An undocumented alternative is to use the Quartus device programing
 | |
| interface:
 | |
| 
 | |
|     1. Select "Active Serial" mode.
 | |
| 
 | |
|     2. Choose the xxx.pof file. For example, for the standard_32
 | |
|        configuration use the "standard_32.pof" file.
 | |
| 
 | |
|     3. Attach your ByteBlaster to J28. Make sure you have the
 | |
|        cable attached properly -- the orientation of J28 is
 | |
|        different than J24 (the JTAG header). On J28, pin 1 is on
 | |
|        the bottom row, left-most pin.
 | |
| 
 | |
|     4. Press and hold the "Power-On Reset" switch (SW10). You will
 | |
|        see the green "Loading" and red "Error" LEDs (LED3 and LED4)
 | |
|        in the on state.
 | |
| 
 | |
|     5. While holding down the "Power-On Reset" switch, start the
 | |
|        programming sequence. This only takes about 10 seconds.
 | |
| 
 | |
|     6. After programming is complete, release the "Power-On Reset"
 | |
|        switch. The Cyclone device should now load its configuration
 | |
|        from the EPCS4 (U59). The green "User" LED (LED 1) should be
 | |
|        blinking if the device was successfully loaded via ASMI.
 | |
| 
 | |
|     7. Remove the ByteBlaster cable. The cable must be removed to
 | |
|        allow the Nios ASMI access to the EPCS4 device.
 | |
| 
 | |
| After you have successfully programmed a configuration into the
 | |
| EPCS4, the ASMI will be used to load the Cyclone configuration
 | |
| unless the "Force Safe" switch (SW9) is pressed.
 | |
| 
 | |
| NOTE: To maximize the amount of space available for program use,
 | |
| you can enable configuration compression in Quartus. With compression
 | |
| enabled, the size of the standard_32 configuration data is
 | |
| approximately 192 KBytes.
 | |
| 
 | |
| To use the U-Boot ASMI commands, try typing "help asmi" at the
 | |
| command prompt. The command "asmi info" will show the current
 | |
| status of the ASMI.
 |