Rev 534 | Rev 623 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 534 | Rev 575 | ||
---|---|---|---|
Line 32... | Line 32... | ||
32 | #include <arch/mm/page.h> |
32 | #include <arch/mm/page.h> |
33 | #include <synch/spinlock.h> |
33 | #include <synch/spinlock.h> |
34 | #include <arch/types.h> |
34 | #include <arch/types.h> |
35 | #include <arch/asm.h> |
35 | #include <arch/asm.h> |
36 | #include <memstr.h> |
36 | #include <memstr.h> |
- | 37 | #include <console/chardev.h> |
|
- | 38 | #include <console/console.h> |
|
37 | 39 | ||
38 | /* |
40 | /* |
39 | * The EGA driver. |
41 | * The EGA driver. |
40 | * Simple and short. Function for displaying characters and "scrolling". |
42 | * Simple and short. Function for displaying characters and "scrolling". |
41 | */ |
43 | */ |
42 | 44 | ||
43 | static spinlock_t egalock; |
45 | static spinlock_t egalock; |
44 | static __u32 ega_cursor; |
46 | static __u32 ega_cursor; |
45 | 47 | ||
- | 48 | static void ega_putchar(chardev_t *d, const char ch); |
|
- | 49 | ||
- | 50 | chardev_t ega_console; |
|
- | 51 | static chardev_operations_t ega_ops = { |
|
- | 52 | .write = ega_putchar |
|
- | 53 | }; |
|
- | 54 | ||
46 | void ega_move_cursor(void); |
55 | void ega_move_cursor(void); |
47 | 56 | ||
48 | void ega_init(void) |
57 | void ega_init(void) |
49 | { |
58 | { |
50 | __u8 hi, lo; |
59 | __u8 hi, lo; |
Line 53... | Line 62... | ||
53 | outb(0x3d4,0xe); |
62 | outb(0x3d4,0xe); |
54 | hi = inb(0x3d5); |
63 | hi = inb(0x3d5); |
55 | outb(0x3d4,0xf); |
64 | outb(0x3d4,0xf); |
56 | lo = inb(0x3d5); |
65 | lo = inb(0x3d5); |
57 | ega_cursor = (hi<<8)|lo; |
66 | ega_cursor = (hi<<8)|lo; |
- | 67 | ||
- | 68 | chardev_initialize("ega_out", &ega_console, &ega_ops); |
|
- | 69 | stdout = &ega_console; |
|
- | 70 | ||
58 | ega_putchar('\n'); |
71 | putchar('\n'); |
59 | } |
72 | } |
60 | 73 | ||
61 | static void ega_display_char(char ch) |
74 | static void ega_display_char(char ch) |
62 | { |
75 | { |
63 | __u8 *vram = (__u8 *) PA2KA(VIDEORAM); |
76 | __u8 *vram = (__u8 *) PA2KA(VIDEORAM); |
Line 76... | Line 89... | ||
76 | memcpy((void *)PA2KA(VIDEORAM), (void *)(PA2KA(VIDEORAM) + ROW*2), (SCREEN - ROW)*2); |
89 | memcpy((void *)PA2KA(VIDEORAM), (void *)(PA2KA(VIDEORAM) + ROW*2), (SCREEN - ROW)*2); |
77 | memsetw(PA2KA(VIDEORAM) + (SCREEN - ROW)*2, ROW, 0x0720); |
90 | memsetw(PA2KA(VIDEORAM) + (SCREEN - ROW)*2, ROW, 0x0720); |
78 | ega_cursor = ega_cursor - ROW; |
91 | ega_cursor = ega_cursor - ROW; |
79 | } |
92 | } |
80 | 93 | ||
81 | void ega_putchar(const char ch) |
94 | void ega_putchar(chardev_t *d, const char ch) |
82 | { |
95 | { |
83 | ipl_t ipl; |
96 | ipl_t ipl; |
84 | 97 | ||
85 | ipl = interrupts_disable(); |
98 | ipl = interrupts_disable(); |
86 | spinlock_lock(&egalock); |
99 | spinlock_lock(&egalock); |
Line 109... | Line 122... | ||
109 | outb(0x3d4,0xe); |
122 | outb(0x3d4,0xe); |
110 | outb(0x3d5,(ega_cursor>>8)&0xff); |
123 | outb(0x3d5,(ega_cursor>>8)&0xff); |
111 | outb(0x3d4,0xf); |
124 | outb(0x3d4,0xf); |
112 | outb(0x3d5,ega_cursor&0xff); |
125 | outb(0x3d5,ega_cursor&0xff); |
113 | } |
126 | } |
114 | - | ||
115 | void putchar(const char ch) |
- | |
116 | { |
- | |
117 | ega_putchar(ch); |
- | |
118 | } |
- |