Merge remote-tracking branches 'asoc/topic/adau1977', 'asoc/topic/arizona', 'asoc...
[sfrench/cifs-2.6.git] / sound / isa / galaxy / azt2316.c
1 /*
2  * Aztech AZT2316 Driver
3  * Copyright (C) 2007,2010  Rene Herman
4  *
5  * This program is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation, either version 2 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
17  *
18  */
19
20 #define AZT2316
21
22 #define CRD_NAME "Aztech AZT2316"
23 #define DRV_NAME "AZT2316"
24 #define DEV_NAME "azt2316"
25
26 #define GALAXY_DSP_MAJOR                3
27 #define GALAXY_DSP_MINOR                1
28
29 #define GALAXY_CONFIG_SIZE              4
30
31 /*
32  * 32-bit config register
33  */
34
35 #define GALAXY_CONFIG_SBA_220           (0 << 0)
36 #define GALAXY_CONFIG_SBA_240           (1 << 0)
37 #define GALAXY_CONFIG_SBA_260           (2 << 0)
38 #define GALAXY_CONFIG_SBA_280           (3 << 0)
39 #define GALAXY_CONFIG_SBA_MASK          GALAXY_CONFIG_SBA_280
40
41 #define GALAXY_CONFIG_SBIRQ_2           (1 << 2)
42 #define GALAXY_CONFIG_SBIRQ_5           (1 << 3)
43 #define GALAXY_CONFIG_SBIRQ_7           (1 << 4)
44 #define GALAXY_CONFIG_SBIRQ_10          (1 << 5)
45
46 #define GALAXY_CONFIG_SBDMA_DISABLE     (0 << 6)
47 #define GALAXY_CONFIG_SBDMA_0           (1 << 6)
48 #define GALAXY_CONFIG_SBDMA_1           (2 << 6)
49 #define GALAXY_CONFIG_SBDMA_3           (3 << 6)
50
51 #define GALAXY_CONFIG_WSSA_530          (0 << 8)
52 #define GALAXY_CONFIG_WSSA_604          (1 << 8)
53 #define GALAXY_CONFIG_WSSA_E80          (2 << 8)
54 #define GALAXY_CONFIG_WSSA_F40          (3 << 8)
55
56 #define GALAXY_CONFIG_WSS_ENABLE        (1 << 10)
57
58 #define GALAXY_CONFIG_GAME_ENABLE       (1 << 11)
59
60 #define GALAXY_CONFIG_MPUA_300          (0 << 12)
61 #define GALAXY_CONFIG_MPUA_330          (1 << 12)
62
63 #define GALAXY_CONFIG_MPU_ENABLE        (1 << 13)
64
65 #define GALAXY_CONFIG_CDA_310           (0 << 14)
66 #define GALAXY_CONFIG_CDA_320           (1 << 14)
67 #define GALAXY_CONFIG_CDA_340           (2 << 14)
68 #define GALAXY_CONFIG_CDA_350           (3 << 14)
69 #define GALAXY_CONFIG_CDA_MASK          GALAXY_CONFIG_CDA_350
70
71 #define GALAXY_CONFIG_CD_DISABLE        (0 << 16)
72 #define GALAXY_CONFIG_CD_PANASONIC      (1 << 16)
73 #define GALAXY_CONFIG_CD_SONY           (2 << 16)
74 #define GALAXY_CONFIG_CD_MITSUMI        (3 << 16)
75 #define GALAXY_CONFIG_CD_AZTECH         (4 << 16)
76 #define GALAXY_CONFIG_CD_UNUSED_5       (5 << 16)
77 #define GALAXY_CONFIG_CD_UNUSED_6       (6 << 16)
78 #define GALAXY_CONFIG_CD_UNUSED_7       (7 << 16)
79 #define GALAXY_CONFIG_CD_MASK           GALAXY_CONFIG_CD_UNUSED_7
80
81 #define GALAXY_CONFIG_CDDMA8_DISABLE    (0 << 20)
82 #define GALAXY_CONFIG_CDDMA8_0          (1 << 20)
83 #define GALAXY_CONFIG_CDDMA8_1          (2 << 20)
84 #define GALAXY_CONFIG_CDDMA8_3          (3 << 20)
85 #define GALAXY_CONFIG_CDDMA8_MASK       GALAXY_CONFIG_CDDMA8_3
86
87 #define GALAXY_CONFIG_CDDMA16_DISABLE   (0 << 22)
88 #define GALAXY_CONFIG_CDDMA16_5         (1 << 22)
89 #define GALAXY_CONFIG_CDDMA16_6         (2 << 22)
90 #define GALAXY_CONFIG_CDDMA16_7         (3 << 22)
91 #define GALAXY_CONFIG_CDDMA16_MASK      GALAXY_CONFIG_CDDMA16_7
92
93 #define GALAXY_CONFIG_MPUIRQ_2          (1 << 24)
94 #define GALAXY_CONFIG_MPUIRQ_5          (1 << 25)
95 #define GALAXY_CONFIG_MPUIRQ_7          (1 << 26)
96 #define GALAXY_CONFIG_MPUIRQ_10         (1 << 27)
97
98 #define GALAXY_CONFIG_CDIRQ_5           (1 << 28)
99 #define GALAXY_CONFIG_CDIRQ_11          (1 << 29)
100 #define GALAXY_CONFIG_CDIRQ_12          (1 << 30)
101 #define GALAXY_CONFIG_CDIRQ_15          (1 << 31)
102 #define GALAXY_CONFIG_CDIRQ_MASK        (\
103         GALAXY_CONFIG_CDIRQ_5 | GALAXY_CONFIG_CDIRQ_11 |\
104         GALAXY_CONFIG_CDIRQ_12 | GALAXY_CONFIG_CDIRQ_15)
105
106 #define GALAXY_CONFIG_MASK              (\
107         GALAXY_CONFIG_SBA_MASK | GALAXY_CONFIG_CDA_MASK |\
108         GALAXY_CONFIG_CD_MASK | GALAXY_CONFIG_CDDMA16_MASK |\
109         GALAXY_CONFIG_CDDMA8_MASK | GALAXY_CONFIG_CDIRQ_MASK)
110
111 #include "galaxy.c"