xref: /openbmc/linux/sound/pci/ice1712/hoontech.h (revision c1017a4cdb68ae5368fbc9ee42c77f1f5dca8916)
11da177e4SLinus Torvalds #ifndef __SOUND_HOONTECH_H
21da177e4SLinus Torvalds #define __SOUND_HOONTECH_H
31da177e4SLinus Torvalds 
41da177e4SLinus Torvalds /*
51da177e4SLinus Torvalds  *   ALSA driver for ICEnsemble ICE1712 (Envy24)
61da177e4SLinus Torvalds  *
71da177e4SLinus Torvalds  *   Lowlevel functions for Hoontech STDSP24
81da177e4SLinus Torvalds  *
9*c1017a4cSJaroslav Kysela  *	Copyright (c) 2000 Jaroslav Kysela <perex@perex.cz>
101da177e4SLinus Torvalds  *
111da177e4SLinus Torvalds  *   This program is free software; you can redistribute it and/or modify
121da177e4SLinus Torvalds  *   it under the terms of the GNU General Public License as published by
131da177e4SLinus Torvalds  *   the Free Software Foundation; either version 2 of the License, or
141da177e4SLinus Torvalds  *   (at your option) any later version.
151da177e4SLinus Torvalds  *
161da177e4SLinus Torvalds  *   This program is distributed in the hope that it will be useful,
171da177e4SLinus Torvalds  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
181da177e4SLinus Torvalds  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
191da177e4SLinus Torvalds  *   GNU General Public License for more details.
201da177e4SLinus Torvalds  *
211da177e4SLinus Torvalds  *   You should have received a copy of the GNU General Public License
221da177e4SLinus Torvalds  *   along with this program; if not, write to the Free Software
231da177e4SLinus Torvalds  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
241da177e4SLinus Torvalds  *
251da177e4SLinus Torvalds  */
261da177e4SLinus Torvalds 
271da177e4SLinus Torvalds #define  HOONTECH_DEVICE_DESC \
281da177e4SLinus Torvalds 	"{Hoontech,SoundTrack DSP 24}," \
291da177e4SLinus Torvalds 	"{Hoontech,SoundTrack DSP 24 Value}," \
301da177e4SLinus Torvalds 	"{Hoontech,SoundTrack DSP 24 Media 7.1}," \
311da177e4SLinus Torvalds 	"{Event Electronics,EZ8},"
321da177e4SLinus Torvalds 
331da177e4SLinus Torvalds #define ICE1712_SUBDEVICE_STDSP24		0x12141217	/* Hoontech SoundTrack Audio DSP 24 */
341da177e4SLinus Torvalds #define ICE1712_SUBDEVICE_STDSP24_VALUE		0x00010010	/* A dummy id for Hoontech SoundTrack Audio DSP 24 Value */
351da177e4SLinus Torvalds #define ICE1712_SUBDEVICE_STDSP24_MEDIA7_1	0x16141217	/* Hoontech ST Audio DSP24 Media 7.1 */
361da177e4SLinus Torvalds #define ICE1712_SUBDEVICE_EVENT_EZ8		0x00010001	/* A dummy id for EZ8 */
371da177e4SLinus Torvalds 
38bf748ed7SRalf Baechle extern struct snd_ice1712_card_info snd_ice1712_hoontech_cards[];
391da177e4SLinus Torvalds 
401da177e4SLinus Torvalds 
411da177e4SLinus Torvalds /* Hoontech SoundTrack Audio DSP 24 GPIO definitions */
421da177e4SLinus Torvalds 
431da177e4SLinus Torvalds #define ICE1712_STDSP24_0_BOX(r, x)	r[0] = ((r[0] & ~3) | ((x)&3))
441da177e4SLinus Torvalds #define ICE1712_STDSP24_0_DAREAR(r, x)	r[0] = ((r[0] & ~4) | (((x)&1)<<2))
451da177e4SLinus Torvalds #define ICE1712_STDSP24_1_CHN1(r, x)	r[1] = ((r[1] & ~1) | ((x)&1))
461da177e4SLinus Torvalds #define ICE1712_STDSP24_1_CHN2(r, x)	r[1] = ((r[1] & ~2) | (((x)&1)<<1))
471da177e4SLinus Torvalds #define ICE1712_STDSP24_1_CHN3(r, x)	r[1] = ((r[1] & ~4) | (((x)&1)<<2))
481da177e4SLinus Torvalds #define ICE1712_STDSP24_2_CHN4(r, x)	r[2] = ((r[2] & ~1) | ((x)&1))
491da177e4SLinus Torvalds #define ICE1712_STDSP24_2_MIDIIN(r, x)	r[2] = ((r[2] & ~2) | (((x)&1)<<1))
501da177e4SLinus Torvalds #define ICE1712_STDSP24_2_MIDI1(r, x)	r[2] = ((r[2] & ~4) | (((x)&1)<<2))
511da177e4SLinus Torvalds #define ICE1712_STDSP24_3_MIDI2(r, x)	r[3] = ((r[3] & ~1) | ((x)&1))
521da177e4SLinus Torvalds #define ICE1712_STDSP24_3_MUTE(r, x)	r[3] = ((r[3] & ~2) | (((x)&1)<<1))
531da177e4SLinus Torvalds #define ICE1712_STDSP24_3_INSEL(r, x)	r[3] = ((r[3] & ~4) | (((x)&1)<<2))
541da177e4SLinus Torvalds #define ICE1712_STDSP24_SET_ADDR(r, a)	r[a&3] = ((r[a&3] & ~0x18) | (((a)&3)<<3))
551da177e4SLinus Torvalds #define ICE1712_STDSP24_CLOCK(r, a, c)	r[a&3] = ((r[a&3] & ~0x20) | (((c)&1)<<5))
561da177e4SLinus Torvalds #define ICE1712_STDSP24_CLOCK_BIT	(1<<5)
571da177e4SLinus Torvalds 
581da177e4SLinus Torvalds /* Hoontech SoundTrack Audio DSP 24 box configuration definitions */
591da177e4SLinus Torvalds 
601da177e4SLinus Torvalds #define ICE1712_STDSP24_DAREAR		(1<<0)
611da177e4SLinus Torvalds #define ICE1712_STDSP24_MUTE		(1<<1)
621da177e4SLinus Torvalds #define ICE1712_STDSP24_INSEL		(1<<2)
631da177e4SLinus Torvalds 
641da177e4SLinus Torvalds #define ICE1712_STDSP24_BOX_CHN1	(1<<0)	/* input channel 1 */
651da177e4SLinus Torvalds #define ICE1712_STDSP24_BOX_CHN2	(1<<1)	/* input channel 2 */
661da177e4SLinus Torvalds #define ICE1712_STDSP24_BOX_CHN3	(1<<2)	/* input channel 3 */
671da177e4SLinus Torvalds #define ICE1712_STDSP24_BOX_CHN4	(1<<3)	/* input channel 4 */
681da177e4SLinus Torvalds #define ICE1712_STDSP24_BOX_MIDI1	(1<<8)
691da177e4SLinus Torvalds #define ICE1712_STDSP24_BOX_MIDI2	(1<<9)
701da177e4SLinus Torvalds 
711da177e4SLinus Torvalds /* Hoontech SoundTrack Audio DSP 24 Value definitions for modified hardware */
721da177e4SLinus Torvalds 
731da177e4SLinus Torvalds #define ICE1712_STDSP24_AK4524_CS	0x03	/* AK4524 chip select; low = active */
741da177e4SLinus Torvalds #define ICE1712_STDSP24_SERIAL_DATA	0x0c	/* ak4524 data */
751da177e4SLinus Torvalds #define ICE1712_STDSP24_SERIAL_CLOCK	0x30	/* ak4524 clock */
761da177e4SLinus Torvalds 
771da177e4SLinus Torvalds #endif /* __SOUND_HOONTECH_H */
78