summaryrefslogtreecommitdiff
path: root/src/port.c
blob: 9af4a499b5c38416374a46f33299485a1198566e (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
29
30
31
32
33
34
35
36
37
38

#include "port.h"

void port_write(struct port p, uint32_t data) {
	switch (p.bandwidth) {
		case port8bit:
			asm volatile("outb %0, %1" : : "a" ((uint8_t) data), "Nd" (p.port_number));
			break;
		case port8bit_slow:
			asm volatile("outb %0, %1\njmp 1f\n1: jmp 1f\n1:" : 
					: "a" ((uint8_t) data), "Nd" (p.port_number));
			break;
		case port16bit:
			asm volatile("outw %0, %1" : : "a" ((uint16_t) data), "Nd" (p.port_number));
		case port32bit:
			asm volatile("outl %0, %1" : : "a" (data), "Nd" (p.port_number));
			break;
	}
}

uint32_t port_read(struct port p) {
	uint32_t result = 0;
	switch (p.bandwidth) {
	 	case port8bit:
			asm volatile("inb %1, %0" : "=a" (result) : "Nd" (p.port_number));
			break;
		case port8bit_slow:
			asm volatile("inb %1, %0\njmp 1f\n1: jmp 1f\n1:" : "=a" (result) : "Nd" (p.port_number));
			break;
		case port16bit:
			asm volatile("inw %1, %0" : "=a" (result) : "Nd" (p.port_number));
			break;
		case port32bit:
			asm volatile("inl %1, %0" : "=a" (result) : "Nd" (p.port_number));
	}

	return result;
}