projects
/
pintos-anon
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Make tests public. Rewrite most tests. Add tests.
[pintos-anon]
/
src
/
devices
/
timer.c
diff --git
a/src/devices/timer.c
b/src/devices/timer.c
index 9e1b4989c833b62cfcaa5a66032c1cae1124fec0..24eede0e247e8c1f389be38f129dda96d81ffb80 100644
(file)
--- a/
src/devices/timer.c
+++ b/
src/devices/timer.c
@@
-16,9
+16,6
@@
#error TIMER_FREQ <= 1000 recommended
#endif
#error TIMER_FREQ <= 1000 recommended
#endif
-/* Number of time ticks to elapse between process yields. */
-#define TIME_SLICE 1
-
/* Number of timer ticks since OS booted. */
static volatile int64_t ticks;
/* Number of timer ticks since OS booted. */
static volatile int64_t ticks;
@@
-45,7
+42,7
@@
timer_init (void)
outb (0x40, count & 0xff);
outb (0x40, count >> 8);
outb (0x40, count & 0xff);
outb (0x40, count >> 8);
- intr_register
(0x20, 0, INTR_OFF
, timer_interrupt, "8254 Timer");
+ intr_register
_ext (0x20
, timer_interrupt, "8254 Timer");
}
/* Calibrates loops_per_tick, used to implement brief delays. */
}
/* Calibrates loops_per_tick, used to implement brief delays. */
@@
-135,8
+132,6
@@
timer_interrupt (struct intr_frame *args UNUSED)
{
ticks++;
thread_tick ();
{
ticks++;
thread_tick ();
- if (ticks % TIME_SLICE == 0)
- intr_yield_on_return ();
}
/* Returns true if LOOPS iterations waits for more than one timer
}
/* Returns true if LOOPS iterations waits for more than one timer