OpenCores
URL https://opencores.org/ocsvn/or1k_soc_on_altera_embedded_dev_kit/or1k_soc_on_altera_embedded_dev_kit/trunk

Subversion Repositories or1k_soc_on_altera_embedded_dev_kit

[/] [or1k_soc_on_altera_embedded_dev_kit/] [trunk/] [linux-2.6/] [linux-2.6.24/] [include/] [asm-or32/] [io.h] - Rev 7

Compare with Previous | Blame | View Log

#ifndef _OR32_IO_H
#define _OR32_IO_H
 
#include <asm/page.h>   /* for __va, __pa */
 
 
/*
 * Change virtual addresses to physical addresses and vv.
 */
 
static inline unsigned long virt_to_phys(volatile void * address)
{
	return __pa(address);
}
 
static inline void * phys_to_virt(unsigned long address)
{
	return __va(address);
}
 
extern void * __ioremap(unsigned long offset, unsigned long size, unsigned long flags);
 
extern inline void * ioremap(unsigned long offset, unsigned long size)
{
	return __ioremap(offset, size, 0);
}
 
/* #define _PAGE_CI       0x002 */
extern inline void * ioremap_nocache(unsigned long offset, unsigned long size)
{
	return __ioremap(offset, size, 0x002);
}
 
extern void iounmap(void *addr);
 
#define page_to_phys(page)	((page - mem_map) << PAGE_SHIFT)
 
/*
 * IO bus memory addresses are also 1:1 with the physical address
 */
#define virt_to_bus virt_to_phys
#define bus_to_virt phys_to_virt
 
/*
 * readX/writeX() are used to access memory mapped devices. On some
 * architectures the memory mapped IO stuff needs to be accessed
 * differently. On the or32 architecture, we just read/write the
 * memory location directly.
 */
#define readb(addr) (*(volatile unsigned char *) (addr))
#define readw(addr) (*(volatile unsigned short *) (addr))
#define readl(addr) (*(volatile unsigned int *) (addr))
 
#define writeb(b,addr) ((*(volatile unsigned char *) (addr)) = (b))
#define writew(b,addr) ((*(volatile unsigned short *) (addr)) = (b))
#define writel(b,addr) ((*(volatile unsigned int *) (addr)) = (b))
#define __raw_writel writel /*RGD*/
 
#define memset_io(a,b,c)	memset((void *)(a),(b),(c))
#define memcpy_fromio(a,b,c)	memcpy((a),(void *)(b),(c))
#define memcpy_toio(a,b,c)	memcpy((void *)(a),(b),(c))
 
/*
 * Again, or32 does not require mem IO specific function.
 */
 
#define eth_io_copy_and_sum(a,b,c,d)	eth_copy_and_sum((a),(void *)(b),(c),(d))
 
#define IO_BASE			0x0
#define IO_SPACE_LIMIT 		0xffffffff
 
#define inb(port)		(*(volatile unsigned char *) (port+IO_BASE))
#define outb(value,port)	((*(volatile unsigned char *) (port+IO_BASE)) = (value))	
 
#define inb_p(port)             inb((port))
#define outb_p(val, port)       outb((val), (port))
 
/*
 * Convert a physical pointer to a virtual kernel pointer for /dev/mem
 * access
 */
#define xlate_dev_mem_ptr(p)	__va(p)
 
/*
 * Convert a virtual cached pointer to an uncached pointer
 */
#define xlate_dev_kmem_ptr(p)	p
 
 
/* Create a virtual mapping cookie for an IO port range */
extern void __iomem *ioport_map(unsigned long port, unsigned int nr);
extern void ioport_unmap(void __iomem *);
 
#endif
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.