summaryrefslogtreecommitdiff
path: root/src/kernel/arch/i386/driver/ps2.c
blob: 1af3166ac5160f1e096d40f49d1a2748a9518455 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <kernel/arch/i386/driver/ps2.h>
#include <kernel/arch/i386/interrupts/irq.h>
#include <shared/mem.h>

#define BACKLOG_CAPACITY 16

/* TODO move away from tty/ */

static volatile uint8_t backlog[BACKLOG_CAPACITY] = {};
static volatile size_t backlog_size = 0;

void ps2_recv(uint8_t s) {
	if (backlog_size >= BACKLOG_CAPACITY) return;
	backlog[backlog_size++] = s;
}

size_t ps2_read(uint8_t *buf, size_t max_len) {
	irq_interrupt_flag(true);
	while (backlog_size == 0)
		asm("hlt" ::: "memory");
	irq_interrupt_flag(false);

	size_t len = backlog_size;
	if (len > max_len) len = max_len;
	backlog_size = 0;
	memcpy(buf, (void*)backlog, len);
	return len;
}