Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
8ef418c7
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
8ef418c7
编写于
3月 18, 2014
作者:
R
Russell King
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ARM: l2c: trial at enabling some Cortex-A9 optimisations
Signed-off-by:
N
Russell King
<
rmk+kernel@arm.linux.org.uk
>
上级
560be613
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
78 addition
and
3 deletion
+78
-3
arch/arm/include/asm/hardware/cache-l2x0.h
arch/arm/include/asm/hardware/cache-l2x0.h
+8
-0
arch/arm/mm/cache-l2x0.c
arch/arm/mm/cache-l2x0.c
+70
-3
未找到文件。
arch/arm/include/asm/hardware/cache-l2x0.h
浏览文件 @
8ef418c7
...
...
@@ -134,6 +134,14 @@
#define L310_ADDR_FILTER_EN 1
#define L310_PREFETCH_CTRL_OFFSET_MASK 0x1f
#define L310_PREFETCH_CTRL_DBL_LINEFILL_INCR BIT(23)
#define L310_PREFETCH_CTRL_PREFETCH_DROP BIT(24)
#define L310_PREFETCH_CTRL_DBL_LINEFILL_WRAP BIT(27)
#define L310_PREFETCH_CTRL_DATA_PREFETCH BIT(28)
#define L310_PREFETCH_CTRL_INSTR_PREFETCH BIT(29)
#define L310_PREFETCH_CTRL_DBL_LINEFILL BIT(30)
#define L2X0_CTRL_EN 1
#define L2X0_WAY_SIZE_SHIFT 3
...
...
arch/arm/mm/cache-l2x0.c
浏览文件 @
8ef418c7
...
...
@@ -16,14 +16,17 @@
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#include <linux/cpu.h>
#include <linux/err.h>
#include <linux/init.h>
#include <linux/smp.h>
#include <linux/spinlock.h>
#include <linux/io.h>
#include <linux/of.h>
#include <linux/of_address.h>
#include <asm/cacheflush.h>
#include <asm/cp15.h>
#include <asm/cputype.h>
#include <asm/hardware/cache-l2x0.h>
#include "cache-tauros3.h"
...
...
@@ -639,7 +642,24 @@ static void l2c310_resume(void)
L310_POWER_CTRL
);
l2c_enable
(
base
,
l2x0_saved_regs
.
aux_ctrl
,
8
);
/* Re-enable full-line-of-zeros for Cortex-A9 */
if
(
l2x0_saved_regs
.
aux_ctrl
&
L310_AUX_CTRL_FULL_LINE_ZERO
)
set_auxcr
(
get_auxcr
()
|
BIT
(
3
)
|
BIT
(
2
)
|
BIT
(
1
));
}
}
static
int
l2c310_cpu_enable_flz
(
struct
notifier_block
*
nb
,
unsigned
long
act
,
void
*
data
)
{
switch
(
act
&
~
CPU_TASKS_FROZEN
)
{
case
CPU_STARTING
:
set_auxcr
(
get_auxcr
()
|
BIT
(
3
)
|
BIT
(
2
)
|
BIT
(
1
));
break
;
case
CPU_DYING
:
set_auxcr
(
get_auxcr
()
&
~
(
BIT
(
3
)
|
BIT
(
2
)
|
BIT
(
1
)));
break
;
}
return
NOTIFY_OK
;
}
static
void
__init
l2c310_enable
(
void
__iomem
*
base
,
u32
aux
,
unsigned
num_lock
)
...
...
@@ -657,6 +677,36 @@ static void __init l2c310_enable(void __iomem *base, u32 aux, unsigned num_lock)
}
}
if
(
cortex_a9
)
{
u32
aux_cur
=
readl_relaxed
(
base
+
L2X0_AUX_CTRL
);
u32
acr
=
get_auxcr
();
pr_debug
(
"Cortex-A9 ACR=0x%08x
\n
"
,
acr
);
if
(
acr
&
BIT
(
3
)
&&
!
(
aux_cur
&
L310_AUX_CTRL_FULL_LINE_ZERO
))
pr_err
(
"L2C-310: full line of zeros enabled in Cortex-A9 but not L2C-310 - invalid
\n
"
);
if
(
aux
&
L310_AUX_CTRL_FULL_LINE_ZERO
&&
!
(
acr
&
BIT
(
3
)))
pr_err
(
"L2C-310: enabling full line of zeros but not enabled in Cortex-A9
\n
"
);
if
(
!
(
aux
&
L310_AUX_CTRL_FULL_LINE_ZERO
)
&&
!
outer_cache
.
write_sec
)
{
aux
|=
L310_AUX_CTRL_FULL_LINE_ZERO
;
pr_info
(
"L2C-310 full line of zeros enabled for Cortex-A9
\n
"
);
}
}
else
if
(
aux
&
(
L310_AUX_CTRL_FULL_LINE_ZERO
|
L310_AUX_CTRL_EARLY_BRESP
))
{
pr_err
(
"L2C-310: disabling Cortex-A9 specific feature bits
\n
"
);
aux
&=
~
(
L310_AUX_CTRL_FULL_LINE_ZERO
|
L310_AUX_CTRL_EARLY_BRESP
);
}
if
(
aux
&
(
L310_AUX_CTRL_DATA_PREFETCH
|
L310_AUX_CTRL_INSTR_PREFETCH
))
{
u32
prefetch
=
readl_relaxed
(
base
+
L310_PREFETCH_CTRL
);
pr_info
(
"L2C-310 %s%s prefetch enabled, offset %u lines
\n
"
,
aux
&
L310_AUX_CTRL_INSTR_PREFETCH
?
"I"
:
""
,
aux
&
L310_AUX_CTRL_DATA_PREFETCH
?
"D"
:
""
,
1
+
(
prefetch
&
L310_PREFETCH_CTRL_OFFSET_MASK
));
}
/* r3p0 or later has power control register */
if
(
rev
>=
L310_CACHE_ID_RTL_R3P0
)
{
u32
power_ctrl
;
...
...
@@ -677,6 +727,11 @@ static void __init l2c310_enable(void __iomem *base, u32 aux, unsigned num_lock)
aux
|=
L310_AUX_CTRL_NS_LOCKDOWN
;
l2c_enable
(
base
,
aux
,
num_lock
);
if
(
aux
&
L310_AUX_CTRL_FULL_LINE_ZERO
)
{
set_auxcr
(
get_auxcr
()
|
BIT
(
3
)
|
BIT
(
2
)
|
BIT
(
1
));
cpu_notifier
(
l2c310_cpu_enable_flz
,
0
);
}
}
static
void
__init
l2c310_fixup
(
void
__iomem
*
base
,
u32
cache_id
,
...
...
@@ -732,6 +787,18 @@ static void __init l2c310_fixup(void __iomem *base, u32 cache_id,
}
}
static
void
l2c310_disable
(
void
)
{
/*
* If full-line-of-zeros is enabled, we must first disable it in the
* Cortex-A9 auxiliary control register before disabling the L2 cache.
*/
if
(
l2x0_saved_regs
.
aux_ctrl
&
L310_AUX_CTRL_FULL_LINE_ZERO
)
set_auxcr
(
get_auxcr
()
&
~
(
BIT
(
3
)
|
BIT
(
2
)
|
BIT
(
1
)));
l2c_disable
();
}
static
const
struct
l2c_init_data
l2c310_init_fns
__initconst
=
{
.
type
=
"L2C-310"
,
.
way_size_0
=
SZ_8K
,
...
...
@@ -744,7 +811,7 @@ static const struct l2c_init_data l2c310_init_fns __initconst = {
.
clean_range
=
l2c210_clean_range
,
.
flush_range
=
l2c210_flush_range
,
.
flush_all
=
l2c210_flush_all
,
.
disable
=
l2c_disable
,
.
disable
=
l2c
310
_disable
,
.
sync
=
l2c210_sync
,
.
resume
=
l2c310_resume
,
},
...
...
@@ -995,7 +1062,7 @@ static const struct l2c_init_data of_l2c310_data __initconst = {
.
clean_range
=
l2c210_clean_range
,
.
flush_range
=
l2c210_flush_range
,
.
flush_all
=
l2c210_flush_all
,
.
disable
=
l2c_disable
,
.
disable
=
l2c
310
_disable
,
.
sync
=
l2c210_sync
,
.
resume
=
l2c310_resume
,
},
...
...
@@ -1342,7 +1409,7 @@ static const struct l2c_init_data of_bcm_l2x0_data __initconst = {
.
clean_range
=
bcm_clean_range
,
.
flush_range
=
bcm_flush_range
,
.
flush_all
=
l2c210_flush_all
,
.
disable
=
l2c_disable
,
.
disable
=
l2c
310
_disable
,
.
sync
=
l2c210_sync
,
.
resume
=
l2c310_resume
,
},
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录