• Vincent Chen's avatar
    riscv: Introduce alternative mechanism to apply errata solution · 6f4eea90
    Vincent Chen authored
    Introduce the "alternative" mechanism from ARM64 and x86 to apply the CPU
    vendors' errata solution at runtime. The main purpose of this patch is
    to provide a framework. Therefore, the implementation is quite basic for
    now so that some scenarios could not use this schemei, such as patching
    code to a module, relocating the patching code and heterogeneous CPU
    topology.
    
    Users could use the macro ALTERNATIVE to apply an errata to the existing
    code flow. In the macro ALTERNATIVE, users need to specify the manufacturer
    information(vendorid, archid, and impid) for this errata. Therefore, kernel
    will know this errata is suitable for which CPU core. During the booting
    procedure, kernel will select the errata required by the CPU core and then
    patch it. It means that the kernel only applies the errata to the specified
    CPU core. In this case, the vendor's errata does not affect each other at
    runtime. The above patching procedure only occurs during the booting phase,
    so we only take the overhead of the "alternative" mechanism once.
    
    This "alternative" mechanism is enabled by default to ensure that all
    required errata will be applied. However, users can disable this feature by
    the Kconfig "CONFIG_RISCV_ERRATA_ALTERNATIVE".
    Signed-off-by: default avatarVincent Chen <vincent.chen@sifive.com>
    Reviewed-by: default avatarAnup Patel <anup@brainfault.org>
    Signed-off-by: default avatarPalmer Dabbelt <palmerdabbelt@google.com>
    6f4eea90
Kconfig 11.5 KB