⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 io.h

📁 open source bios with linux platform, very good and can be reused.
💻 H
字号:
#ifndef _ASM_IO_H#define _ASM_IO_H#include "asm/types.h"extern unsigned int va_shift; // Set in entry.Sextern char _start, _data, _heap, _eheap, _stack, _estack, _end,    _vmem, _evmem,_iomem; // Defined in ldscriptstatic inline unsigned longva2pa(unsigned long va){    if ((va >= (unsigned long)&_start) &&        (va < (unsigned long)&_end))        return va - va_shift;    else        return va;}static inline unsigned longpa2va(unsigned long pa){    if ((pa + va_shift >= (unsigned long)&_start) &&        (pa + va_shift < (unsigned long)&_end))        return pa + va_shift;    else        return pa;}// XXX check use and merge#define phys_to_virt(phys) ((void *) ((unsigned long) (phys)))#define virt_to_phys(virt) ((unsigned long) (virt))struct mem;void mem_init(struct mem *t, char *begin, char *limit);void *mem_alloc(struct mem *t, int size, int align);void *mem_zalloc(struct mem *t, int size, int align);int map_page(unsigned long va, unsigned long epa, int type);void *map_io(unsigned pa, int size);void ob_init_mmu(unsigned long bus, unsigned long base);void init_mmu_swift(unsigned long base);void *dvma_alloc(int size, unsigned int *pphys);#ifndef BOOTSTRAP#ifndef _IO_BASE#define _IO_BASE	0#endif/* * The insw/outsw/insl/outsl macros don't do byte-swapping. * They are only used in practice for transferring buffers which * are arrays of bytes, and byte-swapping is not appropriate in * that case.  - paulus */#define insw(port, buf, ns)	_insw_ns((uint16_t *)((port)+_IO_BASE), (buf), (ns))#define outsw(port, buf, ns)	_outsw_ns((uint16_t *)((port)+_IO_BASE), (buf), (ns))#define inb(port)		in_8((uint8_t *)((port)+_IO_BASE))#define outb(val, port)		out_8((uint8_t *)((port)+_IO_BASE), (val))#define inw(port)		in_le16((uint16_t *)((port)+_IO_BASE))#define outw(val, port)		out_le16((uint16_t *)((port)+_IO_BASE), (val))#define inl(port)		in_le32((uint32_t *)((port)+_IO_BASE))#define outl(val, port)		out_le32((uint32_t *)((port)+_IO_BASE), (val))/* * 8, 16 and 32 bit, big and little endian I/O operations, with barrier. */static inline int in_8(volatile unsigned char *addr){    int ret;    __asm__ __volatile__("lduba [%1] 0x20, %0\n\t"                         "stbar\n\t"                         :"=r"(ret):"r"(addr):"memory");    return ret;}static inline void out_8(volatile unsigned char *addr, int val){    __asm__ __volatile__("stba %0, [%1] 0x20\n\t"                         "stbar\n\t"                         : : "r"(val), "r"(addr):"memory");}static inline int in_le16(volatile unsigned short *addr){    int ret;    // XXX    __asm__ __volatile__("lduha [%1] 0x20, %0\n\t"                         "stbar\n\t"                         :"=r"(ret):"r"(addr):"memory");    return ret;}static inline int in_be16(volatile unsigned short *addr){    int ret;    __asm__ __volatile__("lduha [%1] 0x20, %0\n\t"                         "stbar\n\t"                         :"=r"(ret):"r"(addr):"memory");    return ret;}static inline void out_le16(volatile unsigned short *addr, int val){    // XXX    __asm__ __volatile__("stha %0, [%1] 0x20\n\t"                         "stbar\n\t"                         : : "r"(val), "r"(addr):"memory");}static inline void out_be16(volatile unsigned short *addr, int val){    __asm__ __volatile__("stha %0, [%1] 0x20\n\t"                         "stbar\n\t"                         : : "r"(val), "r"(addr):"memory");}static inline unsigned in_le32(volatile unsigned *addr){    unsigned ret;    // XXX    __asm__ __volatile__("lda [%1] 0x20, %0\n\t"                         "stbar\n\t"                         :"=r"(ret):"r"(addr):"memory");    return ret;}static inline unsigned in_be32(volatile unsigned *addr){    unsigned ret;    __asm__ __volatile__("lda [%1] 0x20, %0\n\t"                         "stbar\n\t"                         :"=r"(ret):"r"(addr):"memory");    return ret;}static inline void out_le32(volatile unsigned *addr, int val){    // XXX    __asm__ __volatile__("sta %0, [%1] 0x20\n\t"                         "stbar\n\t"                         : : "r"(val), "r"(addr):"memory");}static inline void out_be32(volatile unsigned *addr, int val){    __asm__ __volatile__("sta %0, [%1] 0x20\n\t"                         "stbar\n\t"                         : : "r"(val), "r"(addr):"memory");}static inline void _insw_ns(volatile uint16_t * port, void *buf, int ns){	uint16_t *b = (uint16_t *) buf;	while (ns > 0) {		*b++ = in_le16(port);		ns--;	}}static inline void _outsw_ns(volatile uint16_t * port, const void *buf,			     int ns){	uint16_t *b = (uint16_t *) buf;	while (ns > 0) {		out_le16(port, *b++);		ns--;	}}static inline void _insw(volatile uint16_t * port, void *buf, int ns){	uint16_t *b = (uint16_t *) buf;	while (ns > 0) {		*b++ = in_be16(port);		ns--;	}}static inline void _outsw(volatile uint16_t * port, const void *buf,			  int ns){	uint16_t *b = (uint16_t *) buf;	while (ns > 0) {		out_be16(port, *b++);		ns--;	}}#else /* BOOTSTRAP */#ifdef FCOMPILER#define inb(reg) ((u8)0xff)#define inw(reg) ((u16)0xffff)#define inl(reg) ((u32)0xffffffff)#define outb(reg, val) do{} while(0)#define outw(reg, val) do{} while(0)#define outl(reg, val) do{} while(0)#elseextern u8 inb(u32 reg);extern u16 inw(u32 reg);extern u32 inl(u32 reg);extern void insw(u32 reg, void *addr, unsigned long count);extern void outb(u32 reg, u8 val);extern void outw(u32 reg, u16 val);extern void outl(u32 reg, u32 val);extern void outsw(u32 reg, const void *addr, unsigned long count);#endif#endif#endif /* _ASM_IO_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -