genode/repos/base-hw/src/core/spec/riscv
Stefan Kalkowski 8e13b376b0 hw: improve cross-cpu synchronization
This commit addresses several multiprocessing issues in base-hw:

* it reworks cross-cpu maintainance work for TLB invalidation by
  introducing a generic Inter_processor_work and removes the so
  called Cpu_domain_update
* thereby it solves the cross-cpu thread destruction, when the
  corresponding thread is active on another cpu (fix #3043)
* it adds the missing TLB shootdown for x86 (fix #3042)
* on ARM it removes the TLB shootdown via IPIs, because this
  is not needed on the multiprocessing ARM platforms we support
* it enables the per-cpu initialization of the kernel's cpu
  objects, which means those object initialization is executed
  by the proper cpu
* it rollbacks prior decision to make multiprocessing an aspect,
  but puts back certain 'smp' mechanisms (like cross-cpu lock)
  into the generic code base for simplicity reasons
2019-01-07 12:25:44 +01:00
..
kernel hw: improve cross-cpu synchronization 2019-01-07 12:25:44 +01:00
board.h hw: prevent warning about conversion narrowing 2017-06-19 12:35:57 +02:00
cpu.cc Follow practices suggested by "Effective C++" 2018-01-17 12:14:35 +01:00
cpu.h Follow practices suggested by "Effective C++" 2018-01-17 12:14:35 +01:00
crt0.s hw: switch page-tables only when necessary 2017-10-19 13:31:18 +02:00
exception_vector.s hw: turn Cpu_idle into a Thread 2017-11-06 13:57:20 +01:00
pic.h Follow practices suggested by "Effective C++" 2018-01-17 12:14:35 +01:00
platform_support.cc Follow practices suggested by "Effective C++" 2018-01-17 12:14:35 +01:00
timer.cc base-hw: timer support for RISC-V 2017-08-30 10:00:00 +02:00
timer_driver.h base-hw: timer support for RISC-V 2017-08-30 10:00:00 +02:00
translation_table.h Follow practices suggested by "Effective C++" 2018-01-17 12:14:35 +01:00