wdenk | b02744a | 2003-04-05 00:53:31 +0000 | [diff] [blame] | 1 | |
| 2 | Flash programming on the INCA-IP board is complicated because of the |
| 3 | EBU swapping unit. A BDI2000 can be used for flash programming only |
| 4 | if the EBU swapping unit is enabled; otherwise it will not detect the |
| 5 | flash memory. But the EBU swapping unit is disadbled after reset, so |
| 6 | if you program some code to flash with the swapping unit on, it will |
| 7 | not be runnable with the swapping unit off. |
| 8 | |
| 9 | The consequence is that you have to write a pre-swapped image to |
| 10 | flash using the BDI2000. A simple host-side tool "inca-swap-bytes" is |
| 11 | provided in the "tools/" directory. Use it as follows: |
| 12 | |
| 13 | bash$ ./inca-swap-bytes <u-boot.bin >u-boot.bin.swp |
| 14 | |
| 15 | Note that the current BDI config file _disables_ the EBU swapping |
| 16 | unit for the flash bank 0. To enable it, (this is required for the |
| 17 | BDI flash commands to work) uncomment the following line in the |
| 18 | config file: |
| 19 | |
| 20 | ;WM32 0xb8000260 0x404161ff ; Swapping unit enabled |
| 21 | |
| 22 | and comment out |
| 23 | |
| 24 | WM32 0xb8000260 0x004161ff ; Swapping unit disabled |
| 25 | |
| 26 | Alternatively, you can use "mm 0xb8000260 <value>" commands to |
| 27 | enable/disable the swapping unit manually. |
| 28 | |
| 29 | Just for reference, here is the complete sequence of actions we took |
| 30 | to install a U-Boot image into flash. |
| 31 | |
| 32 | 1. ./inca-swap-bytes <u-boot.bin >u-boot.bin.swp |
| 33 | |
| 34 | 2. From BDI: |
| 35 | |
| 36 | mm 0xb8000260 0x404161ff |
| 37 | erase 0xb0000000 |
| 38 | erase 0xb0010000 |
| 39 | prog 0xb0000000 /tftpboot/INCA/u-boot.bin.swp bin |
| 40 | mm 0xb8000260 0x004161ff |
| 41 | go 0xb0000000 |
| 42 | |
| 43 | |
wdenk | 5d84173 | 2003-08-17 18:55:18 +0000 | [diff] [blame] | 44 | Ethernet autonegotiation needs some time to complete. Instead of |
| 45 | delaying the boot process in all cases, we just start the |
| 46 | autonegotiation process when U-Boot comes up and that is all. Most |
| 47 | likely, it will complete by the time the network transfer is |
| 48 | attempted for the first time. In the worst case, if a transfer is |
| 49 | attempted before the autonegotiation is complete, just a single |
| 50 | packet would be lost resulting in a single timeout error, and then |
| 51 | the transfer would proceed normally. So the time that we would have |
| 52 | lost unconditionally waiting for the autonegotiation to complete, we |
| 53 | have to wait only if the file transfer is started immediately after |
| 54 | reset. We've verified that this works for all the clock |
| 55 | configurations. |
| 56 | |
wdenk | b02744a | 2003-04-05 00:53:31 +0000 | [diff] [blame] | 57 | (C) 2003 Wolfgang Denk |