xv6-65oo2/x86.h

154 lines
2.7 KiB
C
Raw Normal View History

2006-07-20 09:07:53 +00:00
static __inline uchar
2006-06-12 15:22:12 +00:00
inb(int port)
{
2006-07-20 09:07:53 +00:00
uchar data;
2006-06-12 15:22:12 +00:00
__asm __volatile("inb %w1,%0" : "=a" (data) : "d" (port));
return data;
}
static __inline void
insl(int port, void *addr, int cnt)
{
__asm __volatile("cld\n\trepne\n\tinsl" :
"=D" (addr), "=c" (cnt) :
"d" (port), "0" (addr), "1" (cnt) :
"memory", "cc");
}
static __inline void
2006-07-20 09:07:53 +00:00
outb(int port, uchar data)
2006-06-12 15:22:12 +00:00
{
__asm __volatile("outb %0,%w1" : : "a" (data), "d" (port));
}
static __inline void
2006-07-20 09:07:53 +00:00
outw(int port, ushort data)
2006-06-12 15:22:12 +00:00
{
__asm __volatile("outw %0,%w1" : : "a" (data), "d" (port));
}
static __inline void
outsl(int port, const void *addr, int cnt)
{
__asm __volatile("cld\n\trepne\n\toutsl" :
"=S" (addr), "=c" (cnt) :
"d" (port), "0" (addr), "1" (cnt) :
"cc");
}
struct segdesc;
2006-06-12 15:22:12 +00:00
static __inline void
lgdt(struct segdesc *p, int size)
2006-06-12 15:22:12 +00:00
{
2006-07-20 09:07:53 +00:00
volatile ushort pd[3];
pd[0] = size-1;
pd[1] = (uint)p;
pd[2] = (uint)p >> 16;
asm volatile("lgdt (%0)" : : "g" (pd));
}
struct gatedesc;
static __inline void
lidt(struct gatedesc *p, int size)
{
2006-07-20 09:07:53 +00:00
volatile ushort pd[3];
pd[0] = size-1;
pd[1] = (uint)p;
pd[2] = (uint)p >> 16;
asm volatile("lidt (%0)" : : "g" (pd));
2006-06-12 15:22:12 +00:00
}
static __inline void
2006-07-20 09:07:53 +00:00
ltr(ushort sel)
2006-06-12 15:22:12 +00:00
{
__asm __volatile("ltr %0" : : "r" (sel));
}
2006-07-20 09:07:53 +00:00
static __inline uint
2006-06-12 15:22:12 +00:00
read_eflags(void)
{
2006-07-20 09:07:53 +00:00
uint eflags;
2006-06-12 15:22:12 +00:00
__asm __volatile("pushfl; popl %0" : "=r" (eflags));
return eflags;
}
static __inline void
2006-07-20 09:07:53 +00:00
write_eflags(uint eflags)
2006-06-12 15:22:12 +00:00
{
__asm __volatile("pushl %0; popfl" : : "r" (eflags));
}
static __inline void
2006-07-20 09:07:53 +00:00
cpuid(uint info, uint *eaxp, uint *ebxp, uint *ecxp, uint *edxp)
2006-06-12 15:22:12 +00:00
{
2006-07-20 09:07:53 +00:00
uint eax, ebx, ecx, edx;
2006-06-12 15:22:12 +00:00
asm volatile("cpuid"
: "=a" (eax), "=b" (ebx), "=c" (ecx), "=d" (edx)
: "a" (info));
if (eaxp)
*eaxp = eax;
if (ebxp)
*ebxp = ebx;
if (ecxp)
*ecxp = ecx;
if (edxp)
*edxp = edx;
}
2006-07-20 09:07:53 +00:00
static __inline uint
cmpxchg(uint oldval, uint newval, volatile uint* lock_addr)
{
2006-07-20 09:07:53 +00:00
uint result;
__asm__ __volatile__(
"lock; cmpxchgl %2, %0"
:"+m" (*lock_addr), "=a" (result) : "r"(newval), "1"(oldval) : "cc"
);
return result;
}
static __inline void
cli(void)
{
__asm__ volatile("cli");
}
static __inline void
sti(void)
{
__asm__ volatile("sti");
}
struct trapframe {
2006-06-12 15:22:12 +00:00
/* registers as pushed by pusha */
2006-07-20 09:07:53 +00:00
uint edi;
uint esi;
uint ebp;
uint oesp; /* Useless */
uint ebx;
uint edx;
uint ecx;
uint eax;
2006-07-17 01:36:39 +00:00
/* rest of trap frame */
2006-07-20 09:07:53 +00:00
ushort es;
ushort padding1;
ushort ds;
ushort padding2;
uint trapno;
2006-06-12 15:22:12 +00:00
/* below here defined by x86 hardware */
2006-07-20 09:07:53 +00:00
uint err;
uint eip;
ushort cs;
ushort padding3;
uint eflags;
2006-06-12 15:22:12 +00:00
/* below here only when crossing rings, such as from user to kernel */
2006-07-20 09:07:53 +00:00
uint esp;
ushort ss;
ushort padding4;
2006-06-12 15:22:12 +00:00
};