xref: /openbmc/linux/sound/isa/galaxy/azt2316.c (revision e23feb16)
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"
112