Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
996dfe98
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看板
提交
996dfe98
编写于
6月 23, 2014
作者:
M
Max Filippov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
hw/xtensa/xtfpga: implement DTB loading
Signed-off-by:
N
Max Filippov
<
jcmvbkbc@gmail.com
>
上级
364d4802
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
23 addition
and
0 deletion
+23
-0
hw/xtensa/xtfpga.c
hw/xtensa/xtfpga.c
+23
-0
未找到文件。
hw/xtensa/xtfpga.c
浏览文件 @
996dfe98
...
...
@@ -37,6 +37,7 @@
#include "hw/block/flash.h"
#include "sysemu/blockdev.h"
#include "sysemu/char.h"
#include "sysemu/device_tree.h"
#include "qemu/error-report.h"
#include "bootparam.h"
...
...
@@ -178,6 +179,7 @@ static void lx_init(const LxBoardDesc *board, MachineState *machine)
const
char
*
cpu_model
=
machine
->
cpu_model
;
const
char
*
kernel_filename
=
qemu_opt_get
(
machine_opts
,
"kernel"
);
const
char
*
kernel_cmdline
=
qemu_opt_get
(
machine_opts
,
"append"
);
const
char
*
dtb_filename
=
qemu_opt_get
(
machine_opts
,
"dtb"
);
int
n
;
if
(
!
cpu_model
)
{
...
...
@@ -246,6 +248,9 @@ static void lx_init(const LxBoardDesc *board, MachineState *machine)
.
start
=
tswap32
(
0
),
.
end
=
tswap32
(
machine
->
ram_size
),
};
uint32_t
lowmem_end
=
machine
->
ram_size
<
0x08000000
?
machine
->
ram_size
:
0x08000000
;
uint32_t
cur_lowmem
=
QEMU_ALIGN_UP
(
lowmem_end
/
2
,
4096
);
rom
=
g_malloc
(
sizeof
(
*
rom
));
memory_region_init_ram
(
rom
,
NULL
,
"lx60.sram"
,
board
->
sram_size
);
...
...
@@ -255,6 +260,9 @@ static void lx_init(const LxBoardDesc *board, MachineState *machine)
if
(
kernel_cmdline
)
{
bp_size
+=
get_tag_size
(
strlen
(
kernel_cmdline
)
+
1
);
}
if
(
dtb_filename
)
{
bp_size
+=
get_tag_size
(
sizeof
(
uint32_t
));
}
/* Put kernel bootparameters to the end of that SRAM */
tagptr
=
(
tagptr
-
bp_size
)
&
~
0xff
;
...
...
@@ -266,6 +274,21 @@ static void lx_init(const LxBoardDesc *board, MachineState *machine)
cur_tagptr
=
put_tag
(
cur_tagptr
,
BP_TAG_COMMAND_LINE
,
strlen
(
kernel_cmdline
)
+
1
,
kernel_cmdline
);
}
if
(
dtb_filename
)
{
int
fdt_size
;
void
*
fdt
=
load_device_tree
(
dtb_filename
,
&
fdt_size
);
uint32_t
dtb_addr
=
tswap32
(
cur_lowmem
);
if
(
!
fdt
)
{
error_report
(
"could not load DTB '%s'
\n
"
,
dtb_filename
);
exit
(
EXIT_FAILURE
);
}
cpu_physical_memory_write
(
cur_lowmem
,
fdt
,
fdt_size
);
cur_tagptr
=
put_tag
(
cur_tagptr
,
BP_TAG_FDT
,
sizeof
(
dtb_addr
),
&
dtb_addr
);
cur_lowmem
=
QEMU_ALIGN_UP
(
cur_lowmem
+
fdt_size
,
4096
);
}
cur_tagptr
=
put_tag
(
cur_tagptr
,
BP_TAG_LAST
,
0
,
NULL
);
env
->
regs
[
2
]
=
tagptr
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录