• Suman Anna's avatar
    remoteproc: k3-r5: Initialize TCM memories for ECC · 34f26536
    Suman Anna authored
    The R5F processors on K3 SoCs all have two TCMs (ATCM and BTCM) that
    support 32-bit ECC. The TCMs are typically loaded with some boot-up
    code to initialize the R5 MPUs to further execute code out of DDR.
    The ECC for the TCMs is enabled by default on K3 SoCs due to internal
    default tie-off values, but the TCM memories are not initialized on
    device power up. Any read access without the corresponding TCM memory
    location initialized will generate an ECC error, and any such access
    from a A72 or A53 core will trigger a SError.
    
    So, zero initialize both the TCM memories before loading any firmware
    onto a R5F in remoteproc mode. Any R5F booted from U-Boot/SPL would
    require a similar initialization in the bootloader. Note that both
    the TCMs are initialized unconditionally as the TCM enable config bits
    only manage the access and visibility from R5.
    Signed-off-by: default avatarSuman Anna <s-anna@ti.com>
    Reviewed-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
    Link: https://lore.kernel.org/r/20201002234234.20704-4-s-anna@ti.comSigned-off-by: default avatarBjorn Andersson <bjorn.andersson@linaro.org>
    34f26536
ti_k3_r5_remoteproc.c 36.1 KB