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;
}
|