| |
| Notes for the MIPS architecture port of U-Boot |
| |
| Toolchains |
| ---------- |
| |
| http://www.denx.de/wiki/DULG/ELDK |
| ELDK < DULG < DENX |
| |
| http://www.emdebian.org/crosstools.html |
| Embedded Debian -- Cross-development toolchains |
| |
| http://buildroot.uclibc.org/ |
| Buildroot |
| |
| Known Issues |
| ------------ |
| |
| * Cache incoherency issue caused by do_bootelf_exec() at cmd_elf.c |
| |
| Cache will be disabled before entering the loaded ELF image without |
| writing back and invalidating cache lines. This leads to cache |
| incoherency in most cases, unless the code gets loaded after U-Boot |
| re-initializes the cache. The more common uImage 'bootm' command does |
| not suffer this problem. |
| |
| [workaround] To avoid this cache incoherency, |
| 1) insert flush_cache(all) before calling dcache_disable(), or |
| 2) fix dcache_disable() to do both flushing and disabling cache. |
| |
| * Note that Linux users need to kill dcache_disable() in do_bootelf_exec() |
| or override do_bootelf_exec() not to disable I-/D-caches, because most |
| Linux/MIPS ports don't re-enable caches after entering kernel_entry. |
| |
| TODOs |
| ----- |
| |
| * Probe CPU types, I-/D-cache and TLB size etc. automatically |
| |
| * Secondary cache support missing |
| |
| * Initialize TLB entries redardless of their use |
| |
| * R2000/R3000 class parts are not supported |
| |
| * Limited testing across different MIPS variants |
| |
| * Due to cache initialization issues, the DRAM on board must be |
| initialized in board specific assembler language before the cache init |
| code is run -- that is, initialize the DRAM in lowlevel_init(). |
| |
| * centralize/share more CPU code of MIPS32, MIPS64 and XBurst |
| |
| * support Qemu Malta |