You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
55 lines
1.6 KiB
55 lines
1.6 KiB
8 months ago
|
|
||
|
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
|