Move assembly code for x86 64 IO to io.S

This commit is contained in:
2025-08-10 21:38:09 +02:00
parent 8ee1ea1292
commit 83e58b0ac2
3 changed files with 27 additions and 22 deletions

View File

@ -1,12 +1,12 @@
.global serial_outb .global io_outb
serial_outb: io_outb:
mov %di, %dx mov %di, %dx
mov %sil, %al mov %sil, %al
out %al, %dx out %al, %dx
ret ret
.global serial_inb .global io_inb
serial_inb: io_inb:
mov %di, %dx mov %di, %dx
in %dx, %al in %dx, %al
movzx %al, %rax movzx %al, %rax

7
kernel/hal/x86_64/io.h Normal file
View File

@ -0,0 +1,7 @@
#ifndef HAL_IO_H_
#define HAL_IO_H_
extern uint8_t io_inb(uint16_t port);
extern void io_outb(uint16_t port, uint8_t value);
#endif // HAL_IO_H_

View File

@ -1,46 +1,44 @@
#include <stdint.h> #include <stdint.h>
#include <stdbool.h> #include <stdbool.h>
#include "io.h"
#define SERIAL_PORT 0x3f8 #define SERIAL_PORT 0x3f8
extern uint8_t serial_inb(uint16_t port);
extern void serial_outb(uint16_t port, uint8_t value);
static int serial_received(void) { static int serial_received(void) {
return serial_inb(SERIAL_PORT + 5) & 1; return io_inb(SERIAL_PORT + 5) & 1;
} }
static uint8_t serial_read(void) { static uint8_t serial_read(void) {
while (serial_received() == 0); while (serial_received() == 0);
return serial_inb(SERIAL_PORT); return io_inb(SERIAL_PORT);
} }
static int serial_trans_empty(void) { static int serial_trans_empty(void) {
return serial_inb(SERIAL_PORT + 5) & 0x20; return io_inb(SERIAL_PORT + 5) & 0x20;
} }
static void serial_write(uint8_t value) { static void serial_write(uint8_t value) {
while (!serial_trans_empty()); while (!serial_trans_empty());
serial_outb(SERIAL_PORT, value); io_outb(SERIAL_PORT, value);
} }
// REFERENCE: https://wiki.osdev.org/Serial_Ports // REFERENCE: https://wiki.osdev.org/Serial_Ports
bool serial_init(void) { bool serial_init(void) {
serial_outb(SERIAL_PORT + 1, 0x00); io_outb(SERIAL_PORT + 1, 0x00);
serial_outb(SERIAL_PORT + 3, 0x80); io_outb(SERIAL_PORT + 3, 0x80);
serial_outb(SERIAL_PORT + 0, 0x03); io_outb(SERIAL_PORT + 0, 0x03);
serial_outb(SERIAL_PORT + 1, 0x00); io_outb(SERIAL_PORT + 1, 0x00);
serial_outb(SERIAL_PORT + 3, 0x03); io_outb(SERIAL_PORT + 3, 0x03);
serial_outb(SERIAL_PORT + 2, 0xc7); io_outb(SERIAL_PORT + 2, 0xc7);
serial_outb(SERIAL_PORT + 4, 0x0b); io_outb(SERIAL_PORT + 4, 0x0b);
serial_outb(SERIAL_PORT + 4, 0x1e); io_outb(SERIAL_PORT + 4, 0x1e);
serial_outb(SERIAL_PORT + 0, 0xae); io_outb(SERIAL_PORT + 0, 0xae);
if (serial_inb(SERIAL_PORT + 0) != 0xae) { if (io_inb(SERIAL_PORT + 0) != 0xae) {
return false; return false;
} }
serial_outb(SERIAL_PORT + 4, 0x0f); io_outb(SERIAL_PORT + 4, 0x0f);
return true; return true;
} }