Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
5c596bb3
提交
5c596bb3
9月 08, 2006
创建
作者:
kaashoek
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
consistency.
上级
5cb7877e
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
45 行增加
和
42 行删除
+45
-42
ioapic.c
ioapic.c
+36
-34
lapic.c
lapic.c
+9
-8
没有找到文件。
ioapic.c
浏览文件 @
5c596bb3
...
@@ -37,30 +37,31 @@ ioapic_init(void)
...
@@ -37,30 +37,31 @@ ioapic_init(void)
uchar
id
;
uchar
id
;
int
i
;
int
i
;
if
(
ismp
)
{
if
(
!
ismp
)
io
=
(
struct
ioapic
*
)
IO_APIC_BASE
;
return
;
l
=
ioapic_read
(
io
,
IOAPIC_VER
);
nintr
=
((
l
&
IOART_VER_MAXREDIR
)
>>
MAXREDIRSHIFT
)
+
1
;
io
=
(
struct
ioapic
*
)
IO_APIC_BASE
;
id
=
ioapic_read
(
io
,
IOAPIC_ID
)
>>
APIC_ID_SHIFT
;
l
=
ioapic_read
(
io
,
IOAPIC_VER
);
if
(
id
!=
ioapic_id
)
nintr
=
((
l
&
IOART_VER_MAXREDIR
)
>>
MAXREDIRSHIFT
)
+
1
;
cprintf
(
"ioapic_init: id isn't equal to ioapic_id; not a MP
\n
"
);
id
=
ioapic_read
(
io
,
IOAPIC_ID
)
>>
APIC_ID_SHIFT
;
for
(
i
=
0
;
i
<
nintr
;
i
++
)
{
if
(
id
!=
ioapic_id
)
// active-hi and edge-triggered for ISA interrupts
cprintf
(
"ioapic_init: id isn't equal to ioapic_id; not a MP
\n
"
);
// Assume that pin 0 on the first I/O APIC is an ExtINT pin.
for
(
i
=
0
;
i
<
nintr
;
i
++
)
{
// Assume that pins 1-15 are ISA interrupts
// active-hi and edge-triggered for ISA interrupts
l
=
ioapic_read
(
io
,
IOAPIC_REDTBL_LO
(
i
));
// Assume that pin 0 on the first I/O APIC is an ExtINT pin.
l
=
l
&
~
IOART_INTMASK
;
// allow INTs
// Assume that pins 1-15 are ISA interrupts
l
|=
IOART_INTMSET
;
l
=
ioapic_read
(
io
,
IOAPIC_REDTBL_LO
(
i
));
l
=
l
&
~
IOART_INTPOL
;
// active hi
l
=
l
&
~
IOART_INTMASK
;
// allow INTs
l
=
l
&
~
IOART_TRGRMOD
;
// edgee triggered
l
|=
IOART_INTMSET
;
l
=
l
&
~
IOART_DELMOD
;
// fixed
l
=
l
&
~
IOART_INTPOL
;
// active hi
l
=
l
&
~
IOART_DESTMOD
;
// physical mode
l
=
l
&
~
IOART_TRGRMOD
;
// edgee triggered
l
=
l
|
(
IRQ_OFFSET
+
i
);
// vector
l
=
l
&
~
IOART_DELMOD
;
// fixed
ioapic_write
(
io
,
IOAPIC_REDTBL_LO
(
i
),
l
);
l
=
l
&
~
IOART_DESTMOD
;
// physical mode
h
=
ioapic_read
(
io
,
IOAPIC_REDTBL_HI
(
i
));
l
=
l
|
(
IRQ_OFFSET
+
i
);
// vector
h
&=
~
IOART_DEST
;
ioapic_write
(
io
,
IOAPIC_REDTBL_LO
(
i
),
l
);
ioapic_write
(
io
,
IOAPIC_REDTBL_HI
(
i
),
h
);
h
=
ioapic_read
(
io
,
IOAPIC_REDTBL_HI
(
i
));
}
h
&=
~
IOART_DEST
;
ioapic_write
(
io
,
IOAPIC_REDTBL_HI
(
i
),
h
);
}
}
}
}
...
@@ -70,14 +71,15 @@ ioapic_enable (int irq, int cpunum)
...
@@ -70,14 +71,15 @@ ioapic_enable (int irq, int cpunum)
uint
l
,
h
;
uint
l
,
h
;
struct
ioapic
*
io
;
struct
ioapic
*
io
;
if
(
ismp
)
{
if
(
!
ismp
)
io
=
(
struct
ioapic
*
)
IO_APIC_BASE
;
return
;
l
=
ioapic_read
(
io
,
IOAPIC_REDTBL_LO
(
irq
));
l
=
l
&
~
IOART_INTMASK
;
// allow INTs
io
=
(
struct
ioapic
*
)
IO_APIC_BASE
;
ioapic_write
(
io
,
IOAPIC_REDTBL_LO
(
irq
),
l
);
l
=
ioapic_read
(
io
,
IOAPIC_REDTBL_LO
(
irq
));
h
=
ioapic_read
(
io
,
IOAPIC_REDTBL_HI
(
irq
));
l
=
l
&
~
IOART_INTMASK
;
// allow INTs
h
&=
~
IOART_DEST
;
ioapic_write
(
io
,
IOAPIC_REDTBL_LO
(
irq
),
l
);
h
|=
(
cpunum
<<
APIC_ID_SHIFT
);
h
=
ioapic_read
(
io
,
IOAPIC_REDTBL_HI
(
irq
));
ioapic_write
(
io
,
IOAPIC_REDTBL_HI
(
irq
),
h
);
h
&=
~
IOART_DEST
;
}
h
|=
(
cpunum
<<
APIC_ID_SHIFT
);
ioapic_write
(
io
,
IOAPIC_REDTBL_HI
(
irq
),
h
);
}
}
lapic.c
浏览文件 @
5c596bb3
...
@@ -105,13 +105,14 @@ lapic_write(int r, int data)
...
@@ -105,13 +105,14 @@ lapic_write(int r, int data)
void
void
lapic_timerinit
(
void
)
lapic_timerinit
(
void
)
{
{
if
(
lapicaddr
)
{
if
(
!
lapicaddr
)
lapic_write
(
LAPIC_TDCR
,
LAPIC_X1
);
return
;
lapic_write
(
LAPIC_TIMER
,
LAPIC_CLKIN
|
LAPIC_PERIODIC
|
(
IRQ_OFFSET
+
IRQ_TIMER
));
lapic_write
(
LAPIC_TDCR
,
LAPIC_X1
);
lapic_write
(
LAPIC_TCCR
,
10000000
);
lapic_write
(
LAPIC_TIMER
,
LAPIC_CLKIN
|
LAPIC_PERIODIC
|
lapic_write
(
LAPIC_TICR
,
10000000
);
(
IRQ_OFFSET
+
IRQ_TIMER
));
}
lapic_write
(
LAPIC_TCCR
,
10000000
);
lapic_write
(
LAPIC_TICR
,
10000000
);
}
}
void
void
...
@@ -126,7 +127,7 @@ lapic_init(int c)
...
@@ -126,7 +127,7 @@ lapic_init(int c)
{
{
uint
r
,
lvt
;
uint
r
,
lvt
;
if
(
lapicaddr
==
0
)
if
(
!
lapicaddr
)
return
;
return
;
lapic_write
(
LAPIC_DFR
,
0xFFFFFFFF
);
// Set dst format register
lapic_write
(
LAPIC_DFR
,
0xFFFFFFFF
);
// Set dst format register
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论