memory-organization-2 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. beim Durchschauen der Implementierung bin ich (soweit ich das sehe) teilweise zu anderen Ergebnissen gekommen, vornehmlich was die Adressbreiten angeht (ich beziehe mich auf die Werte der Beispielimplementierung aus dem geteilten Repository). Die Zusammenfassung finden Sie im Folgenden (mein Ziel war es auch eine Übersicht der Implementierungsfiles zu erstellen, d.h. was wo zu finden ist, die Ihnen bereits bekannt sein dürfte, der Vollständigkeit halber habe ich jedoch nun alles beigefügt):
  2. ###MEMORY STRUCTURE MIRIV###
  3. - top.vhd contains:
  4. (1) pll
  5. (2) core
  6. interface of core to memory:
  7. - Instructions: mem_i_in (MEM->CORE) / mem_i_out (CORE->MEM)
  8. - Data: mem_d_in (MEM->CORE) / mem_d_out (CORE->MEM)
  9. (3) devices
  10. - core.vhd contains:
  11. (1) pipeline
  12. (2) dcache
  13. - devices.vhd contains:
  14. (1) delay unit for imem
  15. (2) delay unit for dmem
  16. (3) serial port wrapper (memory-mapped addresses "as part" of dmem)
  17. (4) counter (memory-mapped address "as part" of dmem)
  18. (5) memory (separate dmem/imem ports)
  19. (6) multiplexer (separating/forwarding dmem address into "actual dmem", counter, uart)
  20. - memory.vhd contains:
  21. (1) jtag_mem
  22. (2) jtag multiplexer
  23. (3) imem
  24. (4) dmem
  25. ==CORE/PIPELINE PERSPECTIVE==
  26. - ADDR_WIDTH (mem_pkg): 14 (pipeline works with byte-addresses) => 2^14Byte (16KB) for dmem; 2^14Byte (16KB) for imem
  27. For accessing the dmem, inside the pipeline byte-addressing is used, where theoretically an address width of 32 could be covered. However, in the memu the last two bits are cut off and (ADDR_WIDTH+1 downto 2) are passed to the devices as a 14-bit wide address (with word granularity). The upper two bits of this address distinguish between "actual dmem", uart and the counter.
  28. ==JTAG PERSPECTIVE==
  29. - RAM_SIZE_LD (generic of memory, set in devices; word-addressed): 12 => 2^12 words (16KB) for dmem; 2^12 words (16KB) for imem
  30. jtag views CTRL (for triggering reset), IMEM, DMEM in a combined address space with
  31. 00_(RAM_SIZE_LD-1 downto 0) => DMEM (word-addressed)
  32. 01_(RAM_SIZE_LD-1 downto 0) => IMEM (word-addressed)
  33. ###MEMORY STRUCTURE MIRIV###
  34. Das heißt, ich komme hier jeweils auf eine Adressbreite (Wortgranularität) von 12bit jeweils für:
  35. - DMEM (bezogen auf jtag im bootloader memory.vhd: 0x0000 bis 0x0FFF)
  36. - IMEM (bezogen auf jtag im bootloader memory.vhd: 0x1000 bis 0x1FFF)
  37. (Die in bootloader.tcl angegebene Basisadresse 0x400 ist meiner Ansicht nach etwas irreführend, da die ankommende Basisadresse meiner Analyse nach tatsächlich 0x1000 ist, wenn der IMEM gefüllt wird.)
  38. Daraus würde ich den Schluss ziehen, dass der Stack mit der Initialisierung mit 0x1000 (Bytegranularität) nicht am "oberen Ende" des DMEM beginnt (ich habe dazu ein Testprogramm mit Ihnen über owncloud geteilt, das diese These zu bestätigen scheint).
  39. Hinsichtlich der Adresse der Textsection (die im Endeffekt ein Artefakt aus der MIPS-Zeit ist bzw. von dort übernommen wurde) wäre meine Erklärung wie folgt: Grundsätzlich muss zwischen den Instruktionen (die nach *.imem.mif gehören, d.h. das Initialisierungsfile für den Instruction Memory) und Daten (die nach *.dmem.mif gehören) getrennt werden (soweit ist das vermutlich bekannt). Daher sollte die Textsection an einer bekannten Adresse platziert werden, getrennt von den Daten gehalten werden und so arrangiert sein, dass es möglich ist die erste Instruktion an (IMEM-)Adresse 0x0...0 zu verlegen. Die Auftrennung erfolgt dann mittels 'objcopy' im Makefile (nach *.imem.hex und *.dmem.hex), danach werden beim Umwandeln von *.hex nach *.mif (in hex2mif.pl) die obersten beiden bits entfernt, so dass die Daten an der niedrigsten Adresse im IMEM und DMEM landen.