| qemu target: sh4 |
| author: Samuel Tardieu <sam@rfc1149.net> |
| last modified: Tue Dec 6 07:22:44 CET 2005 |
| |
| The sh4 target is not ready at all yet for integration in qemu. This |
| file describes the current state of implementation. |
| |
| Most places requiring attention and/or modification can be detected by |
| looking for "XXXXX" or "abort()". |
| |
| The sh4 core is located in target-sh4/*, while the 7750 peripheral |
| features (IO ports for example) are located in hw/sh7750.[ch]. The |
| main board description is in hw/shix.c, and the NAND flash in |
| hw/tc58128.[ch]. |
| |
| All the shortcomings indicated here will eventually be resolved. This |
| is a work in progress. Features are added in a semi-random order: if a |
| point is blocking to progress on booting the Linux kernel for the shix |
| board, it is addressed first; if feedback is necessary and no progress |
| can be made on blocking points until it is received, a random feature |
| is worked on. |
| |
| Goals |
| ----- |
| |
| The primary model being worked on is the soft MMU target to be able to |
| emulate the Shix 2.0 board by Alexis Polti, described at |
| http://perso.enst.fr/~polti/realisations/shix20/ |
| |
| Ultimately, qemu will be coupled with a system C or a verilog |
| simulator to simulate the whole board functionalities. |
| |
| A sh4 user-mode has also somewhat started but will be worked on |
| afterwards. The goal is to automate tests for GNAT (GNU Ada) compiler |
| that I ported recently to the sh4-linux target. |
| |
| Registers |
| --------- |
| |
| 16 general purpose registers are available at any time. The first 8 |
| registers are banked and the non-directly visible ones can be accessed |
| by privileged instructions. In qemu, we define 24 general purpose |
| registers and the code generation use either [0-7]+[8-15] or |
| [16-23]+[8-15] depending on the MD and RB flags in the sr |
| configuration register. |
| |
| Instructions |
| ------------ |
| |
| Most sh4 instructions have been implemented. The missing ones at this |
| time are: |
| - FPU related instructions |
| - LDTLB to load a new MMU entry |
| - SLEEP to put the processor in sleep mode |
| |
| Most instructions could be optimized a lot. This will be worked on |
| after the current model is fully functional unless debugging |
| convenience requires that it is done early. |
| |
| Many instructions did not have a chance to be tested yet. The plan is |
| to implement unit and regression testing of those in the future. |
| |
| MMU |
| --- |
| |
| The MMU is implemented in the sh4 core. MMU management has not been |
| tested at all yet. In the sh7750, it can be manipulated through memory |
| mapped registers and this part has not yet been implemented. |
| |
| Exceptions |
| ---------- |
| |
| Exceptions are implemented as described in the sh4 reference manual |
| but have not been tested yet. They do not use qemu EXCP_ features |
| yet. |
| |
| IRQ |
| --- |
| |
| IRQ are not implemented yet. |
| |
| Peripheral features |
| ------------------- |
| |
| + Serial ports |
| |
| Configuration and use of the first serial port (SCI) without |
| interrupts is supported. Input has not yet been tested. |
| |
| Configuration of the second serial port (SCIF) is supported. FIFO |
| handling infrastructure has been started but is not completed yet. |
| |
| + GPIO ports |
| |
| GPIO ports have been implemented. A registration function allows |
| external modules to register interest in some port changes (see |
| hw/tc58128.[ch] for an example) and will be called back. Interrupt |
| generation is not yet supported but some infrastructure is in place |
| for this purpose. Note that in the current model a peripheral module |
| cannot directly simulate a H->L->H input port transition and have an |
| interrupt generated on the low level. |
| |
| + TC58128 NAND flash |
| |
| TC58128 NAND flash is partially implemented through GPIO ports. It |
| supports reading from flash. |
| |
| GDB |
| --- |
| |
| GDB remote target support has been implemented and lightly tested. |
| |
| Files |
| ----- |
| |
| File names are hardcoded at this time. The bootloader must be stored in |
| shix_bios.bin in the current directory. The initial Linux image must |
| be stored in shix_linux_nand.bin in the current directory in NAND |
| format. Test files can be obtained from |
| http://perso.enst.fr/~polti/robot/ as well as the various datasheets I |
| use. |
| |
| qemu disk parameter on the command line is unused. You can supply any |
| existing image and it will be ignored. As the goal is to simulate an |
| embedded target, it is not clear how this parameter will be handled in |
| the future. |
| |
| To build an ELF kernel image from the NAND image, 16 bytes have to be |
| stripped off the end of every 528 bytes, keeping only 512 of them. The |
| following Python code snippet does it: |
| |
| #! /usr/bin/python |
| |
| def denand (infd, outfd): |
| while True: |
| d = infd.read (528) |
| if not d: return |
| outfd.write (d[:512]) |
| |
| if __name__ == '__main__': |
| import sys |
| denand (open (sys.argv[1], 'rb'), |
| open (sys.argv[2], 'wb')) |
| |
| Style isssues |
| ------------- |
| |
| There is currently a mix between my style (space before opening |
| parenthesis) and qemu style. This will be resolved before final |
| integration is proposed. |