Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
778e40e8
提交
778e40e8
12月 04, 2011
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Odds and ends for event counters on AMD.
上级
3b80afc5
隐藏空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
74 行增加
和
28 行删除
+74
-28
kernel.h
kernel.h
+2
-0
lapic.c
lapic.c
+9
-1
main.c
main.c
+3
-0
prof.c
prof.c
+51
-27
trap.c
trap.c
+9
-0
没有找到文件。
kernel.h
浏览文件 @
778e40e8
...
...
@@ -129,6 +129,7 @@ int cpunum(void);
void
lapicstartap
(
u8
,
u32
addr
);
void
lapiceoi
(
void
);
void
lapic_tlbflush
(
u32
);
void
lapicpc
(
char
mask
);
// mp.c
extern
int
ncpu
;
...
...
@@ -210,6 +211,7 @@ extern int profenable;
void
profreset
(
void
);
void
profdump
(
void
);
void
profstart
(
void
);
int
profintr
(
void
);
// rcu.c
void
rcuinit
(
void
);
...
...
lapic.c
浏览文件 @
778e40e8
...
...
@@ -35,6 +35,8 @@
#define LINT1 (0x0360/4) // Local Vector Table 2 (LINT1)
#define ERROR (0x0370/4) // Local Vector Table 3 (ERROR)
#define MASKED 0x00010000 // Interrupt masked
#define MT_NMI 0x00000400 // NMI message type
#define MT_FIX 0x00000000 // Fixed message type
#define TICR (0x0380/4) // Timer Initial Count
#define TCCR (0x0390/4) // Timer Current Count
#define TDCR (0x03E0/4) // Timer Divide Configuration
...
...
@@ -107,7 +109,7 @@ initlapic(void)
// Disable performance counter overflow interrupts
// on machines that provide that interrupt entry.
if
(((
lapic
[
VER
]
>>
16
)
&
0xFF
)
>=
4
)
lapic
w
(
PCINT
,
MASKED
);
lapic
pc
(
0
);
// Map error interrupt to IRQ_ERROR.
lapicw
(
ERROR
,
T_IRQ0
+
IRQ_ERROR
);
...
...
@@ -129,6 +131,12 @@ initlapic(void)
lapicw
(
TPR
,
0
);
}
void
lapicpc
(
char
mask
)
{
lapicw
(
PCINT
,
mask
?
MASKED
:
MT_NMI
);
}
int
cpunum
(
void
)
{
...
...
main.c
浏览文件 @
778e40e8
...
...
@@ -24,6 +24,7 @@ extern void initdisk(void);
extern
void
inituser
(
void
);
extern
void
inithz
(
void
);
extern
void
initwq
(
void
);
extern
void
initprof
(
void
);
static
volatile
int
bstate
;
...
...
@@ -33,6 +34,7 @@ mpboot(void)
initseg
();
inittls
();
initlapic
();
initprof
();
bstate
=
1
;
scheduler
();
// start running processes
}
...
...
@@ -99,6 +101,7 @@ cmain(void)
#if WQENABLE
initwq
();
// work queues
#endif
initprof
();
cprintf
(
"ncpu %d %lu MHz
\n
"
,
ncpu
,
cpuhz
/
1000000
);
...
...
prof.c
浏览文件 @
778e40e8
...
...
@@ -11,10 +11,46 @@
extern
profctr_t
sprof
[];
extern
profctr_t
eprof
[];
int
profenable
;
static
void
(
*
profconfig
)(
u64
ctr
,
u64
sel
,
u64
val
);
struct
pmu
{
void
(
*
config
)(
u64
ctr
,
u64
sel
,
u64
val
);
u64
cntval_bits
;
};
struct
pmu
pmu
;
//
// AMD stuff
//
static
void
amdconfig
(
u64
ctr
,
u64
sel
,
u64
val
)
{
writemsr
(
MSR_AMD_PERF_SEL0
|
ctr
,
0
);
writemsr
(
MSR_AMD_PERF_CNT0
|
ctr
,
val
);
writemsr
(
MSR_AMD_PERF_SEL0
|
ctr
,
sel
);
}
struct
pmu
amdpmu
=
{
.
config
=
amdconfig
,
.
cntval_bits
=
48
,
};
//
// Intel stuff
//
static
void
intelconfig
(
u64
ctr
,
u64
sel
,
u64
val
)
{
writemsr
(
MSR_INTEL_PERF_SEL0
|
ctr
,
0
);
writemsr
(
MSR_INTEL_PERF_CNT0
|
ctr
,
val
);
writemsr
(
MSR_INTEL_PERF_SEL0
|
ctr
,
sel
);
}
// XXX
struct
pmu
intelpmu
=
{
.
config
=
intelconfig
,
.
cntval_bits
=
48
,
};
void
profreset
(
void
)
...
...
@@ -46,30 +82,12 @@ profdump(void)
}
}
static
void
amdconfig
(
u64
ctr
,
u64
sel
,
u64
val
)
{
writemsr
(
MSR_AMD_PERF_SEL0
|
ctr
,
0
);
writemsr
(
MSR_AMD_PERF_CNT0
|
ctr
,
val
);
writemsr
(
MSR_AMD_PERF_SEL0
|
ctr
,
sel
);
}
static
void
intelconfig
(
u64
ctr
,
u64
sel
,
u64
val
)
{
writemsr
(
MSR_INTEL_PERF_SEL0
|
ctr
,
0
);
writemsr
(
MSR_INTEL_PERF_CNT0
|
ctr
,
val
);
writemsr
(
MSR_INTEL_PERF_SEL0
|
ctr
,
sel
);
}
void
profstart
(
void
)
{
u64
ctr
=
0
;
u64
sel
=
0
;
u64
val
=
-
1000
;
cprintf
(
"profstart ...
\n
"
);
u64
val
=
-
100000
;
sel
=
0UL
<<
32
|
1
<<
24
|
...
...
@@ -81,10 +99,16 @@ profstart(void)
0x76
;
pushcli
();
p
rof
config
(
ctr
,
sel
,
val
);
p
mu
.
config
(
ctr
,
sel
,
val
);
popcli
();
}
cprintf
(
"rdpmc %lx
\n
"
,
rdpmc
(
0
));
int
profintr
(
void
)
{
lapicpc
(
0
);
// Only level-triggered interrupts require an lapiceoi.
return
1
;
}
void
...
...
@@ -97,10 +121,10 @@ initprof(void)
cpuid
(
0
,
0
,
&
name
[
0
],
&
name
[
2
],
&
name
[
1
]);
cprintf
(
"%s
\n
"
,
s
);
if
(
strcmp
(
s
,
"AuthenticAMD"
))
p
rofconfig
=
amdconfig
;
else
if
(
strcmp
(
s
,
"GenuineIntel"
))
p
rofconfig
=
intelconfig
;
if
(
!
strcmp
(
s
,
"AuthenticAMD"
))
p
mu
=
amdpmu
;
else
if
(
!
strcmp
(
s
,
"GenuineIntel"
))
p
mu
=
intelpmu
;
else
panic
(
"Unknown Manufacturer"
);
}
...
...
trap.c
浏览文件 @
778e40e8
...
...
@@ -48,6 +48,14 @@ trap(struct trapframe *tf)
writemsr
(
MSR_GS_BASE
,
(
u64
)
&
cpus
[
cpunum
()].
cpu
);
sti
();
if
(
tf
->
trapno
==
T_NMI
)
{
// The only locks that we can acquire during NMI are ones
// we acquire only during NMI.
if
(
profintr
())
return
;
panic
(
"NMI"
);
}
// XXX(sbw) sysenter/sysexit
if
(
tf
->
trapno
==
T_SYSCALL
){
if
(
myproc
()
->
killed
)
{
...
...
@@ -92,6 +100,7 @@ trap(struct trapframe *tf)
lapiceoi
();
piceoi
();
break
;
case
T_IRQ0
+
IRQ_COM2
:
case
T_IRQ0
+
IRQ_COM1
:
uartintr
();
lapiceoi
();
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论