diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-04-22 13:09:39 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-04-22 14:30:06 +0200 |
commit | 582e427280d00cde3bdac7c81e8fa26bec7fbde9 (patch) | |
tree | d54856bcec082b86cd84e18dd6e169f00d3722d1 /c/src/lib/libbsp/powerpc/qoriq/startup/l1cache.S | |
parent | bsp/qoriq: Do not reset time base (diff) | |
download | rtems-582e427280d00cde3bdac7c81e8fa26bec7fbde9.tar.bz2 |
bsp/qoriq: Move L1 cache invalidate function
Diffstat (limited to 'c/src/lib/libbsp/powerpc/qoriq/startup/l1cache.S')
-rw-r--r-- | c/src/lib/libbsp/powerpc/qoriq/startup/l1cache.S | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/c/src/lib/libbsp/powerpc/qoriq/startup/l1cache.S b/c/src/lib/libbsp/powerpc/qoriq/startup/l1cache.S new file mode 100644 index 0000000000..bee3d28123 --- /dev/null +++ b/c/src/lib/libbsp/powerpc/qoriq/startup/l1cache.S @@ -0,0 +1,43 @@ +/* + * Copyright (c) 2015, 2016 embedded brains GmbH. All rights reserved. + * + * embedded brains GmbH + * Dornierstr. 4 + * 82178 Puchheim + * Germany + * <rtems@embedded-brains.de> + * + * The license and distribution terms for this file may be + * found in the file LICENSE in this distribution or at + * http://www.rtems.org/license/LICENSE. + */ + +#include <libcpu/powerpc-utility.h> + + .global qoriq_l1cache_invalidate + + .section ".bsp_start_text", "ax" + +qoriq_l1cache_invalidate: + + /* Invalidate L1 data cache */ + mfspr r3, FSL_EIS_L1CSR0 + ori r3, r3, FSL_EIS_L1CSR0_CFI + mtspr FSL_EIS_L1CSR0, r3 +1: + mfspr r3, FSL_EIS_L1CSR0 + andi. r3, r3, FSL_EIS_L1CSR0_CFI + bne 1b + isync + + /* Invalidate L1 instruction cache */ + mfspr r3, FSL_EIS_L1CSR1 + ori r3, r3, FSL_EIS_L1CSR1_ICFI + mtspr FSL_EIS_L1CSR1, r3 +1: + mfspr r3, FSL_EIS_L1CSR1 + andi. r3, r3, FSL_EIS_L1CSR1_ICFI + bne 1b + isync + + blr |