Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
538f8e5d
X
XiangShan
项目概览
OpenXiangShan
/
XiangShan
12 个月 前同步成功
通知
1183
Star
3914
Fork
526
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
X
XiangShan
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
538f8e5d
编写于
12月 22, 2020
作者:
A
Allen
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of github.com:RISCVERS/XiangShan
上级
a4433ff7
7b4d29be
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
11 addition
and
7 deletion
+11
-7
.github/workflows/emu.yml
.github/workflows/emu.yml
+1
-1
debug/cputest.sh
debug/cputest.sh
+2
-2
src/test/csrc/emu.h
src/test/csrc/emu.h
+4
-3
src/test/csrc/main.cpp
src/test/csrc/main.cpp
+3
-1
src/test/csrc/ram.h
src/test/csrc/ram.h
+1
-0
未找到文件。
.github/workflows/emu.yml
浏览文件 @
538f8e5d
...
...
@@ -36,7 +36,7 @@ jobs:
t=${test%.c}
echo $t
make -C $CPU_TEST_DIR ALL=$t ARCH=riscv64-noop AM_HOME=$AM_HOME NEMU_HOME=$NEMU_HOME NOOP_HOME=$NOOP_HOME run 2>/dev/null | grep "HIT GOOD TRAP"
if [[ $?
== 1
]];
if [[ $?
!= 0
]];
then
echo $t fail
ret=1
...
...
debug/cputest.sh
浏览文件 @
538f8e5d
...
...
@@ -7,8 +7,8 @@ do
t
=
${
test
%.c
}
echo
-n
-e
"
\x
1b[0m
$t
: "
make
-C
$TEST_HOME
ARCH
=
riscv64-noop
E
=
0
ALL
=
$t
run 2>/dev/null |
grep
-E
"HIT GOOD TRAP|IPC"
if
[[
$?
==
1
]]
;
if
[[
$?
!=
0
]]
;
then
echo
-e
"
\x
1b[31mfail"
echo
-e
"
\x
1b[31mfail
: trap code
$?
"
fi
done
src/test/csrc/emu.h
浏览文件 @
538f8e5d
...
...
@@ -40,9 +40,9 @@ class Emulator {
enum
{
STATE_GOODTRAP
=
0
,
STATE_BADTRAP
,
STATE_ABORT
,
STATE_LIMIT_EXCEEDED
,
STATE_BADTRAP
=
1
,
STATE_ABORT
=
2
,
STATE_LIMIT_EXCEEDED
=
3
,
STATE_RUNNING
=
-
1
};
...
...
@@ -74,4 +74,5 @@ public:
uint64_t
get_cycles
()
const
{
return
cycles
;
}
EmuArgs
get_args
()
const
{
return
args
;
}
bool
is_good_trap
()
{
return
trapCode
==
STATE_GOODTRAP
;
};
int
get_trapcode
()
{
return
trapCode
;
}
};
src/test/csrc/main.cpp
浏览文件 @
538f8e5d
...
...
@@ -21,6 +21,7 @@ int main(int argc, const char** argv) {
auto
args
=
emu
->
get_args
();
uint64_t
cycles
=
emu
->
execute
(
args
.
max_cycles
,
args
.
max_instr
);
bool
is_good_trap
=
emu
->
is_good_trap
();
int
trapcode
=
emu
->
get_trapcode
();
delete
emu
;
extern
uint32_t
uptime
(
void
);
...
...
@@ -30,5 +31,6 @@ int main(int argc, const char** argv) {
" (this will be different from cycleCnt if emu loads a snapshot)
\n
"
ANSI_COLOR_RESET
,
args
.
seed
,
cycles
);
eprintf
(
ANSI_COLOR_BLUE
"Host time spent: %dms
\n
"
ANSI_COLOR_RESET
,
ms
);
return
!
is_good_trap
;
// return !is_good_trap;
return
trapcode
;
}
src/test/csrc/ram.h
浏览文件 @
538f8e5d
...
...
@@ -4,6 +4,7 @@
#include "common.h"
#define EMU_RAM_SIZE (256 * 1024 * 1024UL)
// #define EMU_RAM_SIZE (8 * 1024 * 1024 * 1024UL)
void
init_ram
(
const
char
*
img
);
void
ram_finish
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录