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

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [include/] [asm-or32/] [io.h] - Blame information for rev 1774

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1276 phoenix
#ifndef _OR32_IO_H
2
#define _OR32_IO_H
3
 
4
#include <asm/page.h>
5
#include <linux/config.h>
6
 
7
 
8
/*
9
 * Change virtual addresses to physical addresses and vv.
10
 */
11
 
12
static inline unsigned long virt_to_phys(volatile void * address)
13
{
14
        return __pa(address);
15
}
16
 
17
static inline void * phys_to_virt(unsigned long address)
18
{
19
        return __va(address);
20
}
21
 
22
extern void * __ioremap(unsigned long offset, unsigned long size, unsigned long flags);
23
 
24
extern inline void * ioremap (unsigned long offset, unsigned long size)
25
{
26
        return __ioremap(offset, size, 0);
27
}
28
 
29
#define page_to_phys(page)      ((page - mem_map) << PAGE_SHIFT)
30
 
31
/*
32
 * IO bus memory addresses are also 1:1 with the physical address
33
 */
34
#define virt_to_bus virt_to_phys
35
#define bus_to_virt phys_to_virt
36
 
37
/*
38
 * readX/writeX() are used to access memory mapped devices. On some
39
 * architectures the memory mapped IO stuff needs to be accessed
40
 * differently. On the or32 architecture, we just read/write the
41
 * memory location directly.
42
 */
43
#define readb(addr) (*(volatile unsigned char *) (addr))
44
#define readw(addr) (*(volatile unsigned short *) (addr))
45
#define readl(addr) (*(volatile unsigned int *) (addr))
46
 
47
#define writeb(b,addr) ((*(volatile unsigned char *) (addr)) = (b))
48
#define writew(b,addr) ((*(volatile unsigned short *) (addr)) = (b))
49
#define writel(b,addr) ((*(volatile unsigned int *) (addr)) = (b))
50
 
51
#define memset_io(a,b,c)        memset((void *)(a),(b),(c))
52
#define memcpy_fromio(a,b,c)    memcpy((a),(void *)(b),(c))
53
#define memcpy_toio(a,b,c)      memcpy((void *)(a),(b),(c))
54
 
55
/*
56
 * Again, or32 does not require mem IO specific function.
57
 */
58
 
59
#define eth_io_copy_and_sum(a,b,c,d)    eth_copy_and_sum((a),(void *)(b),(c),(d))
60
 
61
#define IO_BASE                 0x0
62
#define IO_SPACE_LIMIT          0xffffffff
63
 
64
#define inb(port)               (*(volatile unsigned char *) (port+IO_BASE))
65
#define outb(value,port)        ((*(volatile unsigned char *) (port+IO_BASE)) = (value))        
66
 
67
/*
68
 * __PHX__ TODO
69
 */
70
#define outw(x,y)
71
#define outl(x,y)
72
#define insb(x,y,z)
73
#define insw(x,y,z)
74
#define insl(x,y,z)
75
#define outsb(x,y,z)
76
#define outsw(x,y,z)
77
#define outsl(x,y,z)
78
 
79
#endif

powered by: WebSVN 2.1.0

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