 e5b35420ef
			
		
	
	
	e5b35420ef
	
	
	
		
			
			This will fix the following oops: [ 6.169981] genirq: Flags mismatch irq 5. 00000000 (ES1688) vs. 00000000 (ES1688) [ 6.170851] Pid: 1, comm: swapper Not tainted 3.5.0-00004-gceee0e9 #14 [ 6.170851] Call Trace: [ 6.170851] [<c1062237>] ? __setup_irq+0x3c7/0x420 [ 6.170851] [<c1062486>] ? request_threaded_irq+0x76/0x140 [ 6.170851] [<c1290220>] ? snd_es1688_ioctl+0x10/0x10 [ 6.170851] [<c10624c2>] ? request_threaded_irq+0xb2/0x140 [ 6.170851] [<c1291196>] ? snd_es1688_create+0x96/0x330 [ 6.170851] [<c138365d>] ? snd_gusextreme_probe+0x18d/0x5a2 [ 6.170851] [<c11c9d80>] ? __driver_attach+0x80/0x80 [ 6.170851] [<c10db22f>] ? sysfs_create_link+0xf/0x20 [ 6.170851] [<c11c9d80>] ? __driver_attach+0x80/0x80 [ 6.170851] [<c11d1502>] ? isa_bus_probe+0x12/0x20 [ 6.170851] [<c11c9b95>] ? driver_probe_device+0x55/0x1c0 [ 6.170851] [<c13ae04f>] ? _raw_spin_unlock+0xf/0x30 [ 6.170851] [<c13705ea>] ? klist_next+0x6a/0xe0 [ 6.170851] [<c11d15c1>] ? isa_bus_match+0x21/0x40 [ 6.170851] [<c11c8a24>] ? bus_for_each_drv+0x34/0x70 [ 6.170851] [<c11c9e4b>] ? device_attach+0x7b/0x90 [ 6.170851] [<c11c9d80>] ? __driver_attach+0x80/0x80 [ 6.170851] [<c11c8bff>] ? bus_probe_device+0x5f/0x80 [ 6.170851] [<c11c7493>] ? device_add+0x573/0x620 [ 6.170851] [<c1042820>] ? complete_all+0x40/0x60 [ 6.170851] [<c13ae08a>] ? _raw_spin_unlock_irqrestore+0x1a/0x30 [ 6.170851] [<c11d16c6>] ? isa_register_driver+0xb6/0x150 [ 6.170851] [<c15c9002>] ? alsa_card_gusmax_init+0xf/0xf [ 6.170851] [<c15a99bc>] ? do_one_initcall+0x7f/0x12b [ 6.170851] [<c15a9b7a>] ? kernel_init+0x112/0x1a9 [ 6.170851] [<c15a9423>] ? do_early_param+0x77/0x77 [ 6.170851] [<c15a9a68>] ? do_one_initcall+0x12b/0x12b [ 6.170851] [<c13aefbe>] ? kernel_thread_helper+0x6/0xd [ 6.190170] es1688: can't grab IRQ 5 [ 6.190613] genirq: Flags mismatch irq 5. 00000000 (ES1688) vs. 00000000 (ES1688) [ 6.191566] Pid: 1, comm: swapper Not tainted 3.5.0-00004-gceee0e9 #14 [ 6.192394] Call Trace: [ 6.192685] [<c1062237>] ? __setup_irq+0x3c7/0x420 [ 6.193342] [<c1062486>] ? request_threaded_irq+0x76/0x140 [ 6.194081] [<c1290220>] ? snd_es1688_ioctl+0x10/0x10 [ 6.194607] [<c10624c2>] ? request_threaded_irq+0xb2/0x140 [ 6.194607] [<c1291196>] ? snd_es1688_create+0x96/0x330 [ 6.194607] [<c138365d>] ? snd_gusextreme_probe+0x18d/0x5a2 [ 6.194607] [<c11c9d80>] ? __driver_attach+0x80/0x80 [ 6.194607] [<c10db22f>] ? sysfs_create_link+0xf/0x20 [ 6.194607] [<c11c9d80>] ? __driver_attach+0x80/0x80 [ 6.194607] [<c11d1502>] ? isa_bus_probe+0x12/0x20 [ 6.194607] [<c11c9b95>] ? driver_probe_device+0x55/0x1c0 [ 6.194607] [<c13ae04f>] ? _raw_spin_unlock+0xf/0x30 [ 6.194607] [<c13705ea>] ? klist_next+0x6a/0xe0 [ 6.194607] [<c11d15c1>] ? isa_bus_match+0x21/0x40 [ 6.194607] [<c11c8a24>] ? bus_for_each_drv+0x34/0x70 [ 6.194607] [<c11c9e4b>] ? device_attach+0x7b/0x90 [ 6.194607] [<c11c9d80>] ? __driver_attach+0x80/0x80 [ 6.194607] [<c11c8bff>] ? bus_probe_device+0x5f/0x80 [ 6.194607] [<c11c7493>] ? device_add+0x573/0x620 [ 6.194607] [<c1042820>] ? complete_all+0x40/0x60 [ 6.194607] [<c13ae08a>] ? _raw_spin_unlock_irqrestore+0x1a/0x30 [ 6.194607] [<c11d16c6>] ? isa_register_driver+0xb6/0x150 [ 6.194607] [<c15c9002>] ? alsa_card_gusmax_init+0xf/0xf [ 6.194607] [<c15a99bc>] ? do_one_initcall+0x7f/0x12b [ 6.194607] [<c15a9b7a>] ? kernel_init+0x112/0x1a9 [ 6.194607] [<c15a9423>] ? do_early_param+0x77/0x77 [ 6.194607] [<c15a9a68>] ? do_one_initcall+0x12b/0x12b [ 6.194607] [<c13aefbe>] ? kernel_thread_helper+0x6/0xd [ 6.210779] es1688: can't grab IRQ 5 [ 6.211305] gusextreme: probe of gusextreme.0 failed with error -16 Signed-off-by: Daniel Mack <zonque@gmail.com> Signed-off-by: Fengguang Wu <fengguang.wu@intel.com> Signed-off-by: Takashi Iwai <tiwai@suse.de>
		
			
				
	
	
		
			123 lines
		
	
	
	
		
			3.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
	
		
			3.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __SOUND_ES1688_H
 | |
| #define __SOUND_ES1688_H
 | |
| 
 | |
| /*
 | |
|  *  Header file for ES488/ES1688
 | |
|  *  Copyright (c) by Jaroslav Kysela <perex@perex.cz>
 | |
|  *
 | |
|  *
 | |
|  *   This program is free software; you can redistribute it and/or modify
 | |
|  *   it under the terms of the GNU General Public License as published by
 | |
|  *   the Free Software Foundation; either version 2 of the License, or
 | |
|  *   (at your option) any later version.
 | |
|  *
 | |
|  *   This program is distributed in the hope that it will be useful,
 | |
|  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  *   GNU General Public License for more details.
 | |
|  *
 | |
|  *   You should have received a copy of the GNU General Public License
 | |
|  *   along with this program; if not, write to the Free Software
 | |
|  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #include "control.h"
 | |
| #include "pcm.h"
 | |
| #include <linux/interrupt.h>
 | |
| 
 | |
| #define ES1688_HW_AUTO		0x0000
 | |
| #define ES1688_HW_688		0x0001
 | |
| #define ES1688_HW_1688		0x0002
 | |
| #define ES1688_HW_UNDEF	0x0003
 | |
| 
 | |
| struct snd_es1688 {
 | |
| 	unsigned long port;		/* port of ESS chip */
 | |
| 	struct resource *res_port;
 | |
| 	unsigned long mpu_port;		/* MPU-401 port of ESS chip */
 | |
| 	int irq;			/* IRQ number of ESS chip */
 | |
| 	int mpu_irq;			/* MPU IRQ */
 | |
| 	int dma8;			/* 8-bit DMA */
 | |
| 	unsigned short version;		/* version of ESS chip */
 | |
| 	unsigned short hardware;	/* see to ES1688_HW_XXXX */
 | |
| 
 | |
| 	unsigned short trigger_value;
 | |
| 	unsigned char pad;
 | |
| 	unsigned int dma_size;
 | |
| 
 | |
| 	struct snd_pcm *pcm;
 | |
| 	struct snd_pcm_substream *playback_substream;
 | |
| 	struct snd_pcm_substream *capture_substream;
 | |
| 
 | |
| 	spinlock_t reg_lock;
 | |
| 	spinlock_t mixer_lock;
 | |
| };
 | |
| 
 | |
| /* I/O ports */
 | |
| 
 | |
| #define ES1688P(codec, x) ((codec)->port + e_s_s_ESS1688##x)
 | |
| 
 | |
| #define e_s_s_ESS1688RESET	0x6
 | |
| #define e_s_s_ESS1688READ	0xa
 | |
| #define e_s_s_ESS1688WRITE	0xc
 | |
| #define e_s_s_ESS1688COMMAND	0xc
 | |
| #define e_s_s_ESS1688STATUS	0xc
 | |
| #define e_s_s_ESS1688DATA_AVAIL	0xe
 | |
| #define e_s_s_ESS1688DATA_AVAIL_16 0xf
 | |
| #define e_s_s_ESS1688MIXER_ADDR	0x4
 | |
| #define e_s_s_ESS1688MIXER_DATA	0x5
 | |
| #define e_s_s_ESS1688OPL3_LEFT	0x0
 | |
| #define e_s_s_ESS1688OPL3_RIGHT	0x2
 | |
| #define e_s_s_ESS1688OPL3_BOTH	0x8
 | |
| #define e_s_s_ESS1688ENABLE0	0x0
 | |
| #define e_s_s_ESS1688ENABLE1	0x9
 | |
| #define e_s_s_ESS1688ENABLE2	0xb
 | |
| #define e_s_s_ESS1688INIT1	0x7
 | |
| 
 | |
| #define ES1688_DSP_CMD_DMAOFF	0xd0
 | |
| #define ES1688_DSP_CMD_SPKON	0xd1
 | |
| #define ES1688_DSP_CMD_SPKOFF	0xd3
 | |
| #define ES1688_DSP_CMD_DMAON	0xd4
 | |
| 
 | |
| #define ES1688_PCM_DEV		0x14
 | |
| #define ES1688_MIC_DEV		0x1a
 | |
| #define ES1688_REC_DEV		0x1c
 | |
| #define ES1688_MASTER_DEV	0x32
 | |
| #define ES1688_FM_DEV		0x36
 | |
| #define ES1688_CD_DEV		0x38
 | |
| #define ES1688_AUX_DEV		0x3a
 | |
| #define ES1688_SPEAKER_DEV	0x3c
 | |
| #define ES1688_LINE_DEV		0x3e
 | |
| #define ES1688_RECLEV_DEV	0xb4
 | |
| 
 | |
| #define ES1688_MIXS_MASK	0x17
 | |
| #define ES1688_MIXS_MIC		0x00
 | |
| #define ES1688_MIXS_MIC_MASTER	0x01
 | |
| #define ES1688_MIXS_CD		0x02
 | |
| #define ES1688_MIXS_AOUT	0x03
 | |
| #define ES1688_MIXS_MIC1	0x04
 | |
| #define ES1688_MIXS_REC_MIX	0x05
 | |
| #define ES1688_MIXS_LINE	0x06
 | |
| #define ES1688_MIXS_MASTER	0x07
 | |
| #define ES1688_MIXS_MUTE	0x10
 | |
| 
 | |
| /*
 | |
| 
 | |
|  */
 | |
| 
 | |
| void snd_es1688_mixer_write(struct snd_es1688 *chip, unsigned char reg, unsigned char data);
 | |
| 
 | |
| int snd_es1688_create(struct snd_card *card,
 | |
| 		      struct snd_es1688 *chip,
 | |
| 		      unsigned long port,
 | |
| 		      unsigned long mpu_port,
 | |
| 		      int irq,
 | |
| 		      int mpu_irq,
 | |
| 		      int dma8,
 | |
| 		      unsigned short hardware);
 | |
| int snd_es1688_pcm(struct snd_card *card, struct snd_es1688 *chip, int device,
 | |
| 		   struct snd_pcm **rpcm);
 | |
| int snd_es1688_mixer(struct snd_card *card, struct snd_es1688 *chip);
 | |
| int snd_es1688_reset(struct snd_es1688 *chip);
 | |
| 
 | |
| #endif /* __SOUND_ES1688_H */
 |