forked from mit-pdos/xv6-public
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
rsc
committed
Aug 28, 2007
1 parent
eae0416
commit 9e82bfb
Showing
5 changed files
with
38 additions
and
51 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -64,7 +64,7 @@ picirq.c | |
kbd.h | ||
kbd.c | ||
console.c | ||
8253pit.c | ||
timer.c | ||
|
||
# user-level | ||
usys.S | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
// Intel 8253/8254/82C54 Programmable Interval Timer (PIT). | ||
// Only used on uniprocessors; | ||
// SMP machines use the local APIC timer. | ||
|
||
#include "types.h" | ||
#include "defs.h" | ||
#include "traps.h" | ||
#include "x86.h" | ||
|
||
#define IO_TIMER1 0x040 // 8253 Timer #1 | ||
|
||
// Frequency of all three count-down timers; | ||
// (TIMER_FREQ/freq) is the appropriate count | ||
// to generate a frequency of freq Hz. | ||
|
||
#define TIMER_FREQ 1193182 | ||
#define TIMER_DIV(x) ((TIMER_FREQ+(x)/2)/(x)) | ||
|
||
#define TIMER_MODE (IO_TIMER1 + 3) // timer mode port | ||
#define TIMER_SEL0 0x00 // select counter 0 | ||
#define TIMER_RATEGEN 0x04 // mode 2, rate generator | ||
#define TIMER_16BIT 0x30 // r/w counter 16 bits, LSB first | ||
|
||
void | ||
timer_init(void) | ||
{ | ||
// Interrupt 100 times/sec. | ||
outb(TIMER_MODE, TIMER_SEL0 | TIMER_RATEGEN | TIMER_16BIT); | ||
outb(IO_TIMER1, TIMER_DIV(100) % 256); | ||
outb(IO_TIMER1, TIMER_DIV(100) / 256); | ||
irq_enable(IRQ_TIMER); | ||
} |