Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OS
U-Boot.Mirror
提交
6956d53d
U
U-Boot.Mirror
项目概览
OS
/
U-Boot.Mirror
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
U-Boot.Mirror
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
6956d53d
编写于
5月 13, 2008
作者:
S
Sascha Laue
提交者:
Wolfgang Denk
6月 03, 2008
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
lwmon5: add memory-pattern-test to FPGA POST.
上级
e34a0e91
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
50 addition
and
0 deletion
+50
-0
post/board/lwmon5/fpga.c
post/board/lwmon5/fpga.c
+50
-0
未找到文件。
post/board/lwmon5/fpga.c
浏览文件 @
6956d53d
...
...
@@ -41,6 +41,15 @@ DECLARE_GLOBAL_DATA_PTR;
#if CONFIG_POST & CFG_POST_BSPEC3
/* Testpattern for fpga memorytest */
static
uint
pattern
[]
=
{
0x55555555
,
0xAAAAAAAA
,
0xAA5555AA
,
0x55AAAA55
,
0x0
};
static
int
one_scratch_test
(
uint
value
)
{
uint
read_value
;
...
...
@@ -60,9 +69,42 @@ static int one_scratch_test(uint value)
return
ret
;
}
/* FPGA Memory-pattern-test */
static
int
fpga_mem_test
(
void
*
address
)
{
int
ret
=
1
;
uint
read_value
;
uint
old_value
;
uint
i
=
0
;
/* save content */
old_value
=
in_be32
(
address
);
while
(
pattern
[
i
]
!=
0
)
{
out_be32
(
address
,
pattern
[
i
]);
/* read other location (protect against data lines capacity) */
ret
=
in_be16
((
void
*
)
FPGA_VERSION_REG
);
/* verify test pattern */
read_value
=
in_be32
(
address
);
if
(
read_value
!=
pattern
[
i
])
{
post_log
(
"FPGA Memory test failed."
);
post_log
(
" write %08X, read %08X at address %08X
\n
"
,
pattern
[
i
],
read_value
,
address
);
ret
=
1
;
goto
out
;
}
i
++
;
}
ret
=
0
;
out:
out_be32
(
address
,
old_value
);
return
ret
;
}
/* Verify FPGA, get version & memory size */
int
fpga_post_test
(
int
flags
)
{
uint
address
;
uint
old_value
;
ushort
version
;
uint
read_value
;
...
...
@@ -88,6 +130,14 @@ int fpga_post_test(int flags)
read_value
=
get_ram_size
((
void
*
)
CFG_FPGA_BASE_1
,
0x4000
);
post_log
(
"FPGA RAM size: %d bytes
\n
"
,
read_value
);
for
(
address
=
0
;
address
<
0x1000
;
address
++
)
{
if
(
fpga_mem_test
((
void
*
)(
FPGA_RAM_START
+
4
*
address
))
==
1
)
{
ret
=
1
;
goto
out
;
}
}
out:
return
ret
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录