Skip to content
Snippets Groups Projects
Commit 4bab70a7 authored by Masahiro Yamada's avatar Masahiro Yamada
Browse files

ARM: uniphier: rename outer-cache register macros


Sync register macros with Linux code.  This will be helpful to
develop the counterpart of Linux.

Signed-off-by: default avatarMasahiro Yamada <yamada.masahiro@socionext.com>
parent ebab100a
No related branches found
No related tags found
No related merge requests found
...@@ -7,7 +7,7 @@ obj-y += lowlevel_init.o ...@@ -7,7 +7,7 @@ obj-y += lowlevel_init.o
obj-$(CONFIG_DEBUG_LL) += debug_ll.o obj-$(CONFIG_DEBUG_LL) += debug_ll.o
else else
obj-y += late_lowlevel_init.o obj-y += late_lowlevel_init.o
obj-y += cache_uniphier.o obj-y += cache-uniphier.o
endif endif
obj-y += timer.o obj-y += timer.o
/* /*
* Copyright (C) 2012-2015 Masahiro Yamada <yamada.masahiro@socionext.com> * Copyright (C) 2012-2014 Panasonic Corporation
* Copyright (C) 2015-2016 Socionext Inc.
* Author: Masahiro Yamada <yamada.masahiro@socionext.com>
* *
* SPDX-License-Identifier: GPL-2.0+ * SPDX-License-Identifier: GPL-2.0+
*/ */
...@@ -13,22 +15,26 @@ ...@@ -13,22 +15,26 @@
#ifdef CONFIG_UNIPHIER_L2CACHE_ON #ifdef CONFIG_UNIPHIER_L2CACHE_ON
static void uniphier_cache_sync(void) static void uniphier_cache_sync(void)
{ {
writel(SSCOPE_CM_SYNC, SSCOPE); /* drain internal buffers */ /* drain internal buffers */
readl(SSCOPE); /* need a read back to confirm */ writel(UNIPHIER_SSCOPE_CM_SYNC, UNIPHIER_SSCOPE);
/* need a read back to confirm */
readl(UNIPHIER_SSCOPE);
} }
static void uniphier_cache_maint_all(u32 operation) static void uniphier_cache_maint_all(u32 operation)
{ {
/* clear the complete notification flag */ /* clear the complete notification flag */
writel(SSCOLPQS_EF, SSCOLPQS); writel(UNIPHIER_SSCOLPQS_EF, UNIPHIER_SSCOLPQS);
/* try until the command is successfully set */ /* try until the command is successfully set */
do { do {
writel(SSCOQM_S_ALL | SSCOQM_CE | operation, SSCOQM); writel(UNIPHIER_SSCOQM_S_ALL | UNIPHIER_SSCOQM_CE | operation,
} while (readl(SSCOPPQSEF) & (SSCOPPQSEF_FE | SSCOPPQSEF_OE)); UNIPHIER_SSCOQM);
} while (readl(UNIPHIER_SSCOPPQSEF) &
(UNIPHIER_SSCOPPQSEF_FE | UNIPHIER_SSCOPPQSEF_OE));
/* wait until the operation is completed */ /* wait until the operation is completed */
while (readl(SSCOLPQS) != SSCOLPQS_EF) while (readl(UNIPHIER_SSCOLPQS) != UNIPHIER_SSCOLPQS_EF)
; ;
uniphier_cache_sync(); uniphier_cache_sync();
...@@ -36,29 +42,31 @@ static void uniphier_cache_maint_all(u32 operation) ...@@ -36,29 +42,31 @@ static void uniphier_cache_maint_all(u32 operation)
void v7_outer_cache_flush_all(void) void v7_outer_cache_flush_all(void)
{ {
uniphier_cache_maint_all(SSCOQM_CM_WB_INV); uniphier_cache_maint_all(UNIPHIER_SSCOQM_CM_FLUSH);
} }
void v7_outer_cache_inval_all(void) void v7_outer_cache_inval_all(void)
{ {
uniphier_cache_maint_all(SSCOQM_CM_INV); uniphier_cache_maint_all(UNIPHIER_SSCOQM_CM_INV);
} }
static void __uniphier_cache_maint_range(u32 start, u32 size, u32 operation) static void __uniphier_cache_maint_range(u32 start, u32 size, u32 operation)
{ {
/* clear the complete notification flag */ /* clear the complete notification flag */
writel(SSCOLPQS_EF, SSCOLPQS); writel(UNIPHIER_SSCOLPQS_EF, UNIPHIER_SSCOLPQS);
/* try until the command is successfully set */ /* try until the command is successfully set */
do { do {
writel(SSCOQM_S_ADDRESS | SSCOQM_CE | operation, SSCOQM); writel(UNIPHIER_SSCOQM_S_RANGE | UNIPHIER_SSCOQM_CE | operation,
writel(start, SSCOQAD); UNIPHIER_SSCOQM);
writel(size, SSCOQSZ); writel(start, UNIPHIER_SSCOQAD);
writel(size, UNIPHIER_SSCOQSZ);
} while (readl(SSCOPPQSEF) & (SSCOPPQSEF_FE | SSCOPPQSEF_OE)); } while (readl(UNIPHIER_SSCOPPQSEF) &
(UNIPHIER_SSCOPPQSEF_FE | UNIPHIER_SSCOPPQSEF_OE));
/* wait until the operation is completed */ /* wait until the operation is completed */
while (readl(SSCOLPQS) != SSCOLPQS_EF) while (readl(UNIPHIER_SSCOLPQS) != UNIPHIER_SSCOLPQS_EF)
; ;
} }
...@@ -70,11 +78,11 @@ static void uniphier_cache_maint_range(u32 start, u32 end, u32 operation) ...@@ -70,11 +78,11 @@ static void uniphier_cache_maint_range(u32 start, u32 end, u32 operation)
* If start address is not aligned to cache-line, * If start address is not aligned to cache-line,
* do cache operation for the first cache-line * do cache operation for the first cache-line
*/ */
start = start & ~(SSC_LINE_SIZE - 1); start = start & ~(UNIPHIER_SSC_LINE_SIZE - 1);
size = end - start; size = end - start;
if (unlikely(size >= (u32)(-SSC_LINE_SIZE))) { if (unlikely(size >= (u32)(-UNIPHIER_SSC_LINE_SIZE))) {
/* this means cache operation for all range */ /* this means cache operation for all range */
uniphier_cache_maint_all(operation); uniphier_cache_maint_all(operation);
return; return;
...@@ -84,11 +92,11 @@ static void uniphier_cache_maint_range(u32 start, u32 end, u32 operation) ...@@ -84,11 +92,11 @@ static void uniphier_cache_maint_range(u32 start, u32 end, u32 operation)
* If end address is not aligned to cache-line, * If end address is not aligned to cache-line,
* do cache operation for the last cache-line * do cache operation for the last cache-line
*/ */
size = ALIGN(size, SSC_LINE_SIZE); size = ALIGN(size, UNIPHIER_SSC_LINE_SIZE);
while (size) { while (size) {
u32 chunk_size = size > SSC_RANGE_OP_MAX_SIZE ? u32 chunk_size = size > UNIPHIER_SSC_RANGE_OP_MAX_SIZE ?
SSC_RANGE_OP_MAX_SIZE : size; UNIPHIER_SSC_RANGE_OP_MAX_SIZE : size;
__uniphier_cache_maint_range(start, chunk_size, operation); __uniphier_cache_maint_range(start, chunk_size, operation);
start += chunk_size; start += chunk_size;
...@@ -100,16 +108,16 @@ static void uniphier_cache_maint_range(u32 start, u32 end, u32 operation) ...@@ -100,16 +108,16 @@ static void uniphier_cache_maint_range(u32 start, u32 end, u32 operation)
void v7_outer_cache_flush_range(u32 start, u32 end) void v7_outer_cache_flush_range(u32 start, u32 end)
{ {
uniphier_cache_maint_range(start, end, SSCOQM_CM_WB_INV); uniphier_cache_maint_range(start, end, UNIPHIER_SSCOQM_CM_FLUSH);
} }
void v7_outer_cache_inval_range(u32 start, u32 end) void v7_outer_cache_inval_range(u32 start, u32 end)
{ {
if (start & (SSC_LINE_SIZE - 1)) { if (start & (UNIPHIER_SSC_LINE_SIZE - 1)) {
start &= ~(SSC_LINE_SIZE - 1); start &= ~(UNIPHIER_SSC_LINE_SIZE - 1);
__uniphier_cache_maint_range(start, SSC_LINE_SIZE, __uniphier_cache_maint_range(start, UNIPHIER_SSC_LINE_SIZE,
SSCOQM_CM_WB_INV); UNIPHIER_SSCOQM_CM_FLUSH);
start += SSC_LINE_SIZE; start += UNIPHIER_SSC_LINE_SIZE;
} }
if (start >= end) { if (start >= end) {
...@@ -117,10 +125,10 @@ void v7_outer_cache_inval_range(u32 start, u32 end) ...@@ -117,10 +125,10 @@ void v7_outer_cache_inval_range(u32 start, u32 end)
return; return;
} }
if (end & (SSC_LINE_SIZE - 1)) { if (end & (UNIPHIER_SSC_LINE_SIZE - 1)) {
end &= ~(SSC_LINE_SIZE - 1); end &= ~(UNIPHIER_SSC_LINE_SIZE - 1);
__uniphier_cache_maint_range(end, SSC_LINE_SIZE, __uniphier_cache_maint_range(end, UNIPHIER_SSC_LINE_SIZE,
SSCOQM_CM_WB_INV); UNIPHIER_SSCOQM_CM_FLUSH);
} }
if (start >= end) { if (start >= end) {
...@@ -128,26 +136,27 @@ void v7_outer_cache_inval_range(u32 start, u32 end) ...@@ -128,26 +136,27 @@ void v7_outer_cache_inval_range(u32 start, u32 end)
return; return;
} }
uniphier_cache_maint_range(start, end, SSCOQM_CM_INV); uniphier_cache_maint_range(start, end, UNIPHIER_SSCOQM_CM_INV);
} }
void v7_outer_cache_enable(void) void v7_outer_cache_enable(void)
{ {
u32 tmp; u32 tmp;
writel(U32_MAX, SSCLPDAWCR); /* activate all ways */ writel(U32_MAX, UNIPHIER_SSCLPDAWCR); /* activate all ways */
tmp = readl(SSCC); tmp = readl(UNIPHIER_SSCC);
tmp |= SSCC_ON; tmp |= UNIPHIER_SSCC_ON;
writel(tmp, SSCC); writel(tmp, UNIPHIER_SSCC);
} }
#endif #endif
void v7_outer_cache_disable(void) void v7_outer_cache_disable(void)
{ {
u32 tmp; u32 tmp;
tmp = readl(SSCC);
tmp &= ~SSCC_ON; tmp = readl(UNIPHIER_SSCC);
writel(tmp, SSCC); tmp &= ~UNIPHIER_SSCC_ON;
writel(tmp, UNIPHIER_SSCC);
} }
void enable_caches(void) void enable_caches(void)
......
...@@ -10,9 +10,9 @@ ...@@ -10,9 +10,9 @@
#include "ssc-regs.h" #include "ssc-regs.h"
ENTRY(lowlevel_init) ENTRY(lowlevel_init)
ldr r1, = SSCC ldr r1, = UNIPHIER_SSCC
ldr r0, [r1] ldr r0, [r1]
bic r0, r0, #SSCC_ON @ L2 disable bic r0, r0, #UNIPHIER_SSCC_ON @ L2 disable
str r0, [r1] str r0, [r1]
mov pc, lr mov pc, lr
ENDPROC(lowlevel_init) ENDPROC(lowlevel_init)
/* /*
* Copyright (C) 2012-2015 Masahiro Yamada <yamada.masahiro@socionext.com> * Copyright (C) 2012-2015 Panasonic Corporation
* Copyright (C) 2015-2016 Socionext Inc.
* Author: Masahiro Yamada <yamada.masahiro@socionext.com>
* *
* SPDX-License-Identifier: GPL-2.0+ * SPDX-License-Identifier: GPL-2.0+
*/ */
...@@ -94,26 +96,26 @@ ENTRY(setup_init_ram) ...@@ -94,26 +96,26 @@ ENTRY(setup_init_ram)
*/ */
0: 0:
/* /*
* set SSCOQM, SSCOQAD, SSCOQSZ, SSCOQWN in this order * set UNIPHIER_SSCOQM, UNIPHIER_SSCOQAD, UNIPHIER_SSCOQSZ, UNIPHIER_SSCOQWN in this order
*/ */
ldr r0, = 0x00408006 @ touch to zero with address range ldr r0, = 0x00408006 @ touch to zero with address range
ldr r1, = SSCOQM ldr r1, = UNIPHIER_SSCOQM
str r0, [r1] str r0, [r1]
ldr r0, = BOOT_RAM_BASE ldr r0, = BOOT_RAM_BASE
ldr r1, = SSCOQAD ldr r1, = UNIPHIER_SSCOQAD
str r0, [r1] str r0, [r1]
ldr r0, = BOOT_RAM_SIZE ldr r0, = BOOT_RAM_SIZE
ldr r1, = SSCOQSZ ldr r1, = UNIPHIER_SSCOQSZ
str r0, [r1] str r0, [r1]
ldr r0, = BOOT_WAY_BITS ldr r0, = BOOT_WAY_BITS
ldr r1, = SSCOQWN ldr r1, = UNIPHIER_SSCOQWN
str r0, [r1] str r0, [r1]
ldr r1, = SSCOPPQSEF ldr r1, = UNIPHIER_SSCOPPQSEF
ldr r0, [r1] ldr r0, [r1]
cmp r0, #0 @ check if the command is successfully set cmp r0, #0 @ check if the command is successfully set
bne 0b @ try again if an error occurs bne 0b @ try again if an error occurs
ldr r1, = SSCOLPQS ldr r1, = UNIPHIER_SSCOLPQS
1: 1:
ldr r0, [r1] ldr r0, [r1]
cmp r0, #0x4 cmp r0, #0x4
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
* UniPhier System Cache (L2 Cache) registers * UniPhier System Cache (L2 Cache) registers
* *
* Copyright (C) 2011-2014 Panasonic Corporation * Copyright (C) 2011-2014 Panasonic Corporation
* Copyright (C) 2016 Socionext Inc.
* *
* SPDX-License-Identifier: GPL-2.0+ * SPDX-License-Identifier: GPL-2.0+
*/ */
...@@ -9,57 +10,59 @@ ...@@ -9,57 +10,59 @@
#ifndef ARCH_SSC_REGS_H #ifndef ARCH_SSC_REGS_H
#define ARCH_SSC_REGS_H #define ARCH_SSC_REGS_H
#define SSCC 0x500c0000 /* control registers */
#define SSCC_BST (0x1 << 20) #define UNIPHIER_SSCC 0x500c0000 /* Control Register */
#define SSCC_ACT (0x1 << 19) #define UNIPHIER_SSCC_BST (0x1 << 20) /* UCWG burst read */
#define SSCC_WTG (0x1 << 18) #define UNIPHIER_SSCC_ACT (0x1 << 19) /* Inst-Data separate */
#define SSCC_PRD (0x1 << 17) #define UNIPHIER_SSCC_WTG (0x1 << 18) /* WT gathering on */
#define SSCC_WBWA (0x1 << 16) #define UNIPHIER_SSCC_PRD (0x1 << 17) /* enable pre-fetch */
#define SSCC_EX (0x1 << 13) #define UNIPHIER_SSCC_ON (0x1 << 0) /* enable cache */
#define SSCC_ON (0x1 << 0) #define UNIPHIER_SSCLPDAWCR 0x500c0030 /* Unified/Data Active Way Control */
#define UNIPHIER_SSCLPIAWCR 0x500c0034 /* Instruction Active Way Control */
#define SSCLPDAWCR 0x500c0030 /* revision registers */
#define UNIPHIER_SSCID 0x503c0100 /* ID Register */
#define SSCOPE 0x506c0244 /* operation registers */
#define SSCOPE_CM_SYNC 0x00000008 #define UNIPHIER_SSCOPE 0x506c0244 /* Cache Operation Primitive Entry */
#define UNIPHIER_SSCOPE_CM_INV 0x0 /* invalidate */
#define UNIPHIER_SSCOPE_CM_CLEAN 0x1 /* clean */
#define UNIPHIER_SSCOPE_CM_FLUSH 0x2 /* flush */
#define UNIPHIER_SSCOPE_CM_SYNC 0x8 /* sync (drain bufs) */
#define UNIPHIER_SSCOPE_CM_FLUSH_PREFETCH 0x9 /* flush p-fetch buf */
#define UNIPHIER_SSCOQM 0x506c0248
#define UNIPHIER_SSCOQM_TID_MASK (0x3 << 21)
#define UNIPHIER_SSCOQM_TID_LRU_DATA (0x0 << 21)
#define UNIPHIER_SSCOQM_TID_LRU_INST (0x1 << 21)
#define UNIPHIER_SSCOQM_TID_WAY (0x2 << 21)
#define UNIPHIER_SSCOQM_S_MASK (0x3 << 17)
#define UNIPHIER_SSCOQM_S_RANGE (0x0 << 17)
#define UNIPHIER_SSCOQM_S_ALL (0x1 << 17)
#define UNIPHIER_SSCOQM_S_WAY (0x2 << 17)
#define UNIPHIER_SSCOQM_CE (0x1 << 15) /* notify completion */
#define UNIPHIER_SSCOQM_CW (0x1 << 14)
#define UNIPHIER_SSCOQM_CM_MASK (0x7)
#define UNIPHIER_SSCOQM_CM_INV 0x0 /* invalidate */
#define UNIPHIER_SSCOQM_CM_CLEAN 0x1 /* clean */
#define UNIPHIER_SSCOQM_CM_FLUSH 0x2 /* flush */
#define UNIPHIER_SSCOQM_CM_PREFETCH 0x3 /* prefetch to cache */
#define UNIPHIER_SSCOQM_CM_PREFETCH_BUF 0x4 /* prefetch to pf-buf */
#define UNIPHIER_SSCOQM_CM_TOUCH 0x5 /* touch */
#define UNIPHIER_SSCOQM_CM_TOUCH_ZERO 0x6 /* touch to zero */
#define UNIPHIER_SSCOQM_CM_TOUCH_DIRTY 0x7 /* touch with dirty */
#define UNIPHIER_SSCOQAD 0x506c024c /* Cache Operation Queue Address */
#define UNIPHIER_SSCOQSZ 0x506c0250 /* Cache Operation Queue Size */
#define UNIPHIER_SSCOQMASK 0x506c0254 /* Cache Operation Queue Address Mask */
#define UNIPHIER_SSCOQWN 0x506c0258 /* Cache Operation Queue Way Number */
#define UNIPHIER_SSCOPPQSEF 0x506c025c /* Cache Operation Queue Set Complete */
#define UNIPHIER_SSCOPPQSEF_FE (0x1 << 1)
#define UNIPHIER_SSCOPPQSEF_OE (0x1 << 0)
#define UNIPHIER_SSCOLPQS 0x506c0260 /* Cache Operation Queue Status */
#define UNIPHIER_SSCOLPQS_EF (0x1 << 2)
#define UNIPHIER_SSCOLPQS_EST (0x1 << 1)
#define UNIPHIER_SSCOLPQS_QST (0x1 << 0)
#define SSCOQM 0x506c0248 #define UNIPHIER_SSC_LINE_SIZE 128
#define SSCOQM_TID_MASK (0x3 << 21) #define UNIPHIER_SSC_RANGE_OP_MAX_SIZE (0x00400000 - (UNIPHIER_SSC_LINE_SIZE))
#define SSCOQM_TID_BY_WAY (0x2 << 21)
#define SSCOQM_TID_BY_INST_WAY (0x1 << 21)
#define SSCOQM_TID_BY_DATA_WAY (0x0 << 21)
#define SSCOQM_S_MASK (0x3 << 17)
#define SSCOQM_S_WAY (0x2 << 17)
#define SSCOQM_S_ALL (0x1 << 17)
#define SSCOQM_S_ADDRESS (0x0 << 17)
#define SSCOQM_CE (0x1 << 15)
#define SSCOQM_CW (0x1 << 14)
#define SSCOQM_CM_MASK (0x7)
#define SSCOQM_CM_DIRT_TOUCH (0x7)
#define SSCOQM_CM_ZERO_TOUCH (0x6)
#define SSCOQM_CM_NORM_TOUCH (0x5)
#define SSCOQM_CM_PREF_FETCH (0x4)
#define SSCOQM_CM_SSC_FETCH (0x3)
#define SSCOQM_CM_WB_INV (0x2)
#define SSCOQM_CM_WB (0x1)
#define SSCOQM_CM_INV (0x0)
#define SSCOQAD 0x506c024c
#define SSCOQSZ 0x506c0250
#define SSCOQWN 0x506c0258
#define SSCOPPQSEF 0x506c025c
#define SSCOPPQSEF_FE (0x1 << 1)
#define SSCOPPQSEF_OE (0x1 << 0)
#define SSCOLPQS 0x506c0260
#define SSCOLPQS_EF (0x1 << 2)
#define SSCOLPQS_EST (0x1 << 1)
#define SSCOLPQS_QST (0x1 << 0)
#define SSCOQCE0 0x506c0270
#define SSC_LINE_SIZE 128
#define SSC_RANGE_OP_MAX_SIZE (0x00400000 - (SSC_LINE_SIZE))
#endif /* ARCH_SSC_REGS_H */ #endif /* ARCH_SSC_REGS_H */
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment