Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
f56e01e3
提交
f56e01e3
12月 07, 2011
创建
作者:
Frans Kaashoek
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'scale-amd64' of
ssh://amsterdam.csail.mit.edu/home/am0/6.828/xv6
into scale-amd64
Conflicts: main.c
上级
0b085451
b3922680
显示空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
117 行增加
和
21 行删除
+117
-21
boot.S
boot.S
+5
-5
e820.h
e820.h
+0
-0
kalloc.c
kalloc.c
+107
-11
main.c
main.c
+5
-5
没有找到文件。
boot.S
浏览文件 @
f56e01e3
...
...
@@ -86,7 +86,7 @@ start32:
call initpagetables
call init32e
movl $PADDR(start64), %edi
movl $PADDR(start64), %eax
# Enter 64-bit mode.
ljmp $KCSEG, $PADDR(tramp64) // code64 segment selector
...
...
@@ -107,7 +107,7 @@ apstart:
apstart32:
call init32e
movl $PADDR(apstart64), %edi
movl $PADDR(apstart64), %eax
ljmp $KCSEG, $PADDR(tramp64) // code64 segment selector
.code64
...
...
@@ -124,11 +124,11 @@ apstart64:
tramp64:
# The linker thinks we are running at tramp64, but we're actually
# running at PADDR(tramp64), so use an explicit calculation to
# load and jump to the correct address. %r
di
should hold the
# load and jump to the correct address. %r
ax
should hold the
# physical address of the jmp target.
movq $KBASE, %r11
addq %r11, %r
di
jmp *%r
di
addq %r11, %r
ax
jmp *%r
ax
# Initial stack
.comm stack, STACK
...
...
e820.h
0 → 100644
浏览文件 @
f56e01e3
kalloc.c
浏览文件 @
f56e01e3
...
...
@@ -9,6 +9,11 @@
#include "kalloc.h"
#include "mtrace.h"
#include "cpu.h"
#include "multiboot.h"
static
struct
Mbmem
mem
[
128
];
static
u64
nmem
;
static
u64
membytes
;
struct
kmem
kmems
[
NCPU
];
struct
kmem
kstacks
[
NCPU
];
...
...
@@ -19,6 +24,77 @@ enum { kalloc_memset = 0 };
static
int
kinited
__mpalign__
;
static
struct
Mbmem
*
memsearch
(
paddr
pa
)
{
struct
Mbmem
*
e
;
struct
Mbmem
*
q
;
q
=
mem
+
nmem
;
for
(
e
=
&
mem
[
0
];
e
<
q
;
e
++
)
if
((
e
->
base
<=
pa
)
&&
((
e
->
base
+
e
->
length
)
>
pa
))
return
e
;
return
NULL
;
}
static
u64
memsize
(
void
*
va
)
{
struct
Mbmem
*
e
;
paddr
pa
=
v2p
(
va
);
e
=
memsearch
(
pa
);
if
(
e
==
NULL
)
return
-
1
;
return
(
e
->
base
+
e
->
length
)
-
pa
;
}
static
void
*
memnext
(
void
*
va
,
u64
inc
)
{
struct
Mbmem
*
e
,
*
q
;
paddr
pa
=
v2p
(
va
);
e
=
memsearch
(
pa
);
if
(
e
==
NULL
)
return
(
void
*
)
-
1
;
pa
+=
inc
;
if
(
pa
<
(
e
->
base
+
e
->
length
))
return
p2v
(
pa
);
q
=
mem
+
nmem
;
for
(
e
=
e
+
1
;
e
<
q
;
e
++
)
return
p2v
(
e
->
base
);
return
(
void
*
)
-
1
;
}
static
void
initmem
(
u64
mbaddr
)
{
struct
Mbdata
*
mb
;
struct
Mbmem
*
mbmem
;
u8
*
p
,
*
ep
;
mb
=
p2v
(
mbaddr
);
if
(
!
(
mb
->
flags
&
(
1
<<
6
)))
panic
(
"multiboot header has no memory map"
);
p
=
p2v
(
mb
->
mmap_addr
);
ep
=
p
+
mb
->
mmap_length
;
while
(
p
<
ep
)
{
mbmem
=
(
Mbmem
*
)(
p
+
4
);
p
+=
4
+
*
(
u32
*
)
p
;
if
(
mbmem
->
type
==
1
)
{
membytes
+=
mbmem
->
length
;
mem
[
nmem
]
=
*
mbmem
;
nmem
++
;
}
}
}
// simple page allocator to get off the ground during boot
static
char
*
pgalloc
(
void
)
...
...
@@ -41,7 +117,7 @@ kfree_pool(struct kmem *m, char *v)
{
struct
run
*
r
;
if
((
uptr
)
v
%
PGSIZE
||
v
<
end
||
v2p
(
v
)
>=
PHYSTOP
)
if
((
uptr
)
v
%
PGSIZE
||
v
<
end
||
memsize
(
v
)
==
-
1ull
)
panic
(
"kfree_pool"
);
// Fill with junk to catch dangling refs.
...
...
@@ -147,10 +223,13 @@ kminit(void)
// Initialize free list of physical pages.
void
initkalloc
(
void
)
initkalloc
(
u64
mbaddr
)
{
char
*
p
;
char
*
e
;
u64
n
;
u64
k
;
initmem
(
mbaddr
);
for
(
int
c
=
0
;
c
<
NCPU
;
c
++
)
{
kmems
[
c
].
name
[
0
]
=
(
char
)
c
+
'0'
;
...
...
@@ -166,18 +245,35 @@ initkalloc(void)
kstacks
[
c
].
size
=
KSTACKSIZE
;
}
cprintf
(
"%lu mbytes
\n
"
,
membytes
/
(
1
<<
20
));
n
=
membytes
/
NCPU
;
if
(
n
&
(
PGSIZE
-
1
))
{
cprintf
(
"bytes/CPU isn't aligned
\n
"
);
n
=
PGROUNDDOWN
(
n
);
}
p
=
(
char
*
)
PGROUNDUP
((
uptr
)
newend
);
e
=
(
char
*
)
KBASE
;
k
=
(((
uptr
)
p
)
-
KBASE
)
;
for
(
int
c
=
0
;
c
<
NCPU
;
c
++
)
{
char
*
sp
=
p
+
CPUKSTACKS
*
KSTACKSIZE
;
char
*
ep
=
e
+
(
PHYSTOP
/
NCPU
);
if
(
sp
>=
ep
)
panic
(
"Too many stacks"
);
for
(;
p
<
sp
;
p
+=
KSTACKSIZE
)
// Fill the stack allocator
for
(
int
i
=
0
;
i
<
CPUKSTACKS
;
i
++
,
k
+=
KSTACKSIZE
)
{
if
(
p
==
(
void
*
)
-
1
)
panic
(
"initkalloc: e820next"
);
// XXX(sbw) handle this condition
if
(
memsize
(
p
)
<
KSTACKSIZE
)
panic
(
"initkalloc: e820size"
);
kfree_pool
(
&
kstacks
[
c
],
p
);
for
(;
p
<
ep
;
p
+=
PGSIZE
)
p
=
memnext
(
p
,
KSTACKSIZE
);
}
// The rest goes to the page allocator
for
(;
k
!=
n
;
k
+=
PGSIZE
,
p
=
memnext
(
p
,
PGSIZE
))
{
if
(
p
==
(
void
*
)
-
1
)
panic
(
"initkalloc: e820next"
);
kfree_pool
(
&
kmems
[
c
],
p
);
e
=
p
;
}
k
=
0
;
}
kminit
();
...
...
main.c
浏览文件 @
f56e01e3
...
...
@@ -2,6 +2,7 @@
#include "multiboot.h"
#include "kernel.h"
#include "cpu.h"
#include "e820.h"
extern
void
initpic
(
void
);
extern
void
initioapic
(
void
);
...
...
@@ -14,7 +15,7 @@ extern void initlapic(void);
extern
void
inittls
(
void
);
extern
void
inittrap
(
void
);
extern
void
initseg
(
void
);
extern
void
initkalloc
(
void
);
extern
void
initkalloc
(
u64
mbaddr
);
extern
void
initrcu
(
void
);
extern
void
initproc
(
void
);
extern
void
initbio
(
void
);
...
...
@@ -74,7 +75,7 @@ bootothers(void)
}
void
cmain
(
void
)
cmain
(
u64
mbmagic
,
u64
mbaddr
)
{
extern
pml4e_t
kpml4
[];
extern
u64
cpuhz
;
...
...
@@ -91,9 +92,8 @@ cmain(void)
inittrap
();
initmp
();
initlapic
();
initkalloc
();
initgc
();
// initialize rcu module
initkalloc
(
mbaddr
);
initgc
();
// gc epochs
initproc
();
// process table
initbio
();
// buffer cache
initinode
();
// inode cache
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论