zephyr/boards
Nicolas Pitre a50c433012 riscv: exception code mega simplification and optimization
Complete revamp of the exception entry code, including syscall handling.
Proper syscall frame exception trigger. Many correctness fixes, hacks
removal, etc. etc.

I tried to make this into several commits, but this stuff is all
inter-related and a pain to split.

The diffstat summary:

 14 files changed, 250 insertions(+), 802 deletions(-)

Binary size (before):

   text	   data	    bss	    dec	    hex	filename
   1104	      0	      0	   1104	    450	isr.S.obj
     64	      0	      0	     64	     40	userspace.S.obj

Binary size (after):

   text	   data	    bss	    dec	    hex	filename
    600	      0	      0	    600	    258	isr.S.obj
     36	      0	      0	     36	     24	userspace.S.obj

Run of samples/userspace/syscall_perf (before):

*** Booting Zephyr OS build zephyr-v3.0.0-325-g3748accae018  ***
Main Thread started; qemu_riscv32
Supervisor thread started
User thread started
Supervisor thread(0x80010048):       384 cycles	     509 instructions
User thread(0x80010140):           77312 cycles	   77437 instructions

Run of samples/userspace/syscall_perf (after):

*** Booting Zephyr OS build zephyr-v3.0.0-326-g4c877a2753b3  ***
Main Thread started; qemu_riscv32
Supervisor thread started
User thread started
Supervisor thread(0x80010048):       384 cycles	     509 instructions
User thread(0x80010138):            7040 cycles     7165 instructions

Yes, that's more than a 10x speed-up!

Signed-off-by: Nicolas Pitre <npitre@baylibre.com>
2022-03-21 07:28:05 -04:00
..
arc everywhere: fix typos 2022-03-18 13:24:08 -04:00
arm everywhere: fix typos 2022-03-18 13:24:08 -04:00
arm64 boards: fvp v8r: Fix the SRAM/FLASH to the right address 2022-03-16 09:19:44 -05:00
common runners: pyocd: Enable semihosting in pyOCD 2022-01-13 13:37:58 -06:00
mips boards: mips: add Qemu Malta support 2022-01-19 13:48:21 -05:00
nios2
posix everywhere: fix typos 2022-03-18 13:24:08 -04:00
riscv riscv: exception code mega simplification and optimization 2022-03-21 07:28:05 -04:00
shields everywhere: fix typos 2022-03-18 13:24:08 -04:00
sparc
x86 everywhere: fix typos 2022-03-18 13:24:08 -04:00
xtensa boards/odroid_go: Update odroid_go board 2022-03-19 17:45:11 +01:00
CMakeLists.txt
Kconfig
deprecated.cmake
index.rst boards: mips: add Qemu Malta support 2022-01-19 13:48:21 -05:00