Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
2cf6b32d
提交
2cf6b32d
8月 05, 2010
创建
作者:
Robert Morris
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
move jkstack to main.c
replace jstack with asm()s
上级
eb18645f
隐藏空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
17 行增加
和
28 行删除
+17
-28
defs.h
defs.h
+0
-2
main.c
main.c
+16
-6
runoff.list
runoff.list
+1
-0
sh.c
sh.c
+0
-1
swtch.S
swtch.S
+0
-8
vm.c
vm.c
+0
-11
没有找到文件。
defs.h
浏览文件 @
2cf6b32d
...
...
@@ -110,7 +110,6 @@ void yield(void);
// swtch.S
void
swtch
(
struct
context
**
,
struct
context
*
);
void
jstack
(
uint
);
// spinlock.c
void
acquire
(
struct
spinlock
*
);
...
...
@@ -157,7 +156,6 @@ void pminit(void);
void
ksegment
(
void
);
void
kvmalloc
(
void
);
void
vminit
(
void
);
void
jkstack
();
void
printstack
(
void
);
void
printpgdir
(
pde_t
*
);
pde_t
*
setupkvm
(
void
);
...
...
main.c
浏览文件 @
2cf6b32d
...
...
@@ -7,7 +7,8 @@
static
void
bootothers
(
void
);
static
void
mpmain
(
void
);
void
jkstack
(
void
)
__attribute__
((
noreturn
));
void
jkstack
(
void
)
__attribute__
((
noreturn
));
void
mainc
(
void
);
// Bootstrap processor starts running C code here.
int
...
...
@@ -21,13 +22,24 @@ main(void)
consoleinit
();
// I/O devices & their interrupts
uartinit
();
// serial port
pminit
();
// physical memory for kernel
jkstack
();
// Jump to mainc on a proper-allocated kernel stack
jkstack
();
// Jump to mainc on a properly-allocated stack
}
void
jkstack
(
void
)
{
char
*
kstack
=
kalloc
(
PGSIZE
);
if
(
!
kstack
)
panic
(
"jkstack
\n
"
);
char
*
top
=
kstack
+
PGSIZE
;
asm
volatile
(
"movl %0,%%esp"
:
:
"r"
(
top
));
asm
volatile
(
"call mainc"
);
panic
(
"jkstack"
);
}
void
mainc
(
void
)
{
cprintf
(
"cpus %p cpu %p
\n
"
,
cpus
,
cpu
);
cprintf
(
"
\n
cpu%d: starting xv6
\n\n
"
,
cpu
->
id
);
kvmalloc
();
// allocate the kernel page table
pinit
();
// process table
...
...
@@ -52,14 +64,12 @@ mpmain(void)
{
if
(
cpunum
()
!=
mpbcpu
())
{
ksegment
();
cprintf
(
"other cpu
\n
"
);
lapicinit
(
cpunum
());
}
vminit
();
// Run with paging on each processor
cprintf
(
"cpu%d:
mpmain
\n
"
,
cpu
->
id
);
cprintf
(
"cpu%d:
starting
\n
"
,
cpu
->
id
);
idtinit
();
xchg
(
&
cpu
->
booted
,
1
);
cprintf
(
"cpu%d: scheduling
\n
"
,
cpu
->
id
);
scheduler
();
}
...
...
runoff.list
浏览文件 @
2cf6b32d
...
...
@@ -22,6 +22,7 @@ proc.h
proc.c
swtch.S
kalloc.c
vm.c
# system calls
traps.h
...
...
sh.c
浏览文件 @
2cf6b32d
...
...
@@ -420,7 +420,6 @@ parseexec(char **ps, char *es)
int
tok
,
argc
;
struct
execcmd
*
cmd
;
struct
cmd
*
ret
;
int
*
x
=
(
int
*
)
peek
;
if
(
peek
(
ps
,
es
,
"("
))
return
parseblock
(
ps
,
es
);
...
...
swtch.S
浏览文件 @
2cf6b32d
...
...
@@ -26,11 +26,3 @@ swtch:
popl %ebx
popl %ebp
ret
# Jump on a new stack, fake C calling conventions
.globl jstack
jstack:
movl 4(%esp), %esp
subl $16, %esp # space for arguments
movl $0, %ebp # terminate functions that follow ebp's
call mainc # continue at mainc
vm.c
浏览文件 @
2cf6b32d
...
...
@@ -324,17 +324,6 @@ pminit(void)
kinit
((
char
*
)
kernend
,
freesz
);
}
// Jump to mainc on a properly-allocated kernel stack
void
jkstack
(
void
)
{
char
*
kstack
=
kalloc
(
PGSIZE
);
if
(
!
kstack
)
panic
(
"jkstack
\n
"
);
char
*
top
=
kstack
+
PGSIZE
;
jstack
((
uint
)
top
);
}
// Allocate one page table for the machine for the kernel address
// space for scheduler processes.
void
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论