#ifndef __SOUND_ES1688_H #define __SOUND_ES1688_H /* * Header file for ES488/ES1688 * Copyright (c) by Jaroslav Kysela * * * 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 #include #include #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); int snd_es1688_mixer(struct snd_card *card, struct snd_es1688 *chip); int snd_es1688_reset(struct snd_es1688 *chip); #endif /* __SOUND_ES1688_H */ ption>space:mode:
authorColy Li <colyli@suse.de>2017-01-24 15:18:46 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-01-24 16:26:14 -0800
commitf598f82e204ec0b17797caaf1b0311c52d43fb9a (patch)
tree20e0109db50c168a36df14af76b484eaf9b71836 /net/irda/ircomm
parent4180c4c170a5a33b9987b314d248a9d572d89ab0 (diff)
romfs: use different way to generate fsid for BLOCK or MTD
Commit 8a59f5d25265 ("fs/romfs: return f_fsid for statfs(2)") generates a 64bit id from sb->s_bdev->bd_dev. This is only correct when romfs is defined with CONFIG_ROMFS_ON_BLOCK. If romfs is only defined with CONFIG_ROMFS_ON_MTD, sb->s_bdev is NULL, referencing sb->s_bdev->bd_dev will triger an oops. Richard Weinberger points out that when CONFIG_ROMFS_BACKED_BY_BOTH=y, both CONFIG_ROMFS_ON_BLOCK and CONFIG_ROMFS_ON_MTD are defined. Therefore when calling huge_encode_dev() to generate a 64bit id, I use the follow order to choose parameter, - CONFIG_ROMFS_ON_BLOCK defined use sb->s_bdev->bd_dev - CONFIG_ROMFS_ON_BLOCK undefined and CONFIG_ROMFS_ON_MTD defined use sb->s_dev when, - both CONFIG_ROMFS_ON_BLOCK and CONFIG_ROMFS_ON_MTD undefined leave id as 0 When CONFIG_ROMFS_ON_MTD is defined and sb->s_mtd is not NULL, sb->s_dev is set to a device ID generated by MTD_BLOCK_MAJOR and mtd index, otherwise sb->s_dev is 0. This is a try-best effort to generate a uniq file system ID, if all the above conditions are not meet, f_fsid of this romfs instance will be 0. Generally only one romfs can be built on single MTD block device, this method is enough to identify multiple romfs instances in a computer. Link: http://lkml.kernel.org/r/1482928596-115155-1-git-send-email-colyli@suse.de Signed-off-by: Coly Li <colyli@suse.de> Reported-by: Nong Li <nongli1031@gmail.com> Tested-by: Nong Li <nongli1031@gmail.com> Cc: Richard Weinberger <richard.weinberger@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'net/irda/ircomm')