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