refactor: one more step towards arch-agnostic design
[lunaix-os.git] / lunaix-os / kernel / tty / tty.c
index 4c9631cefdeed0312a9d7a0d18de972ec06d3da2..e90899b6f55301aa4f8fa1b92a6d753e1b8eb9e3 100644 (file)
@@ -1,4 +1,3 @@
-#include <hal/io.h>
 #include <klibc/string.h>
 #include <lunaix/common.h>
 #include <lunaix/spike.h>
@@ -6,6 +5,8 @@
 #include <lunaix/tty/tty.h>
 #include <stdint.h>
 
+#include <sys/port_io.h>
+
 vga_attribute* tty_vga_buffer;
 
 vga_attribute tty_theme_color = VGA_COLOR_BLACK;
@@ -26,11 +27,11 @@ tty_init(void* vga_buf)
 
     tty_clear();
 
-    io_outb(0x3D4, 0x0A);
-    io_outb(0x3D5, (io_inb(0x3D5) & 0xC0) | 13);
+    port_wrbyte(0x3D4, 0x0A);
+    port_wrbyte(0x3D5, (port_rdbyte(0x3D5) & 0xC0) | 13);
 
-    io_outb(0x3D4, 0x0B);
-    io_outb(0x3D5, (io_inb(0x3D5) & 0xE0) | 15);
+    port_wrbyte(0x3D4, 0x0B);
+    port_wrbyte(0x3D5, (port_rdbyte(0x3D5) & 0xE0) | 15);
 }
 
 void
@@ -40,10 +41,10 @@ tty_set_cursor(u8_t x, u8_t y)
         x = y = 0;
     }
     u32_t pos = y * TTY_WIDTH + x;
-    io_outb(0x3D4, 14);
-    io_outb(0x3D5, pos / 256);
-    io_outb(0x3D4, 15);
-    io_outb(0x3D5, pos % 256);
+    port_wrbyte(0x3D4, 14);
+    port_wrbyte(0x3D5, pos / 256);
+    port_wrbyte(0x3D4, 15);
+    port_wrbyte(0x3D5, pos % 256);
 }
 
 void