aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/video/console/vgacon.c
diff options
context:
space:
mode:
authorJan Engelhardt <jengelh@linux01.gwdg.de>2007-05-08 03:38:04 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-05-08 14:15:27 -0400
commitfa6ce9ab5fbcb4c276c48861584b70d387e787b3 (patch)
tree71b6295410513d17226a57be542f0a761db97841 /drivers/video/console/vgacon.c
parent1c2bbe6a11ec7d1de114acfc8a6bf2821b0224a5 (diff)
vt: add color support to the "underline" and "italic" attributes
Add color support to the "underline" and "italic" attributes as in OpenBSD/NetBSD-style (vt220) and xterm. Signed-off-by: Jan Engelhardt <jengelh@gmx.de> Acked-by: "Antonino A. Daplas" <adaplas@pol.net> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/video/console/vgacon.c')
-rw-r--r--drivers/video/console/vgacon.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/drivers/video/console/vgacon.c b/drivers/video/console/vgacon.c
index 3e67c34df9a5..53c22197b631 100644
--- a/drivers/video/console/vgacon.c
+++ b/drivers/video/console/vgacon.c
@@ -87,7 +87,7 @@ static void vgacon_save_screen(struct vc_data *c);
87static int vgacon_scroll(struct vc_data *c, int t, int b, int dir, 87static int vgacon_scroll(struct vc_data *c, int t, int b, int dir,
88 int lines); 88 int lines);
89static u8 vgacon_build_attr(struct vc_data *c, u8 color, u8 intensity, 89static u8 vgacon_build_attr(struct vc_data *c, u8 color, u8 intensity,
90 u8 blink, u8 underline, u8 reverse); 90 u8 blink, u8 underline, u8 reverse, u8);
91static void vgacon_invert_region(struct vc_data *c, u16 * p, int count); 91static void vgacon_invert_region(struct vc_data *c, u16 * p, int count);
92static unsigned long vgacon_uni_pagedir[2]; 92static unsigned long vgacon_uni_pagedir[2];
93 93
@@ -578,12 +578,14 @@ static void vgacon_deinit(struct vc_data *c)
578} 578}
579 579
580static u8 vgacon_build_attr(struct vc_data *c, u8 color, u8 intensity, 580static u8 vgacon_build_attr(struct vc_data *c, u8 color, u8 intensity,
581 u8 blink, u8 underline, u8 reverse) 581 u8 blink, u8 underline, u8 reverse, u8 italic)
582{ 582{
583 u8 attr = color; 583 u8 attr = color;
584 584
585 if (vga_can_do_color) { 585 if (vga_can_do_color) {
586 if (underline) 586 if (italic)
587 attr = (attr & 0xF0) | c->vc_itcolor;
588 else if (underline)
587 attr = (attr & 0xf0) | c->vc_ulcolor; 589 attr = (attr & 0xf0) | c->vc_ulcolor;
588 else if (intensity == 0) 590 else if (intensity == 0)
589 attr = (attr & 0xf0) | c->vc_halfcolor; 591 attr = (attr & 0xf0) | c->vc_halfcolor;
@@ -597,7 +599,9 @@ static u8 vgacon_build_attr(struct vc_data *c, u8 color, u8 intensity,
597 if (intensity == 2) 599 if (intensity == 2)
598 attr ^= 0x08; 600 attr ^= 0x08;
599 if (!vga_can_do_color) { 601 if (!vga_can_do_color) {
600 if (underline) 602 if (italic)
603 attr = (attr & 0xF8) | 0x02;
604 else if (underline)
601 attr = (attr & 0xf8) | 0x01; 605 attr = (attr & 0xf8) | 0x01;
602 else if (intensity == 0) 606 else if (intensity == 0)
603 attr = (attr & 0xf0) | 0x08; 607 attr = (attr & 0xf0) | 0x08;