aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/drivers/cpu.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/src/drivers/cpu.c b/src/drivers/cpu.c
index 945dc4a..ba8c66f 100644
--- a/src/drivers/cpu.c
+++ b/src/drivers/cpu.c
@@ -6,44 +6,43 @@
u8 inb(u16 port)
{
u8 value;
- __asm__("inb %1, %0" : "=a"(value) : "Nd"(port));
+ __asm__ volatile("inb %1, %0" : "=a"(value) : "Nd"(port));
return value;
}
u16 inw(u16 port)
{
u16 value;
- __asm__("inw %1, %0" : "=a"(value) : "Nd"(port));
+ __asm__ volatile("inw %1, %0" : "=a"(value) : "Nd"(port));
return value;
}
u32 inl(u16 port)
{
u32 value;
- __asm__("inl %1, %0" : "=a"(value) : "Nd"(port));
+ __asm__ volatile("inl %1, %0" : "=a"(value) : "Nd"(port));
return value;
}
-// TODO: Fix optimization issues with insl
-void __attribute__((optimize("O0"))) insl(u16 port, void *addr, int n)
+void insl(u16 port, void *addr, int n)
{
- __asm__("cld; rep insl"
- : "=D"(addr), "=c"(n)
- : "d"(port), "0"(addr), "1"(n)
- : "memory", "cc");
+ __asm__ volatile("cld; rep insl"
+ : "=D"(addr), "=c"(n)
+ : "d"(port), "0"(addr), "1"(n)
+ : "memory", "cc");
}
void outb(u16 port, u8 data)
{
- __asm__("outb %0, %1" ::"a"(data), "Nd"(port));
+ __asm__ volatile("outb %0, %1" ::"a"(data), "Nd"(port));
}
void outw(u16 port, u16 data)
{
- __asm__("outw %0, %1" ::"a"(data), "Nd"(port));
+ __asm__ volatile("outw %0, %1" ::"a"(data), "Nd"(port));
}
void outl(u16 port, u32 data)
{
- __asm__("outl %0, %1" ::"a"(data), "Nd"(port));
+ __asm__ volatile("outl %0, %1" ::"a"(data), "Nd"(port));
}