vserver 2.0 rc7
[linux-2.6.git] / include / asm-arm / arch-s3c2410 / regs-iis.h
1 /* linux/include/asm/arch-s3c2410/regs-iis.h
2  *
3  * Copyright (c) 2003 Simtec Electronics <linux@simtec.co.uk>
4  *                    http://www.simtec.co.uk/products/SWLINUX/
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  *
10  * S3C2410 IIS register definition
11  *
12  *  Changelog:
13  *    19-06-2003     BJD     Created file
14  *    26-06-2003     BJD     Finished off definitions for register addresses
15  *    12-03-2004     BJD     Updated include protection
16  *    07-03-2005     BJD     Added FIFO size flags and S3C2440 MPLL
17  *    05-04-2005     LCVR    Added IISFCON definitions for the S3C2400
18  */
19
20 #ifndef __ASM_ARCH_REGS_IIS_H
21 #define __ASM_ARCH_REGS_IIS_H
22
23 #define S3C2410_IISCON   (0x00)
24
25 #define S3C2440_IISCON_MPLL       (1<<9)
26 #define S3C2410_IISCON_LRINDEX    (1<<8)
27 #define S3C2410_IISCON_TXFIFORDY  (1<<7)
28 #define S3C2410_IISCON_RXFIFORDY  (1<<6)
29 #define S3C2410_IISCON_TXDMAEN    (1<<5)
30 #define S3C2410_IISCON_RXDMAEN    (1<<4)
31 #define S3C2410_IISCON_TXIDLE     (1<<3)
32 #define S3C2410_IISCON_RXIDLE     (1<<2)
33 #define S3C2410_IISCON_IISEN      (1<<0)
34
35 #define S3C2410_IISMOD   (0x04)
36
37 #define S3C2410_IISMOD_SLAVE      (1<<8)
38 #define S3C2410_IISMOD_NOXFER     (0<<6)
39 #define S3C2410_IISMOD_RXMODE     (1<<6)
40 #define S3C2410_IISMOD_TXMODE     (2<<6)
41 #define S3C2410_IISMOD_TXRXMODE   (3<<6)
42 #define S3C2410_IISMOD_LR_LLOW    (0<<5)
43 #define S3C2410_IISMOD_LR_RLOW    (1<<5)
44 #define S3C2410_IISMOD_IIS        (0<<4)
45 #define S3C2410_IISMOD_MSB        (1<<4)
46 #define S3C2410_IISMOD_8BIT       (0<<3)
47 #define S3C2410_IISMOD_16BIT      (1<<3)
48 #define S3C2410_IISMOD_BITMASK    (1<<3)
49 #define S3C2410_IISMOD_256FS      (0<<1)
50 #define S3C2410_IISMOD_384FS      (1<<1)
51 #define S3C2410_IISMOD_16FS       (0<<0)
52 #define S3C2410_IISMOD_32FS       (1<<0)
53 #define S3C2410_IISMOD_48FS       (2<<0)
54
55 #define S3C2410_IISPSR          (0x08)
56 #define S3C2410_IISPSR_INTMASK  (31<<5)
57 #define S3C2410_IISPSR_INTSHIFT (5)
58 #define S3C2410_IISPSR_EXTMASK  (31<<0)
59 #define S3C2410_IISPSR_EXTSHFIT (0)
60
61 #define S3C2410_IISFCON  (0x0c)
62
63 #define S3C2410_IISFCON_TXDMA     (1<<15)
64 #define S3C2410_IISFCON_RXDMA     (1<<14)
65 #define S3C2410_IISFCON_TXENABLE  (1<<13)
66 #define S3C2410_IISFCON_RXENABLE  (1<<12)
67 #define S3C2410_IISFCON_TXMASK    (0x3f << 6)
68 #define S3C2410_IISFCON_TXSHIFT   (6)
69 #define S3C2410_IISFCON_RXMASK    (0x3f)
70 #define S3C2410_IISFCON_RXSHIFT   (0)
71
72 #define S3C2400_IISFCON_TXDMA     (1<<11)
73 #define S3C2400_IISFCON_RXDMA     (1<<10)
74 #define S3C2400_IISFCON_TXENABLE  (1<<9)
75 #define S3C2400_IISFCON_RXENABLE  (1<<8)
76 #define S3C2400_IISFCON_TXMASK    (0x07 << 4)
77 #define S3C2400_IISFCON_TXSHIFT   (4)
78 #define S3C2400_IISFCON_RXMASK    (0x07)
79 #define S3C2400_IISFCON_RXSHIFT   (0)
80
81 #define S3C2410_IISFIFO  (0x10)
82 #endif /* __ASM_ARCH_REGS_IIS_H */