📄 x86.h
字号:
#ifndef JOS_INC_X86_H#define JOS_INC_X86_H#include <inc/types.h>static __inline void breakpoint(void) __attribute__((always_inline));static __inline uint8_t inb(int port) __attribute__((always_inline));static __inline void insb(int port, void *addr, int cnt) __attribute__((always_inline));static __inline uint16_t inw(int port) __attribute__((always_inline));static __inline void insw(int port, void *addr, int cnt) __attribute__((always_inline));static __inline uint32_t inl(int port) __attribute__((always_inline));static __inline void insl(int port, void *addr, int cnt) __attribute__((always_inline));static __inline void outb(int port, uint8_t data) __attribute__((always_inline));static __inline void outsb(int port, const void *addr, int cnt) __attribute__((always_inline));static __inline void outw(int port, uint16_t data) __attribute__((always_inline));static __inline void outsw(int port, const void *addr, int cnt) __attribute__((always_inline));static __inline void outsl(int port, const void *addr, int cnt) __attribute__((always_inline));static __inline void outl(int port, uint32_t data) __attribute__((always_inline));static __inline void invlpg(void *addr) __attribute__((always_inline));static __inline void lidt(void *p) __attribute__((always_inline));static __inline void lldt(uint16_t sel) __attribute__((always_inline));static __inline void ltr(uint16_t sel) __attribute__((always_inline));static __inline void lcr0(uint32_t val) __attribute__((always_inline));static __inline uint32_t rcr0(void) __attribute__((always_inline));static __inline uint32_t rcr2(void) __attribute__((always_inline));static __inline void lcr3(uint32_t val) __attribute__((always_inline));static __inline uint32_t rcr3(void) __attribute__((always_inline));static __inline void lcr4(uint32_t val) __attribute__((always_inline));static __inline uint32_t rcr4(void) __attribute__((always_inline));static __inline void tlbflush(void) __attribute__((always_inline));static __inline uint32_t read_eflags(void) __attribute__((always_inline));static __inline void write_eflags(uint32_t eflags) __attribute__((always_inline));static __inline uint32_t read_ebp(void) __attribute__((always_inline));static __inline uint32_t read_esp(void) __attribute__((always_inline));static __inline void cpuid(uint32_t info, uint32_t *eaxp, uint32_t *ebxp, uint32_t *ecxp, uint32_t *edxp);static __inline uint64_t read_tsc(void) __attribute__((always_inline));static __inline voidbreakpoint(void){ __asm __volatile("int3");}static __inline uint8_tinb(int port){ uint8_t data; __asm __volatile("inb %w1,%0" : "=a" (data) : "d" (port)); return data;}static __inline voidinsb(int port, void *addr, int cnt){ __asm __volatile("cld\n\trepne\n\tinsb" : "=D" (addr), "=c" (cnt) : "d" (port), "0" (addr), "1" (cnt) : "memory", "cc");}static __inline uint16_tinw(int port){ uint16_t data; __asm __volatile("inw %w1,%0" : "=a" (data) : "d" (port)); return data;}static __inline voidinsw(int port, void *addr, int cnt){ __asm __volatile("cld\n\trepne\n\tinsw" : "=D" (addr), "=c" (cnt) : "d" (port), "0" (addr), "1" (cnt) : "memory", "cc");}static __inline uint32_tinl(int port){ uint32_t data; __asm __volatile("inl %w1,%0" : "=a" (data) : "d" (port)); return data;}static __inline voidinsl(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 voidoutb(int port, uint8_t data){ __asm __volatile("outb %0,%w1" : : "a" (data), "d" (port));}static __inline voidoutsb(int port, const void *addr, int cnt){ __asm __volatile("cld\n\trepne\n\toutsb" : "=S" (addr), "=c" (cnt) : "d" (port), "0" (addr), "1" (cnt) : "cc");}static __inline voidoutw(int port, uint16_t data){ __asm __volatile("outw %0,%w1" : : "a" (data), "d" (port));}static __inline voidoutsw(int port, const void *addr, int cnt){ __asm __volatile("cld\n\trepne\n\toutsw" : "=S" (addr), "=c" (cnt) : "d" (port), "0" (addr), "1" (cnt) : "cc");}static __inline voidoutsl(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");}static __inline voidoutl(int port, uint32_t data){ __asm __volatile("outl %0,%w1" : : "a" (data), "d" (port));}static __inline void invlpg(void *addr){ __asm __volatile("invlpg (%0)" : : "r" (addr) : "memory");} static __inline voidlidt(void *p){ __asm __volatile("lidt (%0)" : : "r" (p));}static __inline voidlldt(uint16_t sel){ __asm __volatile("lldt %0" : : "r" (sel));}static __inline voidltr(uint16_t sel){ __asm __volatile("ltr %0" : : "r" (sel));}static __inline voidlcr0(uint32_t val){ __asm __volatile("movl %0,%%cr0" : : "r" (val));}static __inline uint32_trcr0(void){ uint32_t val; __asm __volatile("movl %%cr0,%0" : "=r" (val)); return val;}static __inline uint32_trcr2(void){ uint32_t val; __asm __volatile("movl %%cr2,%0" : "=r" (val)); return val;}static __inline voidlcr3(uint32_t val){ __asm __volatile("movl %0,%%cr3" : : "r" (val));}static __inline uint32_trcr3(void){ uint32_t val; __asm __volatile("movl %%cr3,%0" : "=r" (val)); return val;}static __inline voidlcr4(uint32_t val){ __asm __volatile("movl %0,%%cr4" : : "r" (val));}static __inline uint32_trcr4(void){ uint32_t cr4; __asm __volatile("movl %%cr4,%0" : "=r" (cr4)); return cr4;}static __inline voidtlbflush(void){ uint32_t cr3; __asm __volatile("movl %%cr3,%0" : "=r" (cr3)); __asm __volatile("movl %0,%%cr3" : : "r" (cr3));}static __inline uint32_tread_eflags(void){ uint32_t eflags; __asm __volatile("pushfl; popl %0" : "=r" (eflags)); return eflags;}static __inline voidwrite_eflags(uint32_t eflags){ __asm __volatile("pushl %0; popfl" : : "r" (eflags));}static __inline uint32_tread_ebp(void){ uint32_t ebp; __asm __volatile("movl %%ebp,%0" : "=r" (ebp)); return ebp;}static __inline uint32_tread_esp(void){ uint32_t esp; __asm __volatile("movl %%esp,%0" : "=r" (esp)); return esp;}static __inline voidcpuid(uint32_t info, uint32_t *eaxp, uint32_t *ebxp, uint32_t *ecxp, uint32_t *edxp){ uint32_t eax, ebx, ecx, edx; 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;}static __inline uint64_tread_tsc(void){ uint64_t tsc; __asm __volatile("rdtsc" : "=A" (tsc)); return tsc;}#endif /* !JOS_INC_X86_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -