Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
2a29ca73
Q
qemu
项目概览
openeuler
/
qemu
通知
10
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Q
qemu
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
2a29ca73
编写于
5月 13, 2003
作者:
B
bellard
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more exception tests
git-svn-id:
svn://svn.savannah.nongnu.org/qemu/trunk@159
c046a42c-6fe2-441c-8c8c-71466251a162
上级
54936004
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
3 deletion
+19
-3
tests/testsig.c
tests/testsig.c
+19
-3
未找到文件。
tests/testsig.c
浏览文件 @
2a29ca73
...
@@ -67,7 +67,7 @@ int tab[2];
...
@@ -67,7 +67,7 @@ int tab[2];
int
main
(
int
argc
,
char
**
argv
)
int
main
(
int
argc
,
char
**
argv
)
{
{
struct
sigaction
act
;
struct
sigaction
act
;
int
val
;
volatile
int
val
;
act
.
sa_sigaction
=
sig_handler
;
act
.
sa_sigaction
=
sig_handler
;
sigemptyset
(
&
act
.
sa_mask
);
sigemptyset
(
&
act
.
sa_mask
);
...
@@ -75,6 +75,7 @@ int main(int argc, char **argv)
...
@@ -75,6 +75,7 @@ int main(int argc, char **argv)
sigaction
(
SIGFPE
,
&
act
,
NULL
);
sigaction
(
SIGFPE
,
&
act
,
NULL
);
sigaction
(
SIGILL
,
&
act
,
NULL
);
sigaction
(
SIGILL
,
&
act
,
NULL
);
sigaction
(
SIGSEGV
,
&
act
,
NULL
);
sigaction
(
SIGSEGV
,
&
act
,
NULL
);
sigaction
(
SIGTRAP
,
&
act
,
NULL
);
/* test division by zero reporting */
/* test division by zero reporting */
if
(
setjmp
(
jmp_env
)
==
0
)
{
if
(
setjmp
(
jmp_env
)
==
0
)
{
...
@@ -112,6 +113,11 @@ int main(int argc, char **argv)
...
@@ -112,6 +113,11 @@ int main(int argc, char **argv)
asm
volatile
(
"int $0xfd"
);
asm
volatile
(
"int $0xfd"
);
}
}
printf
(
"INT3 exception:
\n
"
);
if
(
setjmp
(
jmp_env
)
==
0
)
{
asm
volatile
(
"int3"
);
}
printf
(
"CLI exception:
\n
"
);
printf
(
"CLI exception:
\n
"
);
if
(
setjmp
(
jmp_env
)
==
0
)
{
if
(
setjmp
(
jmp_env
)
==
0
)
{
asm
volatile
(
"cli"
);
asm
volatile
(
"cli"
);
...
@@ -158,10 +164,20 @@ int main(int argc, char **argv)
...
@@ -158,10 +164,20 @@ int main(int argc, char **argv)
printf
(
"HLT exception:
\n
"
);
printf
(
"HLT exception:
\n
"
);
if
(
setjmp
(
jmp_env
)
==
0
)
{
if
(
setjmp
(
jmp_env
)
==
0
)
{
asm
volatile
(
"hlt"
:
:
"d"
(
0x4321
),
"D"
(
tab
),
"c"
(
1
)
);
asm
volatile
(
"hlt"
);
}
}
#if 0
printf
(
"single step exception:
\n
"
);
val
=
0
;
if
(
setjmp
(
jmp_env
)
==
0
)
{
asm
volatile
(
"pushf
\n
"
"orl $0x00100, (%%esp)
\n
"
"popf
\n
"
"movl $0xabcd, %0
\n
"
:
"=m"
(
val
)
:
:
"cc"
,
"memory"
);
}
printf
(
"val=0x%x
\n
"
,
val
);
#if 1
{
{
int
i
;
int
i
;
act
.
sa_handler
=
alarm_handler
;
act
.
sa_handler
=
alarm_handler
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录