rename 8253pit.c to timer.c
This commit is contained in:
		
							parent
							
								
									eae04163a7
								
							
						
					
					
						commit
						9e82bfb04c
					
				
					 5 changed files with 38 additions and 51 deletions
				
			
		
							
								
								
									
										45
									
								
								8253pit.c
									
										
									
									
									
								
							
							
						
						
									
										45
									
								
								8253pit.c
									
										
									
									
									
								
							|  | @ -1,45 +0,0 @@ | |||
| #include "types.h" | ||||
| #include "defs.h" | ||||
| #include "traps.h" | ||||
| #include "x86.h" | ||||
| 
 | ||||
| // Register definitions for the Intel
 | ||||
| // 8253/8254/82C54 Programmable Interval Timer (PIT).
 | ||||
| 
 | ||||
| #define IO_TIMER1       0x040           // 8253 Timer #1
 | ||||
| #define IO_TIMER2       0x048           // 8253 Timer #2 (EISA only)
 | ||||
| 
 | ||||
| // 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_CNTR0     (IO_TIMER1 + 0) // timer 0 counter port
 | ||||
| #define TIMER_CNTR1     (IO_TIMER1 + 1) // timer 1 counter port
 | ||||
| #define TIMER_CNTR2     (IO_TIMER1 + 2) // timer 2 counter port
 | ||||
| #define TIMER_MODE      (IO_TIMER1 + 3) // timer mode port
 | ||||
| #define TIMER_SEL0      0x00    // select counter 0
 | ||||
| #define TIMER_SEL1      0x40    // select counter 1
 | ||||
| #define TIMER_SEL2      0x80    // select counter 2
 | ||||
| #define TIMER_INTTC     0x00    // mode 0, intr on terminal cnt
 | ||||
| #define TIMER_ONESHOT   0x02    // mode 1, one shot
 | ||||
| #define TIMER_RATEGEN   0x04    // mode 2, rate generator
 | ||||
| #define TIMER_SQWAVE    0x06    // mode 3, square wave
 | ||||
| #define TIMER_SWSTROBE  0x08    // mode 4, s/w triggered strobe
 | ||||
| #define TIMER_HWSTROBE  0x0a    // mode 5, h/w triggered strobe
 | ||||
| #define TIMER_LATCH     0x00    // latch counter for reading
 | ||||
| #define TIMER_LSB       0x10    // r/w counter LSB
 | ||||
| #define TIMER_MSB       0x20    // r/w counter MSB
 | ||||
| #define TIMER_16BIT     0x30    // r/w counter 16 bits, LSB first
 | ||||
| #define TIMER_BCD       0x01    // count in BCD
 | ||||
| 
 | ||||
| void | ||||
| pit8253_timerinit(void) | ||||
| { | ||||
|   // initialize 8253 clock to 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); | ||||
| } | ||||
							
								
								
									
										6
									
								
								defs.h
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								defs.h
									
										
									
									
									
								
							|  | @ -7,9 +7,6 @@ struct proc; | |||
| struct spinlock; | ||||
| struct stat; | ||||
| 
 | ||||
| // 8253pit.c
 | ||||
| void            pit8253_timerinit(void); | ||||
| 
 | ||||
| // bio.c
 | ||||
| void            binit(void); | ||||
| struct buf*     bread(uint, uint); | ||||
|  | @ -140,6 +137,9 @@ int             fetchint(struct proc*, uint, int*); | |||
| int             fetchstr(struct proc*, uint, char**); | ||||
| void            syscall(void); | ||||
| 
 | ||||
| // timer.c
 | ||||
| void            timer_init(void); | ||||
| 
 | ||||
| // trap.c
 | ||||
| void            idtinit(void); | ||||
| extern int      ticks; | ||||
|  |  | |||
							
								
								
									
										4
									
								
								main.c
									
										
									
									
									
								
							
							
						
						
									
										4
									
								
								main.c
									
										
									
									
									
								
							|  | @ -46,7 +46,7 @@ main(void) | |||
|   ide_init();      // disk
 | ||||
|   bootothers();    // boot other CPUs
 | ||||
|   if(!ismp) | ||||
|     pit8253_timerinit(); // uniprocessor timer
 | ||||
|     timer_init(); // uniprocessor timer
 | ||||
|   userinit();      // first user process
 | ||||
| 
 | ||||
|   // enable interrupts on this processor.
 | ||||
|  | @ -74,7 +74,7 @@ mpmain(void) | |||
|   scheduler(); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| static void | ||||
| bootothers(void) | ||||
| { | ||||
|   extern uchar _binary_bootother_start[], _binary_bootother_size[]; | ||||
|  |  | |||
|  | @ -64,7 +64,7 @@ picirq.c | |||
| kbd.h | ||||
| kbd.c | ||||
| console.c | ||||
| 8253pit.c | ||||
| timer.c | ||||
| 
 | ||||
| # user-level | ||||
| usys.S | ||||
|  |  | |||
							
								
								
									
										32
									
								
								timer.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								timer.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -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); | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 rsc
						rsc