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

Subversion Repositories or1k

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

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
#ifndef __ALPHA_IO_H
2
#define __ALPHA_IO_H
3
 
4
/* We don't use IO slowdowns on the Alpha, but.. */
5
#define __SLOW_DOWN_IO  do { } while (0)
6
#define SLOW_DOWN_IO    do { } while (0)
7
 
8
/*
9
 * Virtual -> physical identity mapping starts at this offset
10
 */
11
#ifdef USE_48_BIT_KSEG
12
#define IDENT_ADDR     0xffff800000000000
13
#else
14
#define IDENT_ADDR     0xfffffc0000000000
15
#endif
16
 
17
#ifdef __KERNEL__
18
#include <linux/config.h>
19
#include <linux/kernel.h>
20
#include <asm/system.h>
21
#include <asm/machvec.h>
22
#include <asm/hwrpb.h>
23
 
24
/*
25
 * We try to avoid hae updates (thus the cache), but when we
26
 * do need to update the hae, we need to do it atomically, so
27
 * that any interrupts wouldn't get confused with the hae
28
 * register not being up-to-date with respect to the hardware
29
 * value.
30
 */
31
static inline void __set_hae(unsigned long new_hae)
32
{
33
        unsigned long flags;
34
        __save_and_cli(flags);
35
 
36
        alpha_mv.hae_cache = new_hae;
37
        *alpha_mv.hae_register = new_hae;
38
        mb();
39
        /* Re-read to make sure it was written.  */
40
        new_hae = *alpha_mv.hae_register;
41
 
42
        __restore_flags(flags);
43
}
44
 
45
static inline void set_hae(unsigned long new_hae)
46
{
47
        if (new_hae != alpha_mv.hae_cache)
48
                __set_hae(new_hae);
49
}
50
 
51
/*
52
 * Change virtual addresses to physical addresses and vv.
53
 */
54
#ifdef USE_48_BIT_KSEG
55
static inline unsigned long virt_to_phys(void *address)
56
{
57
        return (unsigned long)address - IDENT_ADDR;
58
}
59
 
60
static inline void * phys_to_virt(unsigned long address)
61
{
62
        return (void *) (address + IDENT_ADDR);
63
}
64
#else
65
static inline unsigned long virt_to_phys(void *address)
66
{
67
        unsigned long phys = (unsigned long)address;
68
 
69
        /* Sign-extend from bit 41.  */
70
        phys <<= (64 - 41);
71
        phys = (long)phys >> (64 - 41);
72
 
73
        /* Crop to the physical address width of the processor.  */
74
        phys &= (1ul << hwrpb->pa_bits) - 1;
75
 
76
        return phys;
77
}
78
 
79
static inline void * phys_to_virt(unsigned long address)
80
{
81
        return (void *)(IDENT_ADDR + (address & ((1ul << 41) - 1)));
82
}
83
#endif
84
 
85
#define page_to_phys(page)      PAGE_TO_PA(page)
86
 
87
/*
88
 * Change addresses as seen by the kernel (virtual) to addresses as
89
 * seen by a device (bus), and vice versa.
90
 *
91
 * Note that this only works for a limited range of kernel addresses,
92
 * and very well may not span all memory.  Consider this interface
93
 * deprecated in favour of the mapping functions in <asm/pci.h>.
94
 */
95
extern unsigned long __direct_map_base;
96
extern unsigned long __direct_map_size;
97
 
98
static inline unsigned long virt_to_bus(void *address)
99
{
100
        unsigned long phys = virt_to_phys(address);
101
        unsigned long bus = phys + __direct_map_base;
102
        return phys <= __direct_map_size ? bus : 0;
103
}
104
 
105
static inline void *bus_to_virt(unsigned long address)
106
{
107
        void *virt;
108
 
109
        /* This check is a sanity check but also ensures that bus address 0
110
           maps to virtual address 0 which is useful to detect null pointers
111
           (the NCR driver is much simpler if NULL pointers are preserved).  */
112
        address -= __direct_map_base;
113
        virt = phys_to_virt(address);
114
        return (long)address <= 0 ? NULL : virt;
115
}
116
 
117
#else /* !__KERNEL__ */
118
 
119
/*
120
 * Define actual functions in private name-space so it's easier to
121
 * accommodate things like XFree or svgalib that like to define their
122
 * own versions of inb etc.
123
 */
124
extern void __sethae (unsigned long addr);      /* syscall */
125
extern void _sethae (unsigned long addr);       /* cached version */
126
 
127
#endif /* !__KERNEL__ */
128
 
129
/*
130
 * There are different chipsets to interface the Alpha CPUs to the world.
131
 */
132
 
133
#ifdef __KERNEL__
134
#ifdef CONFIG_ALPHA_GENERIC
135
 
136
/* In a generic kernel, we always go through the machine vector.  */
137
 
138
# define __inb(p)       alpha_mv.mv_inb((unsigned long)(p))
139
# define __inw(p)       alpha_mv.mv_inw((unsigned long)(p))
140
# define __inl(p)       alpha_mv.mv_inl((unsigned long)(p))
141
# define __outb(x,p)    alpha_mv.mv_outb((x),(unsigned long)(p))
142
# define __outw(x,p)    alpha_mv.mv_outw((x),(unsigned long)(p))
143
# define __outl(x,p)    alpha_mv.mv_outl((x),(unsigned long)(p))
144
 
145
# define __readb(a)     alpha_mv.mv_readb((unsigned long)(a))
146
# define __readw(a)     alpha_mv.mv_readw((unsigned long)(a))
147
# define __readl(a)     alpha_mv.mv_readl((unsigned long)(a))
148
# define __readq(a)     alpha_mv.mv_readq((unsigned long)(a))
149
# define __writeb(v,a)  alpha_mv.mv_writeb((v),(unsigned long)(a))
150
# define __writew(v,a)  alpha_mv.mv_writew((v),(unsigned long)(a))
151
# define __writel(v,a)  alpha_mv.mv_writel((v),(unsigned long)(a))
152
# define __writeq(v,a)  alpha_mv.mv_writeq((v),(unsigned long)(a))
153
 
154
# define __ioremap(a,s) alpha_mv.mv_ioremap((unsigned long)(a),(s))
155
# define __iounmap(a)   alpha_mv.mv_iounmap((unsigned long)(a))
156
# define __is_ioaddr(a) alpha_mv.mv_is_ioaddr((unsigned long)(a))
157
 
158
# define inb            __inb
159
# define inw            __inw
160
# define inl            __inl
161
# define outb           __outb
162
# define outw           __outw
163
# define outl           __outl
164
 
165
# define __raw_readb    __readb
166
# define __raw_readw    __readw
167
# define __raw_readl    __readl
168
# define __raw_readq    __readq
169
# define __raw_writeb   __writeb
170
# define __raw_writew   __writew
171
# define __raw_writel   __writel
172
# define __raw_writeq   __writeq
173
 
174
#else
175
 
176
/* Control how and what gets defined within the core logic headers.  */
177
#define __WANT_IO_DEF
178
 
179
#if defined(CONFIG_ALPHA_APECS)
180
# include <asm/core_apecs.h>
181
#elif defined(CONFIG_ALPHA_CIA)
182
# include <asm/core_cia.h>
183
#elif defined(CONFIG_ALPHA_IRONGATE)
184
# include <asm/core_irongate.h>
185
#elif defined(CONFIG_ALPHA_JENSEN)
186
# include <asm/jensen.h>
187
#elif defined(CONFIG_ALPHA_LCA)
188
# include <asm/core_lca.h>
189
#elif defined(CONFIG_ALPHA_MARVEL)
190
# include <asm/core_marvel.h>
191
#elif defined(CONFIG_ALPHA_MCPCIA)
192
# include <asm/core_mcpcia.h>
193
#elif defined(CONFIG_ALPHA_POLARIS)
194
# include <asm/core_polaris.h>
195
#elif defined(CONFIG_ALPHA_T2)
196
# include <asm/core_t2.h>
197
#elif defined(CONFIG_ALPHA_TSUNAMI)
198
# include <asm/core_tsunami.h>
199
#elif defined(CONFIG_ALPHA_TITAN)
200
# include <asm/core_titan.h>
201
#elif defined(CONFIG_ALPHA_WILDFIRE)
202
# include <asm/core_wildfire.h>
203
#else
204
#error "What system is this?"
205
#endif
206
 
207
#undef __WANT_IO_DEF
208
 
209
#endif /* GENERIC */
210
#endif /* __KERNEL__ */
211
 
212
/*
213
 * The convention used for inb/outb etc. is that names starting with
214
 * two underscores are the inline versions, names starting with a
215
 * single underscore are proper functions, and names starting with a
216
 * letter are macros that map in some way to inline or proper function
217
 * versions.  Not all that pretty, but before you change it, be sure
218
 * to convince yourself that it won't break anything (in particular
219
 * module support).
220
 */
221
extern u8               _inb (unsigned long port);
222
extern u16              _inw (unsigned long port);
223
extern u32              _inl (unsigned long port);
224
extern void             _outb (u8 b,unsigned long port);
225
extern void             _outw (u16 w,unsigned long port);
226
extern void             _outl (u32 l,unsigned long port);
227
extern u8               _readb(unsigned long addr);
228
extern u16              _readw(unsigned long addr);
229
extern u32              _readl(unsigned long addr);
230
extern u64              _readq(unsigned long addr);
231
extern void             _writeb(u8 b, unsigned long addr);
232
extern void             _writew(u16 b, unsigned long addr);
233
extern void             _writel(u32 b, unsigned long addr);
234
extern void             _writeq(u64 b, unsigned long addr);
235
 
236
#ifdef __KERNEL__
237
/*
238
 * The platform header files may define some of these macros to use
239
 * the inlined versions where appropriate.  These macros may also be
240
 * redefined by userlevel programs.
241
 */
242
#ifndef inb
243
# define inb(p)         _inb(p)
244
#endif
245
#ifndef inw
246
# define inw(p)         _inw(p)
247
#endif
248
#ifndef inl
249
# define inl(p)         _inl(p)
250
#endif
251
#ifndef outb
252
# define outb(b,p)      _outb((b),(p))
253
#endif
254
#ifndef outw
255
# define outw(w,p)      _outw((w),(p))
256
#endif
257
#ifndef outl
258
# define outl(l,p)      _outl((l),(p))
259
#endif
260
 
261
#ifndef inb_p
262
# define inb_p          inb
263
#endif
264
#ifndef inw_p
265
# define inw_p          inw
266
#endif
267
#ifndef inl_p
268
# define inl_p          inl
269
#endif
270
 
271
#ifndef outb_p
272
# define outb_p         outb
273
#endif
274
#ifndef outw_p
275
# define outw_p         outw
276
#endif
277
#ifndef outl_p
278
# define outl_p         outl
279
#endif
280
 
281
#define IO_SPACE_LIMIT 0xffff
282
 
283
#else 
284
 
285
/* Userspace declarations.  Kill in 2.5. */
286
 
287
extern unsigned int     inb(unsigned long port);
288
extern unsigned int     inw(unsigned long port);
289
extern unsigned int     inl(unsigned long port);
290
extern void             outb(unsigned char b,unsigned long port);
291
extern void             outw(unsigned short w,unsigned long port);
292
extern void             outl(unsigned int l,unsigned long port);
293
extern unsigned long    readb(unsigned long addr);
294
extern unsigned long    readw(unsigned long addr);
295
extern unsigned long    readl(unsigned long addr);
296
extern void             writeb(unsigned char b, unsigned long addr);
297
extern void             writew(unsigned short b, unsigned long addr);
298
extern void             writel(unsigned int b, unsigned long addr);
299
 
300
#endif /* __KERNEL__ */
301
 
302
#ifdef __KERNEL__
303
 
304
/*
305
 * On Alpha, we have the whole of I/O space mapped at all times, but
306
 * at odd and sometimes discontinuous addresses.  Note that the
307
 * discontinuities are all across busses, so we need not care for that
308
 * for any one device.
309
 *
310
 * The DRM drivers need to be able to map contiguously a (potentially)
311
 * discontiguous set of I/O pages. This set of pages is scatter-gather
312
 * mapped contiguously from the perspective of the bus, but we can't
313
 * directly access DMA addresses from the CPU, these addresses need to
314
 * have a real ioremap. Therefore, iounmap and the size argument to
315
 * ioremap are needed to give the platforms the ability to fully implement
316
 * ioremap.
317
 *
318
 * Map the I/O space address into the kernel's virtual address space.
319
 */
320
static inline void * ioremap(unsigned long offset, unsigned long size)
321
{
322
        return (void *) __ioremap(offset, size);
323
}
324
 
325
static inline void iounmap(void *addr)
326
{
327
        __iounmap(addr);
328
}
329
 
330
static inline void * ioremap_nocache(unsigned long offset, unsigned long size)
331
{
332
        return ioremap(offset, size);
333
}
334
 
335
/* Indirect back to the macros provided.  */
336
 
337
extern u8               ___raw_readb(unsigned long addr);
338
extern u16              ___raw_readw(unsigned long addr);
339
extern u32              ___raw_readl(unsigned long addr);
340
extern u64              ___raw_readq(unsigned long addr);
341
extern void             ___raw_writeb(u8 b, unsigned long addr);
342
extern void             ___raw_writew(u16 b, unsigned long addr);
343
extern void             ___raw_writel(u32 b, unsigned long addr);
344
extern void             ___raw_writeq(u64 b, unsigned long addr);
345
 
346
#ifdef __raw_readb
347
# define readb(a)       ({ u8 r_ = __raw_readb(a); mb(); r_; })
348
#endif
349
#ifdef __raw_readw
350
# define readw(a)       ({ u16 r_ = __raw_readw(a); mb(); r_; })
351
#endif
352
#ifdef __raw_readl
353
# define readl(a)       ({ u32 r_ = __raw_readl(a); mb(); r_; })
354
#endif
355
#ifdef __raw_readq
356
# define readq(a)       ({ u64 r_ = __raw_readq(a); mb(); r_; })
357
#endif
358
 
359
#ifdef __raw_writeb
360
# define writeb(v,a)    ({ __raw_writeb((v),(a)); mb(); })
361
#endif
362
#ifdef __raw_writew
363
# define writew(v,a)    ({ __raw_writew((v),(a)); mb(); })
364
#endif
365
#ifdef __raw_writel
366
# define writel(v,a)    ({ __raw_writel((v),(a)); mb(); })
367
#endif
368
#ifdef __raw_writeq
369
# define writeq(v,a)    ({ __raw_writeq((v),(a)); mb(); })
370
#endif
371
 
372
#ifndef __raw_readb
373
# define __raw_readb(a) ___raw_readb((unsigned long)(a))
374
#endif
375
#ifndef __raw_readw
376
# define __raw_readw(a) ___raw_readw((unsigned long)(a))
377
#endif
378
#ifndef __raw_readl
379
# define __raw_readl(a) ___raw_readl((unsigned long)(a))
380
#endif
381
#ifndef __raw_readq
382
# define __raw_readq(a) ___raw_readq((unsigned long)(a))
383
#endif
384
 
385
#ifndef __raw_writeb
386
# define __raw_writeb(v,a)  ___raw_writeb((v),(unsigned long)(a))
387
#endif
388
#ifndef __raw_writew
389
# define __raw_writew(v,a)  ___raw_writew((v),(unsigned long)(a))
390
#endif
391
#ifndef __raw_writel
392
# define __raw_writel(v,a)  ___raw_writel((v),(unsigned long)(a))
393
#endif
394
#ifndef __raw_writeq
395
# define __raw_writeq(v,a)  ___raw_writeq((v),(unsigned long)(a))
396
#endif
397
 
398
#ifndef readb
399
# define readb(a)       _readb((unsigned long)(a))
400
#endif
401
#ifndef readw
402
# define readw(a)       _readw((unsigned long)(a))
403
#endif
404
#ifndef readl
405
# define readl(a)       _readl((unsigned long)(a))
406
#endif
407
#ifndef readq
408
# define readq(a)       _readq((unsigned long)(a))
409
#endif
410
 
411
#ifndef writeb
412
# define writeb(v,a)    _writeb((v),(unsigned long)(a))
413
#endif
414
#ifndef writew
415
# define writew(v,a)    _writew((v),(unsigned long)(a))
416
#endif
417
#ifndef writel
418
# define writel(v,a)    _writel((v),(unsigned long)(a))
419
#endif
420
#ifndef writeq
421
# define writeq(v,a)    _writeq((v),(unsigned long)(a))
422
#endif
423
 
424
/*
425
 * String version of IO memory access ops:
426
 */
427
extern void _memcpy_fromio(void *, unsigned long, long);
428
extern void _memcpy_toio(unsigned long, const void *, long);
429
extern void _memset_c_io(unsigned long, unsigned long, long);
430
 
431
#define memcpy_fromio(to,from,len) \
432
  _memcpy_fromio((to),(unsigned long)(from),(len))
433
#define memcpy_toio(to,from,len) \
434
  _memcpy_toio((unsigned long)(to),(from),(len))
435
#define memset_io(addr,c,len) \
436
  _memset_c_io((unsigned long)(addr),0x0101010101010101UL*(u8)(c),(len))
437
 
438
#define __HAVE_ARCH_MEMSETW_IO
439
#define memsetw_io(addr,c,len) \
440
  _memset_c_io((unsigned long)(addr),0x0001000100010001UL*(u16)(c),(len))
441
 
442
/*
443
 * String versions of in/out ops:
444
 */
445
extern void insb (unsigned long port, void *dst, unsigned long count);
446
extern void insw (unsigned long port, void *dst, unsigned long count);
447
extern void insl (unsigned long port, void *dst, unsigned long count);
448
extern void outsb (unsigned long port, const void *src, unsigned long count);
449
extern void outsw (unsigned long port, const void *src, unsigned long count);
450
extern void outsl (unsigned long port, const void *src, unsigned long count);
451
 
452
/*
453
 * XXX - We don't have csum_partial_copy_fromio() yet, so we cheat here and
454
 * just copy it. The net code will then do the checksum later. Presently
455
 * only used by some shared memory 8390 Ethernet cards anyway.
456
 */
457
 
458
#define eth_io_copy_and_sum(skb,src,len,unused) \
459
  memcpy_fromio((skb)->data,(src),(len))
460
#define isa_eth_io_copy_and_sum(skb,src,len,unused) \
461
  isa_memcpy_fromio((skb)->data,(src),(len))
462
 
463
static inline int
464
check_signature(unsigned long io_addr, const unsigned char *signature,
465
                int length)
466
{
467
        int retval = 0;
468
        do {
469
                if (readb(io_addr) != *signature)
470
                        goto out;
471
                io_addr++;
472
                signature++;
473
                length--;
474
        } while (length);
475
        retval = 1;
476
out:
477
        return retval;
478
}
479
 
480
 
481
/*
482
 * ISA space is mapped to some machine-specific location on Alpha.
483
 * Call into the existing hooks to get the address translated.
484
 */
485
#define isa_readb(a)                    readb(__ioremap((a),1))
486
#define isa_readw(a)                    readw(__ioremap((a),2))
487
#define isa_readl(a)                    readl(__ioremap((a),4))
488
#define isa_writeb(b,a)                 writeb((b),__ioremap((a),1))
489
#define isa_writew(w,a)                 writew((w),__ioremap((a),2))
490
#define isa_writel(l,a)                 writel((l),__ioremap((a),4))
491
#define isa_memset_io(a,b,c)            memset_io(__ioremap((a),(c)),(b),(c))
492
#define isa_memcpy_fromio(a,b,c)        memcpy_fromio((a),__ioremap((b),(c)),(c))
493
#define isa_memcpy_toio(a,b,c)          memcpy_toio(__ioremap((a),(c)),(b),(c))
494
 
495
static inline int
496
isa_check_signature(unsigned long io_addr, const unsigned char *signature,
497
                int length)
498
{
499
        int retval = 0;
500
        do {
501
                if (isa_readb(io_addr) != *signature)
502
                        goto out;
503
                io_addr++;
504
                signature++;
505
                length--;
506
        } while (length);
507
        retval = 1;
508
out:
509
        return retval;
510
}
511
 
512
 
513
/*
514
 * The Alpha Jensen hardware for some rather strange reason puts
515
 * the RTC clock at 0x170 instead of 0x70. Probably due to some
516
 * misguided idea about using 0x70 for NMI stuff.
517
 *
518
 * These defines will override the defaults when doing RTC queries
519
 */
520
 
521
#ifdef CONFIG_ALPHA_GENERIC
522
# define RTC_PORT(x)    ((x) + alpha_mv.rtc_port)
523
#else
524
# ifdef CONFIG_ALPHA_JENSEN
525
#  define RTC_PORT(x)   (0x170+(x))
526
# else
527
#  define RTC_PORT(x)   (0x70 + (x))
528
# endif
529
#endif
530
#define RTC_ALWAYS_BCD  0
531
 
532
/* Nothing to do */
533
 
534
#define dma_cache_inv(_start,_size)             do { } while (0)
535
#define dma_cache_wback(_start,_size)           do { } while (0)
536
#define dma_cache_wback_inv(_start,_size)       do { } while (0)
537
 
538
#endif /* __KERNEL__ */
539
 
540
#endif /* __ALPHA_IO_H */

powered by: WebSVN 2.1.0

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