Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
49c29d6c
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看板
提交
49c29d6c
编写于
12月 28, 2017
作者:
R
Richard Henderson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
target/hppa: Implement the interval timer
Signed-off-by:
N
Richard Henderson
<
richard.henderson@linaro.org
>
上级
4f5f2548
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
67 addition
and
4 deletion
+67
-4
target/hppa/cpu.c
target/hppa/cpu.c
+8
-0
target/hppa/cpu.h
target/hppa/cpu.h
+2
-0
target/hppa/helper.h
target/hppa/helper.h
+3
-0
target/hppa/int_helper.c
target/hppa/int_helper.c
+6
-0
target/hppa/op_helper.c
target/hppa/op_helper.c
+36
-0
target/hppa/translate.c
target/hppa/translate.c
+12
-4
未找到文件。
target/hppa/cpu.c
浏览文件 @
49c29d6c
...
...
@@ -99,6 +99,14 @@ static void hppa_cpu_realizefn(DeviceState *dev, Error **errp)
qemu_init_vcpu
(
cs
);
acc
->
parent_realize
(
dev
,
errp
);
#ifndef CONFIG_USER_ONLY
{
HPPACPU
*
cpu
=
HPPA_CPU
(
cs
);
cpu
->
alarm_timer
=
timer_new_ns
(
QEMU_CLOCK_VIRTUAL
,
hppa_cpu_alarm_timer
,
cpu
);
}
#endif
}
/* Sort hppabetically by type name. */
...
...
target/hppa/cpu.h
浏览文件 @
49c29d6c
...
...
@@ -234,6 +234,7 @@ struct HPPACPU {
/*< public >*/
CPUHPPAState
env
;
QEMUTimer
*
alarm_timer
;
};
static
inline
HPPACPU
*
hppa_env_get_cpu
(
CPUHPPAState
*
env
)
...
...
@@ -342,6 +343,7 @@ int hppa_cpu_handle_mmu_fault(CPUState *cpu, vaddr address, int size,
int
hppa_get_physical_address
(
CPUHPPAState
*
env
,
vaddr
addr
,
int
mmu_idx
,
int
type
,
hwaddr
*
pphys
,
int
*
pprot
);
extern
const
MemoryRegionOps
hppa_io_eir_ops
;
void
hppa_cpu_alarm_timer
(
void
*
);
#endif
#endif
/* HPPA_CPU_H */
target/hppa/helper.h
浏览文件 @
49c29d6c
...
...
@@ -77,9 +77,12 @@ DEF_HELPER_FLAGS_4(fmpynfadd_s, TCG_CALL_NO_RWG, i32, env, i32, i32, i32)
DEF_HELPER_FLAGS_4
(
fmpyfadd_d
,
TCG_CALL_NO_RWG
,
i64
,
env
,
i64
,
i64
,
i64
)
DEF_HELPER_FLAGS_4
(
fmpynfadd_d
,
TCG_CALL_NO_RWG
,
i64
,
env
,
i64
,
i64
,
i64
)
DEF_HELPER_FLAGS_0
(
read_interval_timer
,
TCG_CALL_NO_RWG
,
tr
)
#ifndef CONFIG_USER_ONLY
DEF_HELPER_1
(
rfi
,
void
,
env
)
DEF_HELPER_1
(
rfi_r
,
void
,
env
)
DEF_HELPER_FLAGS_2
(
write_interval_timer
,
TCG_CALL_NO_RWG
,
void
,
env
,
tr
)
DEF_HELPER_FLAGS_2
(
write_eirr
,
TCG_CALL_NO_RWG
,
void
,
env
,
tr
)
DEF_HELPER_FLAGS_2
(
write_eiem
,
TCG_CALL_NO_RWG
,
void
,
env
,
tr
)
DEF_HELPER_FLAGS_2
(
swap_system_mask
,
TCG_CALL_NO_RWG
,
tr
,
env
,
tr
)
...
...
target/hppa/int_helper.c
浏览文件 @
49c29d6c
...
...
@@ -67,6 +67,12 @@ const MemoryRegionOps hppa_io_eir_ops = {
.
impl
.
max_access_size
=
4
,
};
void
hppa_cpu_alarm_timer
(
void
*
opaque
)
{
/* Raise interrupt 0. */
io_eir_write
(
opaque
,
0
,
0
,
4
);
}
void
HELPER
(
write_eirr
)(
CPUHPPAState
*
env
,
target_ureg
val
)
{
env
->
cr
[
CR_EIRR
]
&=
~
val
;
...
...
target/hppa/op_helper.c
浏览文件 @
49c29d6c
...
...
@@ -22,6 +22,8 @@
#include "exec/exec-all.h"
#include "exec/helper-proto.h"
#include "exec/cpu_ldst.h"
#include "qemu/timer.h"
void
QEMU_NORETURN
HELPER
(
excp
)(
CPUHPPAState
*
env
,
int
excp
)
{
...
...
@@ -602,7 +604,41 @@ float64 HELPER(fmpynfadd_d)(CPUHPPAState *env, float64 a, float64 b, float64 c)
return
ret
;
}
target_ureg
HELPER
(
read_interval_timer
)(
void
)
{
#ifdef CONFIG_USER_ONLY
/* In user-mode, QEMU_CLOCK_VIRTUAL doesn't exist.
Just pass through the host cpu clock ticks. */
return
cpu_get_host_ticks
();
#else
/* In system mode we have access to a decent high-resolution clock.
In order to make OS-level time accounting work with the cr16,
present it with a well-timed clock fixed at 250MHz. */
return
qemu_clock_get_ns
(
QEMU_CLOCK_VIRTUAL
)
>>
2
;
#endif
}
#ifndef CONFIG_USER_ONLY
void
HELPER
(
write_interval_timer
)(
CPUHPPAState
*
env
,
target_ureg
val
)
{
HPPACPU
*
cpu
=
hppa_env_get_cpu
(
env
);
uint64_t
current
=
qemu_clock_get_ns
(
QEMU_CLOCK_VIRTUAL
);
uint64_t
timeout
;
/* Even in 64-bit mode, the comparator is always 32-bit. But the
value we expose to the guest is 1/4 of the speed of the clock,
so moosh in 34 bits. */
timeout
=
deposit64
(
current
,
0
,
34
,
(
uint64_t
)
val
<<
2
);
/* If the mooshing puts the clock in the past, advance to next round. */
if
(
timeout
<
current
+
1000
)
{
timeout
+=
1ULL
<<
34
;
}
cpu
->
env
.
cr
[
CR_IT
]
=
timeout
;
timer_mod
(
cpu
->
alarm_timer
,
timeout
);
}
target_ureg
HELPER
(
swap_system_mask
)(
CPUHPPAState
*
env
,
target_ureg
nsm
)
{
target_ulong
psw
=
env
->
psw
;
...
...
target/hppa/translate.c
浏览文件 @
49c29d6c
...
...
@@ -2038,6 +2038,7 @@ static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,
unsigned
rt
=
extract32
(
insn
,
0
,
5
);
unsigned
ctl
=
extract32
(
insn
,
21
,
5
);
TCGv_reg
tmp
;
DisasJumpType
ret
;
switch
(
ctl
)
{
case
CR_SAR
:
...
...
@@ -2056,9 +2057,17 @@ static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,
/* FIXME: Respect PSW_S bit. */
nullify_over
(
ctx
);
tmp
=
dest_gpr
(
ctx
,
rt
);
tcg_gen_movi_reg
(
tmp
,
0
);
/* FIXME */
if
(
ctx
->
base
.
tb
->
cflags
&
CF_USE_ICOUNT
)
{
gen_io_start
();
gen_helper_read_interval_timer
(
tmp
);
gen_io_end
();
ret
=
DISAS_IAQ_N_STALE
;
}
else
{
gen_helper_read_interval_timer
(
tmp
);
ret
=
DISAS_NEXT
;
}
save_gpr
(
ctx
,
rt
,
tmp
);
break
;
return
nullify_end
(
ctx
,
ret
)
;
case
26
:
case
27
:
break
;
...
...
@@ -2132,9 +2141,8 @@ static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,
nullify_over
(
ctx
);
switch
(
ctl
)
{
case
CR_IT
:
/* ??? modify interval timer offset */
gen_helper_write_interval_timer
(
cpu_env
,
reg
);
break
;
case
CR_EIRR
:
gen_helper_write_eirr
(
cpu_env
,
reg
);
break
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录