diff options
author | Andrea Bastoni <bastoni@cs.unc.edu> | 2010-10-23 01:01:49 -0400 |
---|---|---|
committer | Andrea Bastoni <bastoni@cs.unc.edu> | 2010-10-23 01:01:49 -0400 |
commit | 3dd41424090a0ca3a660218d06afe6ff4441bad3 (patch) | |
tree | 511ef1bb1799027fc5aad574adce49120ecadd87 /include/sound | |
parent | 5c5456402d467969b217d7fdd6670f8c8600f5a8 (diff) | |
parent | f6f94e2ab1b33f0082ac22d71f66385a60d8157f (diff) |
Merge commit 'v2.6.36' into wip-merge-2.6.36
Conflicts:
Makefile
arch/x86/include/asm/unistd_32.h
arch/x86/kernel/syscall_table_32.S
kernel/sched.c
kernel/time/tick-sched.c
Relevant API and functions changes (solved in this commit):
- (API) .enqueue_task() (enqueue_task_litmus),
dequeue_task() (dequeue_task_litmus),
[litmus/sched_litmus.c]
- (API) .select_task_rq() (select_task_rq_litmus)
[litmus/sched_litmus.c]
- (API) sysrq_dump_trace_buffer() and sysrq_handle_kill_rt_tasks()
[litmus/sched_trace.c]
- struct kfifo internal buffer name changed (buffer -> buf)
[litmus/sched_trace.c]
- add_wait_queue_exclusive_locked -> __add_wait_queue_tail_exclusive
[litmus/fmlp.c]
- syscall numbers for both x86_32 and x86_64
Diffstat (limited to 'include/sound')
-rw-r--r-- | include/sound/Kbuild | 9 | ||||
-rw-r--r-- | include/sound/asound.h | 26 | ||||
-rw-r--r-- | include/sound/emu10k1.h | 1 | ||||
-rw-r--r-- | include/sound/es1688.h | 11 | ||||
-rw-r--r-- | include/sound/info.h | 24 | ||||
-rw-r--r-- | include/sound/jack.h | 8 | ||||
-rw-r--r-- | include/sound/pcm.h | 9 | ||||
-rw-r--r-- | include/sound/sh_fsi.h | 49 | ||||
-rw-r--r-- | include/sound/soc-dai.h | 7 | ||||
-rw-r--r-- | include/sound/soc-dapm.h | 10 | ||||
-rw-r--r-- | include/sound/soc.h | 82 | ||||
-rw-r--r-- | include/sound/tlv320aic3x.h | 17 | ||||
-rw-r--r-- | include/sound/tlv320dac33-plat.h | 3 | ||||
-rw-r--r-- | include/sound/uda134x.h | 13 | ||||
-rw-r--r-- | include/sound/version.h | 2 | ||||
-rw-r--r-- | include/sound/wm8903.h | 249 | ||||
-rw-r--r-- | include/sound/wm8904.h | 110 | ||||
-rw-r--r-- | include/sound/wm8960.h | 24 | ||||
-rw-r--r-- | include/sound/wm9090.h | 28 |
19 files changed, 619 insertions, 63 deletions
diff --git a/include/sound/Kbuild b/include/sound/Kbuild index e9dd9369ecb9..802947f60915 100644 --- a/include/sound/Kbuild +++ b/include/sound/Kbuild | |||
@@ -1,9 +1,8 @@ | |||
1 | header-y += asequencer.h | ||
2 | header-y += asound.h | ||
1 | header-y += asound_fm.h | 3 | header-y += asound_fm.h |
4 | header-y += emu10k1.h | ||
2 | header-y += hdsp.h | 5 | header-y += hdsp.h |
3 | header-y += hdspm.h | 6 | header-y += hdspm.h |
7 | header-y += sb16_csp.h | ||
4 | header-y += sfnt_info.h | 8 | header-y += sfnt_info.h |
5 | |||
6 | unifdef-y += asequencer.h | ||
7 | unifdef-y += asound.h | ||
8 | unifdef-y += emu10k1.h | ||
9 | unifdef-y += sb16_csp.h | ||
diff --git a/include/sound/asound.h b/include/sound/asound.h index 098595500632..a1803ecea34d 100644 --- a/include/sound/asound.h +++ b/include/sound/asound.h | |||
@@ -212,7 +212,11 @@ typedef int __bitwise snd_pcm_format_t; | |||
212 | #define SNDRV_PCM_FORMAT_S18_3BE ((__force snd_pcm_format_t) 41) /* in three bytes */ | 212 | #define SNDRV_PCM_FORMAT_S18_3BE ((__force snd_pcm_format_t) 41) /* in three bytes */ |
213 | #define SNDRV_PCM_FORMAT_U18_3LE ((__force snd_pcm_format_t) 42) /* in three bytes */ | 213 | #define SNDRV_PCM_FORMAT_U18_3LE ((__force snd_pcm_format_t) 42) /* in three bytes */ |
214 | #define SNDRV_PCM_FORMAT_U18_3BE ((__force snd_pcm_format_t) 43) /* in three bytes */ | 214 | #define SNDRV_PCM_FORMAT_U18_3BE ((__force snd_pcm_format_t) 43) /* in three bytes */ |
215 | #define SNDRV_PCM_FORMAT_LAST SNDRV_PCM_FORMAT_U18_3BE | 215 | #define SNDRV_PCM_FORMAT_G723_24 ((__force snd_pcm_format_t) 44) /* 8 samples in 3 bytes */ |
216 | #define SNDRV_PCM_FORMAT_G723_24_1B ((__force snd_pcm_format_t) 45) /* 1 sample in 1 byte */ | ||
217 | #define SNDRV_PCM_FORMAT_G723_40 ((__force snd_pcm_format_t) 46) /* 8 Samples in 5 bytes */ | ||
218 | #define SNDRV_PCM_FORMAT_G723_40_1B ((__force snd_pcm_format_t) 47) /* 1 sample in 1 byte */ | ||
219 | #define SNDRV_PCM_FORMAT_LAST SNDRV_PCM_FORMAT_G723_40_1B | ||
216 | 220 | ||
217 | #ifdef SNDRV_LITTLE_ENDIAN | 221 | #ifdef SNDRV_LITTLE_ENDIAN |
218 | #define SNDRV_PCM_FORMAT_S16 SNDRV_PCM_FORMAT_S16_LE | 222 | #define SNDRV_PCM_FORMAT_S16 SNDRV_PCM_FORMAT_S16_LE |
@@ -574,7 +578,7 @@ enum { | |||
574 | #define SNDRV_TIMER_FLG_SLAVE (1<<0) /* cannot be controlled */ | 578 | #define SNDRV_TIMER_FLG_SLAVE (1<<0) /* cannot be controlled */ |
575 | 579 | ||
576 | struct snd_timer_id { | 580 | struct snd_timer_id { |
577 | int dev_class; | 581 | int dev_class; |
578 | int dev_sclass; | 582 | int dev_sclass; |
579 | int card; | 583 | int card; |
580 | int device; | 584 | int device; |
@@ -762,7 +766,7 @@ struct snd_ctl_elem_id { | |||
762 | snd_ctl_elem_iface_t iface; /* interface identifier */ | 766 | snd_ctl_elem_iface_t iface; /* interface identifier */ |
763 | unsigned int device; /* device/client number */ | 767 | unsigned int device; /* device/client number */ |
764 | unsigned int subdevice; /* subdevice (substream) number */ | 768 | unsigned int subdevice; /* subdevice (substream) number */ |
765 | unsigned char name[44]; /* ASCII name of item */ | 769 | unsigned char name[44]; /* ASCII name of item */ |
766 | unsigned int index; /* index of item */ | 770 | unsigned int index; /* index of item */ |
767 | }; | 771 | }; |
768 | 772 | ||
@@ -809,7 +813,7 @@ struct snd_ctl_elem_info { | |||
809 | struct snd_ctl_elem_value { | 813 | struct snd_ctl_elem_value { |
810 | struct snd_ctl_elem_id id; /* W: element ID */ | 814 | struct snd_ctl_elem_id id; /* W: element ID */ |
811 | unsigned int indirect: 1; /* W: indirect access - obsoleted */ | 815 | unsigned int indirect: 1; /* W: indirect access - obsoleted */ |
812 | union { | 816 | union { |
813 | union { | 817 | union { |
814 | long value[128]; | 818 | long value[128]; |
815 | long *value_ptr; /* obsoleted */ | 819 | long *value_ptr; /* obsoleted */ |
@@ -827,15 +831,15 @@ struct snd_ctl_elem_value { | |||
827 | unsigned char *data_ptr; /* obsoleted */ | 831 | unsigned char *data_ptr; /* obsoleted */ |
828 | } bytes; | 832 | } bytes; |
829 | struct snd_aes_iec958 iec958; | 833 | struct snd_aes_iec958 iec958; |
830 | } value; /* RO */ | 834 | } value; /* RO */ |
831 | struct timespec tstamp; | 835 | struct timespec tstamp; |
832 | unsigned char reserved[128-sizeof(struct timespec)]; | 836 | unsigned char reserved[128-sizeof(struct timespec)]; |
833 | }; | 837 | }; |
834 | 838 | ||
835 | struct snd_ctl_tlv { | 839 | struct snd_ctl_tlv { |
836 | unsigned int numid; /* control element numeric identification */ | 840 | unsigned int numid; /* control element numeric identification */ |
837 | unsigned int length; /* in bytes aligned to 4 */ | 841 | unsigned int length; /* in bytes aligned to 4 */ |
838 | unsigned int tlv[0]; /* first TLV */ | 842 | unsigned int tlv[0]; /* first TLV */ |
839 | }; | 843 | }; |
840 | 844 | ||
841 | #define SNDRV_CTL_IOCTL_PVERSION _IOR('U', 0x00, int) | 845 | #define SNDRV_CTL_IOCTL_PVERSION _IOR('U', 0x00, int) |
@@ -886,8 +890,8 @@ struct snd_ctl_event { | |||
886 | unsigned int mask; | 890 | unsigned int mask; |
887 | struct snd_ctl_elem_id id; | 891 | struct snd_ctl_elem_id id; |
888 | } elem; | 892 | } elem; |
889 | unsigned char data8[60]; | 893 | unsigned char data8[60]; |
890 | } data; | 894 | } data; |
891 | }; | 895 | }; |
892 | 896 | ||
893 | /* | 897 | /* |
diff --git a/include/sound/emu10k1.h b/include/sound/emu10k1.h index 6a664c3f7c1e..7dc97d12253c 100644 --- a/include/sound/emu10k1.h +++ b/include/sound/emu10k1.h | |||
@@ -1707,6 +1707,7 @@ struct snd_emu10k1 { | |||
1707 | unsigned int card_type; /* EMU10K1_CARD_* */ | 1707 | unsigned int card_type; /* EMU10K1_CARD_* */ |
1708 | unsigned int ecard_ctrl; /* ecard control bits */ | 1708 | unsigned int ecard_ctrl; /* ecard control bits */ |
1709 | unsigned long dma_mask; /* PCI DMA mask */ | 1709 | unsigned long dma_mask; /* PCI DMA mask */ |
1710 | unsigned int delay_pcm_irq; /* in samples */ | ||
1710 | int max_cache_pages; /* max memory size / PAGE_SIZE */ | 1711 | int max_cache_pages; /* max memory size / PAGE_SIZE */ |
1711 | struct snd_dma_buffer silent_page; /* silent page */ | 1712 | struct snd_dma_buffer silent_page; /* silent page */ |
1712 | struct snd_dma_buffer ptb_pages; /* page table pages */ | 1713 | struct snd_dma_buffer ptb_pages; /* page table pages */ |
diff --git a/include/sound/es1688.h b/include/sound/es1688.h index 10fcf1465810..3ec7ecbe2502 100644 --- a/include/sound/es1688.h +++ b/include/sound/es1688.h | |||
@@ -44,7 +44,6 @@ struct snd_es1688 { | |||
44 | unsigned char pad; | 44 | unsigned char pad; |
45 | unsigned int dma_size; | 45 | unsigned int dma_size; |
46 | 46 | ||
47 | struct snd_card *card; | ||
48 | struct snd_pcm *pcm; | 47 | struct snd_pcm *pcm; |
49 | struct snd_pcm_substream *playback_substream; | 48 | struct snd_pcm_substream *playback_substream; |
50 | struct snd_pcm_substream *capture_substream; | 49 | struct snd_pcm_substream *capture_substream; |
@@ -108,14 +107,16 @@ struct snd_es1688 { | |||
108 | void snd_es1688_mixer_write(struct snd_es1688 *chip, unsigned char reg, unsigned char data); | 107 | void snd_es1688_mixer_write(struct snd_es1688 *chip, unsigned char reg, unsigned char data); |
109 | 108 | ||
110 | int snd_es1688_create(struct snd_card *card, | 109 | int snd_es1688_create(struct snd_card *card, |
110 | struct snd_es1688 *chip, | ||
111 | unsigned long port, | 111 | unsigned long port, |
112 | unsigned long mpu_port, | 112 | unsigned long mpu_port, |
113 | int irq, | 113 | int irq, |
114 | int mpu_irq, | 114 | int mpu_irq, |
115 | int dma8, | 115 | int dma8, |
116 | unsigned short hardware, | 116 | unsigned short hardware); |
117 | struct snd_es1688 ** rchip); | 117 | int snd_es1688_pcm(struct snd_card *card, struct snd_es1688 *chip, int device, |
118 | int snd_es1688_pcm(struct snd_es1688 *chip, int device, struct snd_pcm ** rpcm); | 118 | struct snd_pcm **rpcm); |
119 | int snd_es1688_mixer(struct snd_es1688 *chip); | 119 | int snd_es1688_mixer(struct snd_card *card, struct snd_es1688 *chip); |
120 | int snd_es1688_reset(struct snd_es1688 *chip); | ||
120 | 121 | ||
121 | #endif /* __SOUND_ES1688_H */ | 122 | #endif /* __SOUND_ES1688_H */ |
diff --git a/include/sound/info.h b/include/sound/info.h index 112e8949e1a7..4e94cf1ff762 100644 --- a/include/sound/info.h +++ b/include/sound/info.h | |||
@@ -51,18 +51,18 @@ struct snd_info_entry_ops { | |||
51 | unsigned short mode, void **file_private_data); | 51 | unsigned short mode, void **file_private_data); |
52 | int (*release)(struct snd_info_entry *entry, | 52 | int (*release)(struct snd_info_entry *entry, |
53 | unsigned short mode, void *file_private_data); | 53 | unsigned short mode, void *file_private_data); |
54 | long (*read)(struct snd_info_entry *entry, void *file_private_data, | 54 | ssize_t (*read)(struct snd_info_entry *entry, void *file_private_data, |
55 | struct file *file, char __user *buf, | 55 | struct file *file, char __user *buf, |
56 | unsigned long count, unsigned long pos); | 56 | size_t count, loff_t pos); |
57 | long (*write)(struct snd_info_entry *entry, void *file_private_data, | 57 | ssize_t (*write)(struct snd_info_entry *entry, void *file_private_data, |
58 | struct file *file, const char __user *buf, | 58 | struct file *file, const char __user *buf, |
59 | unsigned long count, unsigned long pos); | 59 | size_t count, loff_t pos); |
60 | long long (*llseek)(struct snd_info_entry *entry, | 60 | loff_t (*llseek)(struct snd_info_entry *entry, |
61 | void *file_private_data, struct file *file, | 61 | void *file_private_data, struct file *file, |
62 | long long offset, int orig); | 62 | loff_t offset, int orig); |
63 | unsigned int(*poll)(struct snd_info_entry *entry, | 63 | unsigned int (*poll)(struct snd_info_entry *entry, |
64 | void *file_private_data, struct file *file, | 64 | void *file_private_data, struct file *file, |
65 | poll_table *wait); | 65 | poll_table *wait); |
66 | int (*ioctl)(struct snd_info_entry *entry, void *file_private_data, | 66 | int (*ioctl)(struct snd_info_entry *entry, void *file_private_data, |
67 | struct file *file, unsigned int cmd, unsigned long arg); | 67 | struct file *file, unsigned int cmd, unsigned long arg); |
68 | int (*mmap)(struct snd_info_entry *entry, void *file_private_data, | 68 | int (*mmap)(struct snd_info_entry *entry, void *file_private_data, |
diff --git a/include/sound/jack.h b/include/sound/jack.h index f236e426a706..d90b9fa32707 100644 --- a/include/sound/jack.h +++ b/include/sound/jack.h | |||
@@ -42,6 +42,11 @@ enum snd_jack_types { | |||
42 | SND_JACK_MECHANICAL = 0x0008, /* If detected separately */ | 42 | SND_JACK_MECHANICAL = 0x0008, /* If detected separately */ |
43 | SND_JACK_VIDEOOUT = 0x0010, | 43 | SND_JACK_VIDEOOUT = 0x0010, |
44 | SND_JACK_AVOUT = SND_JACK_LINEOUT | SND_JACK_VIDEOOUT, | 44 | SND_JACK_AVOUT = SND_JACK_LINEOUT | SND_JACK_VIDEOOUT, |
45 | |||
46 | /* Kept separate from switches to facilitate implementation */ | ||
47 | SND_JACK_BTN_0 = 0x4000, | ||
48 | SND_JACK_BTN_1 = 0x2000, | ||
49 | SND_JACK_BTN_2 = 0x1000, | ||
45 | }; | 50 | }; |
46 | 51 | ||
47 | struct snd_jack { | 52 | struct snd_jack { |
@@ -50,6 +55,7 @@ struct snd_jack { | |||
50 | int type; | 55 | int type; |
51 | const char *id; | 56 | const char *id; |
52 | char name[100]; | 57 | char name[100]; |
58 | unsigned int key[3]; /* Keep in sync with definitions above */ | ||
53 | void *private_data; | 59 | void *private_data; |
54 | void (*private_free)(struct snd_jack *); | 60 | void (*private_free)(struct snd_jack *); |
55 | }; | 61 | }; |
@@ -59,6 +65,8 @@ struct snd_jack { | |||
59 | int snd_jack_new(struct snd_card *card, const char *id, int type, | 65 | int snd_jack_new(struct snd_card *card, const char *id, int type, |
60 | struct snd_jack **jack); | 66 | struct snd_jack **jack); |
61 | void snd_jack_set_parent(struct snd_jack *jack, struct device *parent); | 67 | void snd_jack_set_parent(struct snd_jack *jack, struct device *parent); |
68 | int snd_jack_set_key(struct snd_jack *jack, enum snd_jack_types type, | ||
69 | int keytype); | ||
62 | 70 | ||
63 | void snd_jack_report(struct snd_jack *jack, int status); | 71 | void snd_jack_report(struct snd_jack *jack, int status); |
64 | 72 | ||
diff --git a/include/sound/pcm.h b/include/sound/pcm.h index 8b611a561985..85f1c6bf8566 100644 --- a/include/sound/pcm.h +++ b/include/sound/pcm.h | |||
@@ -29,6 +29,7 @@ | |||
29 | #include <linux/poll.h> | 29 | #include <linux/poll.h> |
30 | #include <linux/mm.h> | 30 | #include <linux/mm.h> |
31 | #include <linux/bitops.h> | 31 | #include <linux/bitops.h> |
32 | #include <linux/pm_qos_params.h> | ||
32 | 33 | ||
33 | #define snd_pcm_substream_chip(substream) ((substream)->private_data) | 34 | #define snd_pcm_substream_chip(substream) ((substream)->private_data) |
34 | #define snd_pcm_chip(pcm) ((pcm)->private_data) | 35 | #define snd_pcm_chip(pcm) ((pcm)->private_data) |
@@ -173,6 +174,10 @@ struct snd_pcm_ops { | |||
173 | #define SNDRV_PCM_FMTBIT_U18_3LE (1ULL << SNDRV_PCM_FORMAT_U18_3LE) | 174 | #define SNDRV_PCM_FMTBIT_U18_3LE (1ULL << SNDRV_PCM_FORMAT_U18_3LE) |
174 | #define SNDRV_PCM_FMTBIT_S18_3BE (1ULL << SNDRV_PCM_FORMAT_S18_3BE) | 175 | #define SNDRV_PCM_FMTBIT_S18_3BE (1ULL << SNDRV_PCM_FORMAT_S18_3BE) |
175 | #define SNDRV_PCM_FMTBIT_U18_3BE (1ULL << SNDRV_PCM_FORMAT_U18_3BE) | 176 | #define SNDRV_PCM_FMTBIT_U18_3BE (1ULL << SNDRV_PCM_FORMAT_U18_3BE) |
177 | #define SNDRV_PCM_FMTBIT_G723_24 (1ULL << SNDRV_PCM_FORMAT_G723_24) | ||
178 | #define SNDRV_PCM_FMTBIT_G723_24_1B (1ULL << SNDRV_PCM_FORMAT_G723_24_1B) | ||
179 | #define SNDRV_PCM_FMTBIT_G723_40 (1ULL << SNDRV_PCM_FORMAT_G723_40) | ||
180 | #define SNDRV_PCM_FMTBIT_G723_40_1B (1ULL << SNDRV_PCM_FORMAT_G723_40_1B) | ||
176 | 181 | ||
177 | #ifdef SNDRV_LITTLE_ENDIAN | 182 | #ifdef SNDRV_LITTLE_ENDIAN |
178 | #define SNDRV_PCM_FMTBIT_S16 SNDRV_PCM_FMTBIT_S16_LE | 183 | #define SNDRV_PCM_FMTBIT_S16 SNDRV_PCM_FMTBIT_S16_LE |
@@ -312,7 +317,7 @@ struct snd_pcm_runtime { | |||
312 | struct snd_pcm_mmap_control *control; | 317 | struct snd_pcm_mmap_control *control; |
313 | 318 | ||
314 | /* -- locking / scheduling -- */ | 319 | /* -- locking / scheduling -- */ |
315 | unsigned int twake: 1; /* do transfer (!poll) wakeup */ | 320 | snd_pcm_uframes_t twake; /* do transfer (!poll) wakeup if non-zero */ |
316 | wait_queue_head_t sleep; /* poll sleep */ | 321 | wait_queue_head_t sleep; /* poll sleep */ |
317 | wait_queue_head_t tsleep; /* transfer sleep */ | 322 | wait_queue_head_t tsleep; /* transfer sleep */ |
318 | struct fasync_struct *fasync; | 323 | struct fasync_struct *fasync; |
@@ -365,7 +370,7 @@ struct snd_pcm_substream { | |||
365 | int number; | 370 | int number; |
366 | char name[32]; /* substream name */ | 371 | char name[32]; /* substream name */ |
367 | int stream; /* stream (direction) */ | 372 | int stream; /* stream (direction) */ |
368 | char latency_id[20]; /* latency identifier */ | 373 | struct pm_qos_request_list latency_pm_qos_req; /* pm_qos request */ |
369 | size_t buffer_bytes_max; /* limit ring buffer size */ | 374 | size_t buffer_bytes_max; /* limit ring buffer size */ |
370 | struct snd_dma_buffer dma_buffer; | 375 | struct snd_dma_buffer dma_buffer; |
371 | unsigned int dma_buf_id; | 376 | unsigned int dma_buf_id; |
diff --git a/include/sound/sh_fsi.h b/include/sound/sh_fsi.h index c0227361a876..9d51d6f35893 100644 --- a/include/sound/sh_fsi.h +++ b/include/sound/sh_fsi.h | |||
@@ -12,6 +12,9 @@ | |||
12 | * published by the Free Software Foundation. | 12 | * published by the Free Software Foundation. |
13 | */ | 13 | */ |
14 | 14 | ||
15 | #define FSI_PORT_A 0 | ||
16 | #define FSI_PORT_B 1 | ||
17 | |||
15 | /* flags format | 18 | /* flags format |
16 | 19 | ||
17 | * 0xABCDEEFF | 20 | * 0xABCDEEFF |
@@ -55,12 +58,14 @@ | |||
55 | #define SH_FSI_GET_IFMT(x) ((x >> 8) & SH_FSI_FMT_MASK) | 58 | #define SH_FSI_GET_IFMT(x) ((x >> 8) & SH_FSI_FMT_MASK) |
56 | #define SH_FSI_GET_OFMT(x) ((x >> 0) & SH_FSI_FMT_MASK) | 59 | #define SH_FSI_GET_OFMT(x) ((x >> 0) & SH_FSI_FMT_MASK) |
57 | 60 | ||
58 | #define SH_FSI_FMT_MONO (1 << 0) | 61 | #define SH_FSI_FMT_MONO 0 |
59 | #define SH_FSI_FMT_MONO_DELAY (1 << 1) | 62 | #define SH_FSI_FMT_MONO_DELAY 1 |
60 | #define SH_FSI_FMT_PCM (1 << 2) | 63 | #define SH_FSI_FMT_PCM 2 |
61 | #define SH_FSI_FMT_I2S (1 << 3) | 64 | #define SH_FSI_FMT_I2S 3 |
62 | #define SH_FSI_FMT_TDM (1 << 4) | 65 | #define SH_FSI_FMT_TDM 4 |
63 | #define SH_FSI_FMT_TDM_DELAY (1 << 5) | 66 | #define SH_FSI_FMT_TDM_DELAY 5 |
67 | #define SH_FSI_FMT_SPDIF 6 | ||
68 | |||
64 | 69 | ||
65 | #define SH_FSI_IFMT_TDM_CH(x) \ | 70 | #define SH_FSI_IFMT_TDM_CH(x) \ |
66 | (SH_FSI_IFMT(TDM) | SH_FSI_SET_CH_I(x)) | 71 | (SH_FSI_IFMT(TDM) | SH_FSI_SET_CH_I(x)) |
@@ -72,9 +77,41 @@ | |||
72 | #define SH_FSI_OFMT_TDM_DELAY_CH(x) \ | 77 | #define SH_FSI_OFMT_TDM_DELAY_CH(x) \ |
73 | (SH_FSI_OFMT(TDM_DELAY) | SH_FSI_SET_CH_O(x)) | 78 | (SH_FSI_OFMT(TDM_DELAY) | SH_FSI_SET_CH_O(x)) |
74 | 79 | ||
80 | |||
81 | /* | ||
82 | * set_rate return value | ||
83 | * | ||
84 | * see ACKMD/BPFMD on | ||
85 | * ACK_MD (FSI2) | ||
86 | * CKG1 (FSI) | ||
87 | * | ||
88 | * err: return value < 0 | ||
89 | * | ||
90 | * 0x-00000AB | ||
91 | * | ||
92 | * A: ACKMD value | ||
93 | * B: BPFMD value | ||
94 | */ | ||
95 | |||
96 | #define SH_FSI_ACKMD_MASK (0xF << 0) | ||
97 | #define SH_FSI_ACKMD_512 (1 << 0) | ||
98 | #define SH_FSI_ACKMD_256 (2 << 0) | ||
99 | #define SH_FSI_ACKMD_128 (3 << 0) | ||
100 | #define SH_FSI_ACKMD_64 (4 << 0) | ||
101 | #define SH_FSI_ACKMD_32 (5 << 0) | ||
102 | |||
103 | #define SH_FSI_BPFMD_MASK (0xF << 4) | ||
104 | #define SH_FSI_BPFMD_512 (1 << 4) | ||
105 | #define SH_FSI_BPFMD_256 (2 << 4) | ||
106 | #define SH_FSI_BPFMD_128 (3 << 4) | ||
107 | #define SH_FSI_BPFMD_64 (4 << 4) | ||
108 | #define SH_FSI_BPFMD_32 (5 << 4) | ||
109 | #define SH_FSI_BPFMD_16 (6 << 4) | ||
110 | |||
75 | struct sh_fsi_platform_info { | 111 | struct sh_fsi_platform_info { |
76 | unsigned long porta_flags; | 112 | unsigned long porta_flags; |
77 | unsigned long portb_flags; | 113 | unsigned long portb_flags; |
114 | int (*set_rate)(int is_porta, int rate); /* for master mode */ | ||
78 | }; | 115 | }; |
79 | 116 | ||
80 | extern struct snd_soc_dai fsi_soc_dai[2]; | 117 | extern struct snd_soc_dai fsi_soc_dai[2]; |
diff --git a/include/sound/soc-dai.h b/include/sound/soc-dai.h index 0a0b019d41ad..377693a14385 100644 --- a/include/sound/soc-dai.h +++ b/include/sound/soc-dai.h | |||
@@ -182,6 +182,12 @@ struct snd_soc_dai_ops { | |||
182 | struct snd_soc_dai *); | 182 | struct snd_soc_dai *); |
183 | int (*trigger)(struct snd_pcm_substream *, int, | 183 | int (*trigger)(struct snd_pcm_substream *, int, |
184 | struct snd_soc_dai *); | 184 | struct snd_soc_dai *); |
185 | /* | ||
186 | * For hardware based FIFO caused delay reporting. | ||
187 | * Optional. | ||
188 | */ | ||
189 | snd_pcm_sframes_t (*delay)(struct snd_pcm_substream *, | ||
190 | struct snd_soc_dai *); | ||
185 | }; | 191 | }; |
186 | 192 | ||
187 | /* | 193 | /* |
@@ -215,7 +221,6 @@ struct snd_soc_dai { | |||
215 | unsigned int symmetric_rates:1; | 221 | unsigned int symmetric_rates:1; |
216 | 222 | ||
217 | /* DAI runtime info */ | 223 | /* DAI runtime info */ |
218 | struct snd_pcm_runtime *runtime; | ||
219 | struct snd_soc_codec *codec; | 224 | struct snd_soc_codec *codec; |
220 | unsigned int active; | 225 | unsigned int active; |
221 | unsigned char pop_wait:1; | 226 | unsigned char pop_wait:1; |
diff --git a/include/sound/soc-dapm.h b/include/sound/soc-dapm.h index c0922a034223..c5d9987bc897 100644 --- a/include/sound/soc-dapm.h +++ b/include/sound/soc-dapm.h | |||
@@ -273,6 +273,8 @@ | |||
273 | #define SND_SOC_DAPM_POST_PMD 0x8 /* after widget power down */ | 273 | #define SND_SOC_DAPM_POST_PMD 0x8 /* after widget power down */ |
274 | #define SND_SOC_DAPM_PRE_REG 0x10 /* before audio path setup */ | 274 | #define SND_SOC_DAPM_PRE_REG 0x10 /* before audio path setup */ |
275 | #define SND_SOC_DAPM_POST_REG 0x20 /* after audio path setup */ | 275 | #define SND_SOC_DAPM_POST_REG 0x20 /* after audio path setup */ |
276 | #define SND_SOC_DAPM_PRE_POST_PMD \ | ||
277 | (SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD) | ||
276 | 278 | ||
277 | /* convenience event type detection */ | 279 | /* convenience event type detection */ |
278 | #define SND_SOC_DAPM_EVENT_ON(e) \ | 280 | #define SND_SOC_DAPM_EVENT_ON(e) \ |
@@ -339,6 +341,9 @@ int snd_soc_dapm_disable_pin(struct snd_soc_codec *codec, const char *pin); | |||
339 | int snd_soc_dapm_nc_pin(struct snd_soc_codec *codec, const char *pin); | 341 | int snd_soc_dapm_nc_pin(struct snd_soc_codec *codec, const char *pin); |
340 | int snd_soc_dapm_get_pin_status(struct snd_soc_codec *codec, const char *pin); | 342 | int snd_soc_dapm_get_pin_status(struct snd_soc_codec *codec, const char *pin); |
341 | int snd_soc_dapm_sync(struct snd_soc_codec *codec); | 343 | int snd_soc_dapm_sync(struct snd_soc_codec *codec); |
344 | int snd_soc_dapm_force_enable_pin(struct snd_soc_codec *codec, | ||
345 | const char *pin); | ||
346 | int snd_soc_dapm_ignore_suspend(struct snd_soc_codec *codec, const char *pin); | ||
342 | 347 | ||
343 | /* dapm widget types */ | 348 | /* dapm widget types */ |
344 | enum snd_soc_dapm_type { | 349 | enum snd_soc_dapm_type { |
@@ -425,9 +430,8 @@ struct snd_soc_dapm_widget { | |||
425 | unsigned char connected:1; /* connected codec pin */ | 430 | unsigned char connected:1; /* connected codec pin */ |
426 | unsigned char new:1; /* cnew complete */ | 431 | unsigned char new:1; /* cnew complete */ |
427 | unsigned char ext:1; /* has external widgets */ | 432 | unsigned char ext:1; /* has external widgets */ |
428 | unsigned char muted:1; /* muted for pop reduction */ | 433 | unsigned char force:1; /* force state */ |
429 | unsigned char suspend:1; /* was active before suspend */ | 434 | unsigned char ignore_suspend:1; /* kept enabled over suspend */ |
430 | unsigned char pmdown:1; /* waiting for timeout */ | ||
431 | 435 | ||
432 | int (*power_check)(struct snd_soc_dapm_widget *w); | 436 | int (*power_check)(struct snd_soc_dapm_widget *w); |
433 | 437 | ||
diff --git a/include/sound/soc.h b/include/sound/soc.h index a57fbfcd4c8f..65e9d03ed4f5 100644 --- a/include/sound/soc.h +++ b/include/sound/soc.h | |||
@@ -15,6 +15,7 @@ | |||
15 | 15 | ||
16 | #include <linux/platform_device.h> | 16 | #include <linux/platform_device.h> |
17 | #include <linux/types.h> | 17 | #include <linux/types.h> |
18 | #include <linux/notifier.h> | ||
18 | #include <linux/workqueue.h> | 19 | #include <linux/workqueue.h> |
19 | #include <linux/interrupt.h> | 20 | #include <linux/interrupt.h> |
20 | #include <linux/kernel.h> | 21 | #include <linux/kernel.h> |
@@ -29,10 +30,10 @@ | |||
29 | #define SOC_SINGLE_VALUE(xreg, xshift, xmax, xinvert) \ | 30 | #define SOC_SINGLE_VALUE(xreg, xshift, xmax, xinvert) \ |
30 | ((unsigned long)&(struct soc_mixer_control) \ | 31 | ((unsigned long)&(struct soc_mixer_control) \ |
31 | {.reg = xreg, .shift = xshift, .rshift = xshift, .max = xmax, \ | 32 | {.reg = xreg, .shift = xshift, .rshift = xshift, .max = xmax, \ |
32 | .invert = xinvert}) | 33 | .platform_max = xmax, .invert = xinvert}) |
33 | #define SOC_SINGLE_VALUE_EXT(xreg, xmax, xinvert) \ | 34 | #define SOC_SINGLE_VALUE_EXT(xreg, xmax, xinvert) \ |
34 | ((unsigned long)&(struct soc_mixer_control) \ | 35 | ((unsigned long)&(struct soc_mixer_control) \ |
35 | {.reg = xreg, .max = xmax, .invert = xinvert}) | 36 | {.reg = xreg, .max = xmax, .platform_max = xmax, .invert = xinvert}) |
36 | #define SOC_SINGLE(xname, reg, shift, max, invert) \ | 37 | #define SOC_SINGLE(xname, reg, shift, max, invert) \ |
37 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ | 38 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ |
38 | .info = snd_soc_info_volsw, .get = snd_soc_get_volsw,\ | 39 | .info = snd_soc_info_volsw, .get = snd_soc_get_volsw,\ |
@@ -52,14 +53,14 @@ | |||
52 | .put = snd_soc_put_volsw, \ | 53 | .put = snd_soc_put_volsw, \ |
53 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 54 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
54 | {.reg = xreg, .shift = shift_left, .rshift = shift_right, \ | 55 | {.reg = xreg, .shift = shift_left, .rshift = shift_right, \ |
55 | .max = xmax, .invert = xinvert} } | 56 | .max = xmax, .platform_max = xmax, .invert = xinvert} } |
56 | #define SOC_DOUBLE_R(xname, reg_left, reg_right, xshift, xmax, xinvert) \ | 57 | #define SOC_DOUBLE_R(xname, reg_left, reg_right, xshift, xmax, xinvert) \ |
57 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), \ | 58 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), \ |
58 | .info = snd_soc_info_volsw_2r, \ | 59 | .info = snd_soc_info_volsw_2r, \ |
59 | .get = snd_soc_get_volsw_2r, .put = snd_soc_put_volsw_2r, \ | 60 | .get = snd_soc_get_volsw_2r, .put = snd_soc_put_volsw_2r, \ |
60 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 61 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
61 | {.reg = reg_left, .rreg = reg_right, .shift = xshift, \ | 62 | {.reg = reg_left, .rreg = reg_right, .shift = xshift, \ |
62 | .max = xmax, .invert = xinvert} } | 63 | .max = xmax, .platform_max = xmax, .invert = xinvert} } |
63 | #define SOC_DOUBLE_TLV(xname, xreg, shift_left, shift_right, xmax, xinvert, tlv_array) \ | 64 | #define SOC_DOUBLE_TLV(xname, xreg, shift_left, shift_right, xmax, xinvert, tlv_array) \ |
64 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname),\ | 65 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname),\ |
65 | .access = SNDRV_CTL_ELEM_ACCESS_TLV_READ |\ | 66 | .access = SNDRV_CTL_ELEM_ACCESS_TLV_READ |\ |
@@ -69,7 +70,7 @@ | |||
69 | .put = snd_soc_put_volsw, \ | 70 | .put = snd_soc_put_volsw, \ |
70 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 71 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
71 | {.reg = xreg, .shift = shift_left, .rshift = shift_right,\ | 72 | {.reg = xreg, .shift = shift_left, .rshift = shift_right,\ |
72 | .max = xmax, .invert = xinvert} } | 73 | .max = xmax, .platform_max = xmax, .invert = xinvert} } |
73 | #define SOC_DOUBLE_R_TLV(xname, reg_left, reg_right, xshift, xmax, xinvert, tlv_array) \ | 74 | #define SOC_DOUBLE_R_TLV(xname, reg_left, reg_right, xshift, xmax, xinvert, tlv_array) \ |
74 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname),\ | 75 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname),\ |
75 | .access = SNDRV_CTL_ELEM_ACCESS_TLV_READ |\ | 76 | .access = SNDRV_CTL_ELEM_ACCESS_TLV_READ |\ |
@@ -79,7 +80,7 @@ | |||
79 | .get = snd_soc_get_volsw_2r, .put = snd_soc_put_volsw_2r, \ | 80 | .get = snd_soc_get_volsw_2r, .put = snd_soc_put_volsw_2r, \ |
80 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 81 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
81 | {.reg = reg_left, .rreg = reg_right, .shift = xshift, \ | 82 | {.reg = reg_left, .rreg = reg_right, .shift = xshift, \ |
82 | .max = xmax, .invert = xinvert} } | 83 | .max = xmax, .platform_max = xmax, .invert = xinvert} } |
83 | #define SOC_DOUBLE_S8_TLV(xname, xreg, xmin, xmax, tlv_array) \ | 84 | #define SOC_DOUBLE_S8_TLV(xname, xreg, xmin, xmax, tlv_array) \ |
84 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), \ | 85 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), \ |
85 | .access = SNDRV_CTL_ELEM_ACCESS_TLV_READ | \ | 86 | .access = SNDRV_CTL_ELEM_ACCESS_TLV_READ | \ |
@@ -88,7 +89,8 @@ | |||
88 | .info = snd_soc_info_volsw_s8, .get = snd_soc_get_volsw_s8, \ | 89 | .info = snd_soc_info_volsw_s8, .get = snd_soc_get_volsw_s8, \ |
89 | .put = snd_soc_put_volsw_s8, \ | 90 | .put = snd_soc_put_volsw_s8, \ |
90 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 91 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
91 | {.reg = xreg, .min = xmin, .max = xmax} } | 92 | {.reg = xreg, .min = xmin, .max = xmax, \ |
93 | .platform_max = xmax} } | ||
92 | #define SOC_ENUM_DOUBLE(xreg, xshift_l, xshift_r, xmax, xtexts) \ | 94 | #define SOC_ENUM_DOUBLE(xreg, xshift_l, xshift_r, xmax, xtexts) \ |
93 | { .reg = xreg, .shift_l = xshift_l, .shift_r = xshift_r, \ | 95 | { .reg = xreg, .shift_l = xshift_l, .shift_r = xshift_r, \ |
94 | .max = xmax, .texts = xtexts } | 96 | .max = xmax, .texts = xtexts } |
@@ -125,7 +127,7 @@ | |||
125 | .get = xhandler_get, .put = xhandler_put, \ | 127 | .get = xhandler_get, .put = xhandler_put, \ |
126 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 128 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
127 | {.reg = xreg, .shift = shift_left, .rshift = shift_right, \ | 129 | {.reg = xreg, .shift = shift_left, .rshift = shift_right, \ |
128 | .max = xmax, .invert = xinvert} } | 130 | .max = xmax, .platform_max = xmax, .invert = xinvert} } |
129 | #define SOC_SINGLE_EXT_TLV(xname, xreg, xshift, xmax, xinvert,\ | 131 | #define SOC_SINGLE_EXT_TLV(xname, xreg, xshift, xmax, xinvert,\ |
130 | xhandler_get, xhandler_put, tlv_array) \ | 132 | xhandler_get, xhandler_put, tlv_array) \ |
131 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ | 133 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ |
@@ -145,7 +147,7 @@ | |||
145 | .get = xhandler_get, .put = xhandler_put, \ | 147 | .get = xhandler_get, .put = xhandler_put, \ |
146 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 148 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
147 | {.reg = xreg, .shift = shift_left, .rshift = shift_right, \ | 149 | {.reg = xreg, .shift = shift_left, .rshift = shift_right, \ |
148 | .max = xmax, .invert = xinvert} } | 150 | .max = xmax, .platform_max = xmax, .invert = xinvert} } |
149 | #define SOC_DOUBLE_R_EXT_TLV(xname, reg_left, reg_right, xshift, xmax, xinvert,\ | 151 | #define SOC_DOUBLE_R_EXT_TLV(xname, reg_left, reg_right, xshift, xmax, xinvert,\ |
150 | xhandler_get, xhandler_put, tlv_array) \ | 152 | xhandler_get, xhandler_put, tlv_array) \ |
151 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), \ | 153 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), \ |
@@ -156,7 +158,7 @@ | |||
156 | .get = xhandler_get, .put = xhandler_put, \ | 158 | .get = xhandler_get, .put = xhandler_put, \ |
157 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | 159 | .private_value = (unsigned long)&(struct soc_mixer_control) \ |
158 | {.reg = reg_left, .rreg = reg_right, .shift = xshift, \ | 160 | {.reg = reg_left, .rreg = reg_right, .shift = xshift, \ |
159 | .max = xmax, .invert = xinvert} } | 161 | .max = xmax, .platform_max = xmax, .invert = xinvert} } |
160 | #define SOC_SINGLE_BOOL_EXT(xname, xdata, xhandler_get, xhandler_put) \ | 162 | #define SOC_SINGLE_BOOL_EXT(xname, xdata, xhandler_get, xhandler_put) \ |
161 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ | 163 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ |
162 | .info = snd_soc_info_bool_ext, \ | 164 | .info = snd_soc_info_bool_ext, \ |
@@ -168,6 +170,21 @@ | |||
168 | .get = xhandler_get, .put = xhandler_put, \ | 170 | .get = xhandler_get, .put = xhandler_put, \ |
169 | .private_value = (unsigned long)&xenum } | 171 | .private_value = (unsigned long)&xenum } |
170 | 172 | ||
173 | #define SOC_DOUBLE_R_SX_TLV(xname, xreg_left, xreg_right, xshift,\ | ||
174 | xmin, xmax, tlv_array) \ | ||
175 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), \ | ||
176 | .access = SNDRV_CTL_ELEM_ACCESS_TLV_READ | \ | ||
177 | SNDRV_CTL_ELEM_ACCESS_READWRITE, \ | ||
178 | .tlv.p = (tlv_array), \ | ||
179 | .info = snd_soc_info_volsw_2r_sx, \ | ||
180 | .get = snd_soc_get_volsw_2r_sx, \ | ||
181 | .put = snd_soc_put_volsw_2r_sx, \ | ||
182 | .private_value = (unsigned long)&(struct soc_mixer_control) \ | ||
183 | {.reg = xreg_left, \ | ||
184 | .rreg = xreg_right, .shift = xshift, \ | ||
185 | .min = xmin, .max = xmax} } | ||
186 | |||
187 | |||
171 | /* | 188 | /* |
172 | * Simplified versions of above macros, declaring a struct and calculating | 189 | * Simplified versions of above macros, declaring a struct and calculating |
173 | * ARRAY_SIZE internally | 190 | * ARRAY_SIZE internally |
@@ -212,6 +229,7 @@ struct snd_soc_dai_mode; | |||
212 | struct snd_soc_pcm_runtime; | 229 | struct snd_soc_pcm_runtime; |
213 | struct snd_soc_dai; | 230 | struct snd_soc_dai; |
214 | struct snd_soc_platform; | 231 | struct snd_soc_platform; |
232 | struct snd_soc_dai_link; | ||
215 | struct snd_soc_codec; | 233 | struct snd_soc_codec; |
216 | struct soc_enum; | 234 | struct soc_enum; |
217 | struct snd_soc_ac97_ops; | 235 | struct snd_soc_ac97_ops; |
@@ -260,6 +278,10 @@ int snd_soc_jack_new(struct snd_soc_card *card, const char *id, int type, | |||
260 | void snd_soc_jack_report(struct snd_soc_jack *jack, int status, int mask); | 278 | void snd_soc_jack_report(struct snd_soc_jack *jack, int status, int mask); |
261 | int snd_soc_jack_add_pins(struct snd_soc_jack *jack, int count, | 279 | int snd_soc_jack_add_pins(struct snd_soc_jack *jack, int count, |
262 | struct snd_soc_jack_pin *pins); | 280 | struct snd_soc_jack_pin *pins); |
281 | void snd_soc_jack_notifier_register(struct snd_soc_jack *jack, | ||
282 | struct notifier_block *nb); | ||
283 | void snd_soc_jack_notifier_unregister(struct snd_soc_jack *jack, | ||
284 | struct notifier_block *nb); | ||
263 | #ifdef CONFIG_GPIOLIB | 285 | #ifdef CONFIG_GPIOLIB |
264 | int snd_soc_jack_add_gpios(struct snd_soc_jack *jack, int count, | 286 | int snd_soc_jack_add_gpios(struct snd_soc_jack *jack, int count, |
265 | struct snd_soc_jack_gpio *gpios); | 287 | struct snd_soc_jack_gpio *gpios); |
@@ -320,6 +342,14 @@ int snd_soc_get_volsw_s8(struct snd_kcontrol *kcontrol, | |||
320 | struct snd_ctl_elem_value *ucontrol); | 342 | struct snd_ctl_elem_value *ucontrol); |
321 | int snd_soc_put_volsw_s8(struct snd_kcontrol *kcontrol, | 343 | int snd_soc_put_volsw_s8(struct snd_kcontrol *kcontrol, |
322 | struct snd_ctl_elem_value *ucontrol); | 344 | struct snd_ctl_elem_value *ucontrol); |
345 | int snd_soc_limit_volume(struct snd_soc_codec *codec, | ||
346 | const char *name, int max); | ||
347 | int snd_soc_info_volsw_2r_sx(struct snd_kcontrol *kcontrol, | ||
348 | struct snd_ctl_elem_info *uinfo); | ||
349 | int snd_soc_get_volsw_2r_sx(struct snd_kcontrol *kcontrol, | ||
350 | struct snd_ctl_elem_value *ucontrol); | ||
351 | int snd_soc_put_volsw_2r_sx(struct snd_kcontrol *kcontrol, | ||
352 | struct snd_ctl_elem_value *ucontrol); | ||
323 | 353 | ||
324 | /** | 354 | /** |
325 | * struct snd_soc_jack_pin - Describes a pin to update based on jack detection | 355 | * struct snd_soc_jack_pin - Describes a pin to update based on jack detection |
@@ -363,6 +393,7 @@ struct snd_soc_jack { | |||
363 | struct snd_soc_card *card; | 393 | struct snd_soc_card *card; |
364 | struct list_head pins; | 394 | struct list_head pins; |
365 | int status; | 395 | int status; |
396 | struct blocking_notifier_head notifier; | ||
366 | }; | 397 | }; |
367 | 398 | ||
368 | /* SoC PCM stream information */ | 399 | /* SoC PCM stream information */ |
@@ -374,7 +405,7 @@ struct snd_soc_pcm_stream { | |||
374 | unsigned int rate_max; /* max rate */ | 405 | unsigned int rate_max; /* max rate */ |
375 | unsigned int channels_min; /* min channels */ | 406 | unsigned int channels_min; /* min channels */ |
376 | unsigned int channels_max; /* max channels */ | 407 | unsigned int channels_max; /* max channels */ |
377 | unsigned int active:1; /* stream is in use */ | 408 | unsigned int active; /* stream is in use */ |
378 | void *dma_data; /* used by platform code */ | 409 | void *dma_data; /* used by platform code */ |
379 | }; | 410 | }; |
380 | 411 | ||
@@ -407,7 +438,7 @@ struct snd_soc_codec { | |||
407 | struct snd_ac97 *ac97; /* for ad-hoc ac97 devices */ | 438 | struct snd_ac97 *ac97; /* for ad-hoc ac97 devices */ |
408 | unsigned int active; | 439 | unsigned int active; |
409 | unsigned int pcm_devs; | 440 | unsigned int pcm_devs; |
410 | void *private_data; | 441 | void *drvdata; |
411 | 442 | ||
412 | /* codec IO */ | 443 | /* codec IO */ |
413 | void *control_data; /* codec control (i2c/3wire) data */ | 444 | void *control_data; /* codec control (i2c/3wire) data */ |
@@ -462,14 +493,21 @@ struct snd_soc_platform { | |||
462 | 493 | ||
463 | int (*probe)(struct platform_device *pdev); | 494 | int (*probe)(struct platform_device *pdev); |
464 | int (*remove)(struct platform_device *pdev); | 495 | int (*remove)(struct platform_device *pdev); |
465 | int (*suspend)(struct snd_soc_dai *dai); | 496 | int (*suspend)(struct snd_soc_dai_link *dai_link); |
466 | int (*resume)(struct snd_soc_dai *dai); | 497 | int (*resume)(struct snd_soc_dai_link *dai_link); |
467 | 498 | ||
468 | /* pcm creation and destruction */ | 499 | /* pcm creation and destruction */ |
469 | int (*pcm_new)(struct snd_card *, struct snd_soc_dai *, | 500 | int (*pcm_new)(struct snd_card *, struct snd_soc_dai *, |
470 | struct snd_pcm *); | 501 | struct snd_pcm *); |
471 | void (*pcm_free)(struct snd_pcm *); | 502 | void (*pcm_free)(struct snd_pcm *); |
472 | 503 | ||
504 | /* | ||
505 | * For platform caused delay reporting. | ||
506 | * Optional. | ||
507 | */ | ||
508 | snd_pcm_sframes_t (*delay)(struct snd_pcm_substream *, | ||
509 | struct snd_soc_dai *); | ||
510 | |||
473 | /* platform stream ops */ | 511 | /* platform stream ops */ |
474 | struct snd_pcm_ops *pcm_ops; | 512 | struct snd_pcm_ops *pcm_ops; |
475 | }; | 513 | }; |
@@ -489,6 +527,9 @@ struct snd_soc_dai_link { | |||
489 | /* codec/machine specific init - e.g. add machine controls */ | 527 | /* codec/machine specific init - e.g. add machine controls */ |
490 | int (*init)(struct snd_soc_codec *codec); | 528 | int (*init)(struct snd_soc_codec *codec); |
491 | 529 | ||
530 | /* Keep DAI active over suspend */ | ||
531 | unsigned int ignore_suspend:1; | ||
532 | |||
492 | /* Symmetry requirements */ | 533 | /* Symmetry requirements */ |
493 | unsigned int symmetric_rates:1; | 534 | unsigned int symmetric_rates:1; |
494 | 535 | ||
@@ -553,7 +594,7 @@ struct snd_soc_pcm_runtime { | |||
553 | 594 | ||
554 | /* mixer control */ | 595 | /* mixer control */ |
555 | struct soc_mixer_control { | 596 | struct soc_mixer_control { |
556 | int min, max; | 597 | int min, max, platform_max; |
557 | unsigned int reg, rreg, shift, rshift, invert; | 598 | unsigned int reg, rreg, shift, rshift, invert; |
558 | }; | 599 | }; |
559 | 600 | ||
@@ -583,6 +624,17 @@ static inline unsigned int snd_soc_write(struct snd_soc_codec *codec, | |||
583 | return codec->write(codec, reg, val); | 624 | return codec->write(codec, reg, val); |
584 | } | 625 | } |
585 | 626 | ||
627 | static inline void snd_soc_codec_set_drvdata(struct snd_soc_codec *codec, | ||
628 | void *data) | ||
629 | { | ||
630 | codec->drvdata = data; | ||
631 | } | ||
632 | |||
633 | static inline void *snd_soc_codec_get_drvdata(struct snd_soc_codec *codec) | ||
634 | { | ||
635 | return codec->drvdata; | ||
636 | } | ||
637 | |||
586 | #include <sound/soc-dai.h> | 638 | #include <sound/soc-dai.h> |
587 | 639 | ||
588 | #endif | 640 | #endif |
diff --git a/include/sound/tlv320aic3x.h b/include/sound/tlv320aic3x.h new file mode 100644 index 000000000000..b1a5f34e5cfa --- /dev/null +++ b/include/sound/tlv320aic3x.h | |||
@@ -0,0 +1,17 @@ | |||
1 | /* | ||
2 | * Platform data for Texas Instruments TLV320AIC3x codec | ||
3 | * | ||
4 | * Author: Jarkko Nikula <jhnikula@gmail.com> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | #ifndef __TLV320AIC3x_H__ | ||
11 | #define __TLV320AIC3x_H__ | ||
12 | |||
13 | struct aic3x_pdata { | ||
14 | int gpio_reset; /* < 0 if not used */ | ||
15 | }; | ||
16 | |||
17 | #endif \ No newline at end of file | ||
diff --git a/include/sound/tlv320dac33-plat.h b/include/sound/tlv320dac33-plat.h index ac0665264bdf..6c6649656798 100644 --- a/include/sound/tlv320dac33-plat.h +++ b/include/sound/tlv320dac33-plat.h | |||
@@ -15,6 +15,9 @@ | |||
15 | 15 | ||
16 | struct tlv320dac33_platform_data { | 16 | struct tlv320dac33_platform_data { |
17 | int power_gpio; | 17 | int power_gpio; |
18 | int mode1_latency; /* latency caused by the i2c writes in us */ | ||
19 | int auto_fifo_config; /* FIFO config based on the period size */ | ||
20 | int keep_bclk; /* Keep the BCLK running in FIFO modes */ | ||
18 | u8 burst_bclkdiv; | 21 | u8 burst_bclkdiv; |
19 | }; | 22 | }; |
20 | 23 | ||
diff --git a/include/sound/uda134x.h b/include/sound/uda134x.h index 475ef8bb7dcd..e475659bd3be 100644 --- a/include/sound/uda134x.h +++ b/include/sound/uda134x.h | |||
@@ -18,9 +18,22 @@ struct uda134x_platform_data { | |||
18 | struct l3_pins l3; | 18 | struct l3_pins l3; |
19 | void (*power) (int); | 19 | void (*power) (int); |
20 | int model; | 20 | int model; |
21 | /* | ||
22 | ALSA SOC usually puts the device in standby mode when it's not used | ||
23 | for sometime. If you unset is_powered_on_standby the driver will | ||
24 | turn off the ADC/DAC when this callback is invoked and turn it back | ||
25 | on when needed. Unfortunately this will result in a very light bump | ||
26 | (it can be audible only with good earphones). If this bothers you | ||
27 | set is_powered_on_standby, you will have slightly higher power | ||
28 | consumption. Please note that sending the L3 command for ADC is | ||
29 | enough to make the bump, so it doesn't make difference if you | ||
30 | completely take off power from the codec. | ||
31 | */ | ||
32 | int is_powered_on_standby; | ||
21 | #define UDA134X_UDA1340 1 | 33 | #define UDA134X_UDA1340 1 |
22 | #define UDA134X_UDA1341 2 | 34 | #define UDA134X_UDA1341 2 |
23 | #define UDA134X_UDA1344 3 | 35 | #define UDA134X_UDA1344 3 |
36 | #define UDA134X_UDA1345 4 | ||
24 | }; | 37 | }; |
25 | 38 | ||
26 | #endif /* _UDA134X_H */ | 39 | #endif /* _UDA134X_H */ |
diff --git a/include/sound/version.h b/include/sound/version.h index 7fed23442db8..bf69a5b7e65f 100644 --- a/include/sound/version.h +++ b/include/sound/version.h | |||
@@ -1,3 +1,3 @@ | |||
1 | /* include/version.h */ | 1 | /* include/version.h */ |
2 | #define CONFIG_SND_VERSION "1.0.22.1" | 2 | #define CONFIG_SND_VERSION "1.0.23" |
3 | #define CONFIG_SND_DATE "" | 3 | #define CONFIG_SND_DATE "" |
diff --git a/include/sound/wm8903.h b/include/sound/wm8903.h new file mode 100644 index 000000000000..b4a0db2307ef --- /dev/null +++ b/include/sound/wm8903.h | |||
@@ -0,0 +1,249 @@ | |||
1 | /* | ||
2 | * linux/sound/wm8903.h -- Platform data for WM8903 | ||
3 | * | ||
4 | * Copyright 2010 Wolfson Microelectronics. PLC. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __LINUX_SND_WM8903_H | ||
12 | #define __LINUX_SND_WM8903_H | ||
13 | |||
14 | /* Used to enable configuration of a GPIO to all zeros */ | ||
15 | #define WM8903_GPIO_NO_CONFIG 0x8000 | ||
16 | |||
17 | /* | ||
18 | * R6 (0x06) - Mic Bias Control 0 | ||
19 | */ | ||
20 | #define WM8903_MICDET_HYST_ENA 0x0080 /* MICDET_HYST_ENA */ | ||
21 | #define WM8903_MICDET_HYST_ENA_MASK 0x0080 /* MICDET_HYST_ENA */ | ||
22 | #define WM8903_MICDET_HYST_ENA_SHIFT 7 /* MICDET_HYST_ENA */ | ||
23 | #define WM8903_MICDET_HYST_ENA_WIDTH 1 /* MICDET_HYST_ENA */ | ||
24 | #define WM8903_MICDET_THR_MASK 0x0070 /* MICDET_THR - [6:4] */ | ||
25 | #define WM8903_MICDET_THR_SHIFT 4 /* MICDET_THR - [6:4] */ | ||
26 | #define WM8903_MICDET_THR_WIDTH 3 /* MICDET_THR - [6:4] */ | ||
27 | #define WM8903_MICSHORT_THR_MASK 0x000C /* MICSHORT_THR - [3:2] */ | ||
28 | #define WM8903_MICSHORT_THR_SHIFT 2 /* MICSHORT_THR - [3:2] */ | ||
29 | #define WM8903_MICSHORT_THR_WIDTH 2 /* MICSHORT_THR - [3:2] */ | ||
30 | #define WM8903_MICDET_ENA 0x0002 /* MICDET_ENA */ | ||
31 | #define WM8903_MICDET_ENA_MASK 0x0002 /* MICDET_ENA */ | ||
32 | #define WM8903_MICDET_ENA_SHIFT 1 /* MICDET_ENA */ | ||
33 | #define WM8903_MICDET_ENA_WIDTH 1 /* MICDET_ENA */ | ||
34 | #define WM8903_MICBIAS_ENA 0x0001 /* MICBIAS_ENA */ | ||
35 | #define WM8903_MICBIAS_ENA_MASK 0x0001 /* MICBIAS_ENA */ | ||
36 | #define WM8903_MICBIAS_ENA_SHIFT 0 /* MICBIAS_ENA */ | ||
37 | #define WM8903_MICBIAS_ENA_WIDTH 1 /* MICBIAS_ENA */ | ||
38 | |||
39 | /* | ||
40 | * R116 (0x74) - GPIO Control 1 | ||
41 | */ | ||
42 | #define WM8903_GP1_FN_MASK 0x1F00 /* GP1_FN - [12:8] */ | ||
43 | #define WM8903_GP1_FN_SHIFT 8 /* GP1_FN - [12:8] */ | ||
44 | #define WM8903_GP1_FN_WIDTH 5 /* GP1_FN - [12:8] */ | ||
45 | #define WM8903_GP1_DIR 0x0080 /* GP1_DIR */ | ||
46 | #define WM8903_GP1_DIR_MASK 0x0080 /* GP1_DIR */ | ||
47 | #define WM8903_GP1_DIR_SHIFT 7 /* GP1_DIR */ | ||
48 | #define WM8903_GP1_DIR_WIDTH 1 /* GP1_DIR */ | ||
49 | #define WM8903_GP1_OP_CFG 0x0040 /* GP1_OP_CFG */ | ||
50 | #define WM8903_GP1_OP_CFG_MASK 0x0040 /* GP1_OP_CFG */ | ||
51 | #define WM8903_GP1_OP_CFG_SHIFT 6 /* GP1_OP_CFG */ | ||
52 | #define WM8903_GP1_OP_CFG_WIDTH 1 /* GP1_OP_CFG */ | ||
53 | #define WM8903_GP1_IP_CFG 0x0020 /* GP1_IP_CFG */ | ||
54 | #define WM8903_GP1_IP_CFG_MASK 0x0020 /* GP1_IP_CFG */ | ||
55 | #define WM8903_GP1_IP_CFG_SHIFT 5 /* GP1_IP_CFG */ | ||
56 | #define WM8903_GP1_IP_CFG_WIDTH 1 /* GP1_IP_CFG */ | ||
57 | #define WM8903_GP1_LVL 0x0010 /* GP1_LVL */ | ||
58 | #define WM8903_GP1_LVL_MASK 0x0010 /* GP1_LVL */ | ||
59 | #define WM8903_GP1_LVL_SHIFT 4 /* GP1_LVL */ | ||
60 | #define WM8903_GP1_LVL_WIDTH 1 /* GP1_LVL */ | ||
61 | #define WM8903_GP1_PD 0x0008 /* GP1_PD */ | ||
62 | #define WM8903_GP1_PD_MASK 0x0008 /* GP1_PD */ | ||
63 | #define WM8903_GP1_PD_SHIFT 3 /* GP1_PD */ | ||
64 | #define WM8903_GP1_PD_WIDTH 1 /* GP1_PD */ | ||
65 | #define WM8903_GP1_PU 0x0004 /* GP1_PU */ | ||
66 | #define WM8903_GP1_PU_MASK 0x0004 /* GP1_PU */ | ||
67 | #define WM8903_GP1_PU_SHIFT 2 /* GP1_PU */ | ||
68 | #define WM8903_GP1_PU_WIDTH 1 /* GP1_PU */ | ||
69 | #define WM8903_GP1_INTMODE 0x0002 /* GP1_INTMODE */ | ||
70 | #define WM8903_GP1_INTMODE_MASK 0x0002 /* GP1_INTMODE */ | ||
71 | #define WM8903_GP1_INTMODE_SHIFT 1 /* GP1_INTMODE */ | ||
72 | #define WM8903_GP1_INTMODE_WIDTH 1 /* GP1_INTMODE */ | ||
73 | #define WM8903_GP1_DB 0x0001 /* GP1_DB */ | ||
74 | #define WM8903_GP1_DB_MASK 0x0001 /* GP1_DB */ | ||
75 | #define WM8903_GP1_DB_SHIFT 0 /* GP1_DB */ | ||
76 | #define WM8903_GP1_DB_WIDTH 1 /* GP1_DB */ | ||
77 | |||
78 | /* | ||
79 | * R117 (0x75) - GPIO Control 2 | ||
80 | */ | ||
81 | #define WM8903_GP2_FN_MASK 0x1F00 /* GP2_FN - [12:8] */ | ||
82 | #define WM8903_GP2_FN_SHIFT 8 /* GP2_FN - [12:8] */ | ||
83 | #define WM8903_GP2_FN_WIDTH 5 /* GP2_FN - [12:8] */ | ||
84 | #define WM8903_GP2_DIR 0x0080 /* GP2_DIR */ | ||
85 | #define WM8903_GP2_DIR_MASK 0x0080 /* GP2_DIR */ | ||
86 | #define WM8903_GP2_DIR_SHIFT 7 /* GP2_DIR */ | ||
87 | #define WM8903_GP2_DIR_WIDTH 1 /* GP2_DIR */ | ||
88 | #define WM8903_GP2_OP_CFG 0x0040 /* GP2_OP_CFG */ | ||
89 | #define WM8903_GP2_OP_CFG_MASK 0x0040 /* GP2_OP_CFG */ | ||
90 | #define WM8903_GP2_OP_CFG_SHIFT 6 /* GP2_OP_CFG */ | ||
91 | #define WM8903_GP2_OP_CFG_WIDTH 1 /* GP2_OP_CFG */ | ||
92 | #define WM8903_GP2_IP_CFG 0x0020 /* GP2_IP_CFG */ | ||
93 | #define WM8903_GP2_IP_CFG_MASK 0x0020 /* GP2_IP_CFG */ | ||
94 | #define WM8903_GP2_IP_CFG_SHIFT 5 /* GP2_IP_CFG */ | ||
95 | #define WM8903_GP2_IP_CFG_WIDTH 1 /* GP2_IP_CFG */ | ||
96 | #define WM8903_GP2_LVL 0x0010 /* GP2_LVL */ | ||
97 | #define WM8903_GP2_LVL_MASK 0x0010 /* GP2_LVL */ | ||
98 | #define WM8903_GP2_LVL_SHIFT 4 /* GP2_LVL */ | ||
99 | #define WM8903_GP2_LVL_WIDTH 1 /* GP2_LVL */ | ||
100 | #define WM8903_GP2_PD 0x0008 /* GP2_PD */ | ||
101 | #define WM8903_GP2_PD_MASK 0x0008 /* GP2_PD */ | ||
102 | #define WM8903_GP2_PD_SHIFT 3 /* GP2_PD */ | ||
103 | #define WM8903_GP2_PD_WIDTH 1 /* GP2_PD */ | ||
104 | #define WM8903_GP2_PU 0x0004 /* GP2_PU */ | ||
105 | #define WM8903_GP2_PU_MASK 0x0004 /* GP2_PU */ | ||
106 | #define WM8903_GP2_PU_SHIFT 2 /* GP2_PU */ | ||
107 | #define WM8903_GP2_PU_WIDTH 1 /* GP2_PU */ | ||
108 | #define WM8903_GP2_INTMODE 0x0002 /* GP2_INTMODE */ | ||
109 | #define WM8903_GP2_INTMODE_MASK 0x0002 /* GP2_INTMODE */ | ||
110 | #define WM8903_GP2_INTMODE_SHIFT 1 /* GP2_INTMODE */ | ||
111 | #define WM8903_GP2_INTMODE_WIDTH 1 /* GP2_INTMODE */ | ||
112 | #define WM8903_GP2_DB 0x0001 /* GP2_DB */ | ||
113 | #define WM8903_GP2_DB_MASK 0x0001 /* GP2_DB */ | ||
114 | #define WM8903_GP2_DB_SHIFT 0 /* GP2_DB */ | ||
115 | #define WM8903_GP2_DB_WIDTH 1 /* GP2_DB */ | ||
116 | |||
117 | /* | ||
118 | * R118 (0x76) - GPIO Control 3 | ||
119 | */ | ||
120 | #define WM8903_GP3_FN_MASK 0x1F00 /* GP3_FN - [12:8] */ | ||
121 | #define WM8903_GP3_FN_SHIFT 8 /* GP3_FN - [12:8] */ | ||
122 | #define WM8903_GP3_FN_WIDTH 5 /* GP3_FN - [12:8] */ | ||
123 | #define WM8903_GP3_DIR 0x0080 /* GP3_DIR */ | ||
124 | #define WM8903_GP3_DIR_MASK 0x0080 /* GP3_DIR */ | ||
125 | #define WM8903_GP3_DIR_SHIFT 7 /* GP3_DIR */ | ||
126 | #define WM8903_GP3_DIR_WIDTH 1 /* GP3_DIR */ | ||
127 | #define WM8903_GP3_OP_CFG 0x0040 /* GP3_OP_CFG */ | ||
128 | #define WM8903_GP3_OP_CFG_MASK 0x0040 /* GP3_OP_CFG */ | ||
129 | #define WM8903_GP3_OP_CFG_SHIFT 6 /* GP3_OP_CFG */ | ||
130 | #define WM8903_GP3_OP_CFG_WIDTH 1 /* GP3_OP_CFG */ | ||
131 | #define WM8903_GP3_IP_CFG 0x0020 /* GP3_IP_CFG */ | ||
132 | #define WM8903_GP3_IP_CFG_MASK 0x0020 /* GP3_IP_CFG */ | ||
133 | #define WM8903_GP3_IP_CFG_SHIFT 5 /* GP3_IP_CFG */ | ||
134 | #define WM8903_GP3_IP_CFG_WIDTH 1 /* GP3_IP_CFG */ | ||
135 | #define WM8903_GP3_LVL 0x0010 /* GP3_LVL */ | ||
136 | #define WM8903_GP3_LVL_MASK 0x0010 /* GP3_LVL */ | ||
137 | #define WM8903_GP3_LVL_SHIFT 4 /* GP3_LVL */ | ||
138 | #define WM8903_GP3_LVL_WIDTH 1 /* GP3_LVL */ | ||
139 | #define WM8903_GP3_PD 0x0008 /* GP3_PD */ | ||
140 | #define WM8903_GP3_PD_MASK 0x0008 /* GP3_PD */ | ||
141 | #define WM8903_GP3_PD_SHIFT 3 /* GP3_PD */ | ||
142 | #define WM8903_GP3_PD_WIDTH 1 /* GP3_PD */ | ||
143 | #define WM8903_GP3_PU 0x0004 /* GP3_PU */ | ||
144 | #define WM8903_GP3_PU_MASK 0x0004 /* GP3_PU */ | ||
145 | #define WM8903_GP3_PU_SHIFT 2 /* GP3_PU */ | ||
146 | #define WM8903_GP3_PU_WIDTH 1 /* GP3_PU */ | ||
147 | #define WM8903_GP3_INTMODE 0x0002 /* GP3_INTMODE */ | ||
148 | #define WM8903_GP3_INTMODE_MASK 0x0002 /* GP3_INTMODE */ | ||
149 | #define WM8903_GP3_INTMODE_SHIFT 1 /* GP3_INTMODE */ | ||
150 | #define WM8903_GP3_INTMODE_WIDTH 1 /* GP3_INTMODE */ | ||
151 | #define WM8903_GP3_DB 0x0001 /* GP3_DB */ | ||
152 | #define WM8903_GP3_DB_MASK 0x0001 /* GP3_DB */ | ||
153 | #define WM8903_GP3_DB_SHIFT 0 /* GP3_DB */ | ||
154 | #define WM8903_GP3_DB_WIDTH 1 /* GP3_DB */ | ||
155 | |||
156 | /* | ||
157 | * R119 (0x77) - GPIO Control 4 | ||
158 | */ | ||
159 | #define WM8903_GP4_FN_MASK 0x1F00 /* GP4_FN - [12:8] */ | ||
160 | #define WM8903_GP4_FN_SHIFT 8 /* GP4_FN - [12:8] */ | ||
161 | #define WM8903_GP4_FN_WIDTH 5 /* GP4_FN - [12:8] */ | ||
162 | #define WM8903_GP4_DIR 0x0080 /* GP4_DIR */ | ||
163 | #define WM8903_GP4_DIR_MASK 0x0080 /* GP4_DIR */ | ||
164 | #define WM8903_GP4_DIR_SHIFT 7 /* GP4_DIR */ | ||
165 | #define WM8903_GP4_DIR_WIDTH 1 /* GP4_DIR */ | ||
166 | #define WM8903_GP4_OP_CFG 0x0040 /* GP4_OP_CFG */ | ||
167 | #define WM8903_GP4_OP_CFG_MASK 0x0040 /* GP4_OP_CFG */ | ||
168 | #define WM8903_GP4_OP_CFG_SHIFT 6 /* GP4_OP_CFG */ | ||
169 | #define WM8903_GP4_OP_CFG_WIDTH 1 /* GP4_OP_CFG */ | ||
170 | #define WM8903_GP4_IP_CFG 0x0020 /* GP4_IP_CFG */ | ||
171 | #define WM8903_GP4_IP_CFG_MASK 0x0020 /* GP4_IP_CFG */ | ||
172 | #define WM8903_GP4_IP_CFG_SHIFT 5 /* GP4_IP_CFG */ | ||
173 | #define WM8903_GP4_IP_CFG_WIDTH 1 /* GP4_IP_CFG */ | ||
174 | #define WM8903_GP4_LVL 0x0010 /* GP4_LVL */ | ||
175 | #define WM8903_GP4_LVL_MASK 0x0010 /* GP4_LVL */ | ||
176 | #define WM8903_GP4_LVL_SHIFT 4 /* GP4_LVL */ | ||
177 | #define WM8903_GP4_LVL_WIDTH 1 /* GP4_LVL */ | ||
178 | #define WM8903_GP4_PD 0x0008 /* GP4_PD */ | ||
179 | #define WM8903_GP4_PD_MASK 0x0008 /* GP4_PD */ | ||
180 | #define WM8903_GP4_PD_SHIFT 3 /* GP4_PD */ | ||
181 | #define WM8903_GP4_PD_WIDTH 1 /* GP4_PD */ | ||
182 | #define WM8903_GP4_PU 0x0004 /* GP4_PU */ | ||
183 | #define WM8903_GP4_PU_MASK 0x0004 /* GP4_PU */ | ||
184 | #define WM8903_GP4_PU_SHIFT 2 /* GP4_PU */ | ||
185 | #define WM8903_GP4_PU_WIDTH 1 /* GP4_PU */ | ||
186 | #define WM8903_GP4_INTMODE 0x0002 /* GP4_INTMODE */ | ||
187 | #define WM8903_GP4_INTMODE_MASK 0x0002 /* GP4_INTMODE */ | ||
188 | #define WM8903_GP4_INTMODE_SHIFT 1 /* GP4_INTMODE */ | ||
189 | #define WM8903_GP4_INTMODE_WIDTH 1 /* GP4_INTMODE */ | ||
190 | #define WM8903_GP4_DB 0x0001 /* GP4_DB */ | ||
191 | #define WM8903_GP4_DB_MASK 0x0001 /* GP4_DB */ | ||
192 | #define WM8903_GP4_DB_SHIFT 0 /* GP4_DB */ | ||
193 | #define WM8903_GP4_DB_WIDTH 1 /* GP4_DB */ | ||
194 | |||
195 | /* | ||
196 | * R120 (0x78) - GPIO Control 5 | ||
197 | */ | ||
198 | #define WM8903_GP5_FN_MASK 0x1F00 /* GP5_FN - [12:8] */ | ||
199 | #define WM8903_GP5_FN_SHIFT 8 /* GP5_FN - [12:8] */ | ||
200 | #define WM8903_GP5_FN_WIDTH 5 /* GP5_FN - [12:8] */ | ||
201 | #define WM8903_GP5_DIR 0x0080 /* GP5_DIR */ | ||
202 | #define WM8903_GP5_DIR_MASK 0x0080 /* GP5_DIR */ | ||
203 | #define WM8903_GP5_DIR_SHIFT 7 /* GP5_DIR */ | ||
204 | #define WM8903_GP5_DIR_WIDTH 1 /* GP5_DIR */ | ||
205 | #define WM8903_GP5_OP_CFG 0x0040 /* GP5_OP_CFG */ | ||
206 | #define WM8903_GP5_OP_CFG_MASK 0x0040 /* GP5_OP_CFG */ | ||
207 | #define WM8903_GP5_OP_CFG_SHIFT 6 /* GP5_OP_CFG */ | ||
208 | #define WM8903_GP5_OP_CFG_WIDTH 1 /* GP5_OP_CFG */ | ||
209 | #define WM8903_GP5_IP_CFG 0x0020 /* GP5_IP_CFG */ | ||
210 | #define WM8903_GP5_IP_CFG_MASK 0x0020 /* GP5_IP_CFG */ | ||
211 | #define WM8903_GP5_IP_CFG_SHIFT 5 /* GP5_IP_CFG */ | ||
212 | #define WM8903_GP5_IP_CFG_WIDTH 1 /* GP5_IP_CFG */ | ||
213 | #define WM8903_GP5_LVL 0x0010 /* GP5_LVL */ | ||
214 | #define WM8903_GP5_LVL_MASK 0x0010 /* GP5_LVL */ | ||
215 | #define WM8903_GP5_LVL_SHIFT 4 /* GP5_LVL */ | ||
216 | #define WM8903_GP5_LVL_WIDTH 1 /* GP5_LVL */ | ||
217 | #define WM8903_GP5_PD 0x0008 /* GP5_PD */ | ||
218 | #define WM8903_GP5_PD_MASK 0x0008 /* GP5_PD */ | ||
219 | #define WM8903_GP5_PD_SHIFT 3 /* GP5_PD */ | ||
220 | #define WM8903_GP5_PD_WIDTH 1 /* GP5_PD */ | ||
221 | #define WM8903_GP5_PU 0x0004 /* GP5_PU */ | ||
222 | #define WM8903_GP5_PU_MASK 0x0004 /* GP5_PU */ | ||
223 | #define WM8903_GP5_PU_SHIFT 2 /* GP5_PU */ | ||
224 | #define WM8903_GP5_PU_WIDTH 1 /* GP5_PU */ | ||
225 | #define WM8903_GP5_INTMODE 0x0002 /* GP5_INTMODE */ | ||
226 | #define WM8903_GP5_INTMODE_MASK 0x0002 /* GP5_INTMODE */ | ||
227 | #define WM8903_GP5_INTMODE_SHIFT 1 /* GP5_INTMODE */ | ||
228 | #define WM8903_GP5_INTMODE_WIDTH 1 /* GP5_INTMODE */ | ||
229 | #define WM8903_GP5_DB 0x0001 /* GP5_DB */ | ||
230 | #define WM8903_GP5_DB_MASK 0x0001 /* GP5_DB */ | ||
231 | #define WM8903_GP5_DB_SHIFT 0 /* GP5_DB */ | ||
232 | #define WM8903_GP5_DB_WIDTH 1 /* GP5_DB */ | ||
233 | |||
234 | struct wm8903_platform_data { | ||
235 | bool irq_active_low; /* Set if IRQ active low, default high */ | ||
236 | |||
237 | /* Default register value for R6 (Mic bias), used to configure | ||
238 | * microphone detection. In conjunction with gpio_cfg this | ||
239 | * can be used to route the microphone status signals out onto | ||
240 | * the GPIOs for use with snd_soc_jack_add_gpios(). | ||
241 | */ | ||
242 | u16 micdet_cfg; | ||
243 | |||
244 | int micdet_delay; /* Delay after microphone detection (ms) */ | ||
245 | |||
246 | u32 gpio_cfg[5]; /* Default register values for GPIO pin mux */ | ||
247 | }; | ||
248 | |||
249 | #endif | ||
diff --git a/include/sound/wm8904.h b/include/sound/wm8904.h index d66575a601be..898be3a8db9a 100644 --- a/include/sound/wm8904.h +++ b/include/sound/wm8904.h | |||
@@ -15,8 +15,111 @@ | |||
15 | #ifndef __MFD_WM8994_PDATA_H__ | 15 | #ifndef __MFD_WM8994_PDATA_H__ |
16 | #define __MFD_WM8994_PDATA_H__ | 16 | #define __MFD_WM8994_PDATA_H__ |
17 | 17 | ||
18 | #define WM8904_DRC_REGS 4 | 18 | /* Used to enable configuration of a GPIO to all zeros */ |
19 | #define WM8904_EQ_REGS 25 | 19 | #define WM8904_GPIO_NO_CONFIG 0x8000 |
20 | |||
21 | /* | ||
22 | * R6 (0x06) - Mic Bias Control 0 | ||
23 | */ | ||
24 | #define WM8904_MICDET_THR_MASK 0x0070 /* MICDET_THR - [6:4] */ | ||
25 | #define WM8904_MICDET_THR_SHIFT 4 /* MICDET_THR - [6:4] */ | ||
26 | #define WM8904_MICDET_THR_WIDTH 3 /* MICDET_THR - [6:4] */ | ||
27 | #define WM8904_MICSHORT_THR_MASK 0x000C /* MICSHORT_THR - [3:2] */ | ||
28 | #define WM8904_MICSHORT_THR_SHIFT 2 /* MICSHORT_THR - [3:2] */ | ||
29 | #define WM8904_MICSHORT_THR_WIDTH 2 /* MICSHORT_THR - [3:2] */ | ||
30 | #define WM8904_MICDET_ENA 0x0002 /* MICDET_ENA */ | ||
31 | #define WM8904_MICDET_ENA_MASK 0x0002 /* MICDET_ENA */ | ||
32 | #define WM8904_MICDET_ENA_SHIFT 1 /* MICDET_ENA */ | ||
33 | #define WM8904_MICDET_ENA_WIDTH 1 /* MICDET_ENA */ | ||
34 | #define WM8904_MICBIAS_ENA 0x0001 /* MICBIAS_ENA */ | ||
35 | #define WM8904_MICBIAS_ENA_MASK 0x0001 /* MICBIAS_ENA */ | ||
36 | #define WM8904_MICBIAS_ENA_SHIFT 0 /* MICBIAS_ENA */ | ||
37 | #define WM8904_MICBIAS_ENA_WIDTH 1 /* MICBIAS_ENA */ | ||
38 | |||
39 | /* | ||
40 | * R7 (0x07) - Mic Bias Control 1 | ||
41 | */ | ||
42 | #define WM8904_MIC_DET_FILTER_ENA 0x8000 /* MIC_DET_FILTER_ENA */ | ||
43 | #define WM8904_MIC_DET_FILTER_ENA_MASK 0x8000 /* MIC_DET_FILTER_ENA */ | ||
44 | #define WM8904_MIC_DET_FILTER_ENA_SHIFT 15 /* MIC_DET_FILTER_ENA */ | ||
45 | #define WM8904_MIC_DET_FILTER_ENA_WIDTH 1 /* MIC_DET_FILTER_ENA */ | ||
46 | #define WM8904_MIC_SHORT_FILTER_ENA 0x4000 /* MIC_SHORT_FILTER_ENA */ | ||
47 | #define WM8904_MIC_SHORT_FILTER_ENA_MASK 0x4000 /* MIC_SHORT_FILTER_ENA */ | ||
48 | #define WM8904_MIC_SHORT_FILTER_ENA_SHIFT 14 /* MIC_SHORT_FILTER_ENA */ | ||
49 | #define WM8904_MIC_SHORT_FILTER_ENA_WIDTH 1 /* MIC_SHORT_FILTER_ENA */ | ||
50 | #define WM8904_MICBIAS_SEL_MASK 0x0007 /* MICBIAS_SEL - [2:0] */ | ||
51 | #define WM8904_MICBIAS_SEL_SHIFT 0 /* MICBIAS_SEL - [2:0] */ | ||
52 | #define WM8904_MICBIAS_SEL_WIDTH 3 /* MICBIAS_SEL - [2:0] */ | ||
53 | |||
54 | |||
55 | /* | ||
56 | * R121 (0x79) - GPIO Control 1 | ||
57 | */ | ||
58 | #define WM8904_GPIO1_PU 0x0020 /* GPIO1_PU */ | ||
59 | #define WM8904_GPIO1_PU_MASK 0x0020 /* GPIO1_PU */ | ||
60 | #define WM8904_GPIO1_PU_SHIFT 5 /* GPIO1_PU */ | ||
61 | #define WM8904_GPIO1_PU_WIDTH 1 /* GPIO1_PU */ | ||
62 | #define WM8904_GPIO1_PD 0x0010 /* GPIO1_PD */ | ||
63 | #define WM8904_GPIO1_PD_MASK 0x0010 /* GPIO1_PD */ | ||
64 | #define WM8904_GPIO1_PD_SHIFT 4 /* GPIO1_PD */ | ||
65 | #define WM8904_GPIO1_PD_WIDTH 1 /* GPIO1_PD */ | ||
66 | #define WM8904_GPIO1_SEL_MASK 0x000F /* GPIO1_SEL - [3:0] */ | ||
67 | #define WM8904_GPIO1_SEL_SHIFT 0 /* GPIO1_SEL - [3:0] */ | ||
68 | #define WM8904_GPIO1_SEL_WIDTH 4 /* GPIO1_SEL - [3:0] */ | ||
69 | |||
70 | /* | ||
71 | * R122 (0x7A) - GPIO Control 2 | ||
72 | */ | ||
73 | #define WM8904_GPIO2_PU 0x0020 /* GPIO2_PU */ | ||
74 | #define WM8904_GPIO2_PU_MASK 0x0020 /* GPIO2_PU */ | ||
75 | #define WM8904_GPIO2_PU_SHIFT 5 /* GPIO2_PU */ | ||
76 | #define WM8904_GPIO2_PU_WIDTH 1 /* GPIO2_PU */ | ||
77 | #define WM8904_GPIO2_PD 0x0010 /* GPIO2_PD */ | ||
78 | #define WM8904_GPIO2_PD_MASK 0x0010 /* GPIO2_PD */ | ||
79 | #define WM8904_GPIO2_PD_SHIFT 4 /* GPIO2_PD */ | ||
80 | #define WM8904_GPIO2_PD_WIDTH 1 /* GPIO2_PD */ | ||
81 | #define WM8904_GPIO2_SEL_MASK 0x000F /* GPIO2_SEL - [3:0] */ | ||
82 | #define WM8904_GPIO2_SEL_SHIFT 0 /* GPIO2_SEL - [3:0] */ | ||
83 | #define WM8904_GPIO2_SEL_WIDTH 4 /* GPIO2_SEL - [3:0] */ | ||
84 | |||
85 | /* | ||
86 | * R123 (0x7B) - GPIO Control 3 | ||
87 | */ | ||
88 | #define WM8904_GPIO3_PU 0x0020 /* GPIO3_PU */ | ||
89 | #define WM8904_GPIO3_PU_MASK 0x0020 /* GPIO3_PU */ | ||
90 | #define WM8904_GPIO3_PU_SHIFT 5 /* GPIO3_PU */ | ||
91 | #define WM8904_GPIO3_PU_WIDTH 1 /* GPIO3_PU */ | ||
92 | #define WM8904_GPIO3_PD 0x0010 /* GPIO3_PD */ | ||
93 | #define WM8904_GPIO3_PD_MASK 0x0010 /* GPIO3_PD */ | ||
94 | #define WM8904_GPIO3_PD_SHIFT 4 /* GPIO3_PD */ | ||
95 | #define WM8904_GPIO3_PD_WIDTH 1 /* GPIO3_PD */ | ||
96 | #define WM8904_GPIO3_SEL_MASK 0x000F /* GPIO3_SEL - [3:0] */ | ||
97 | #define WM8904_GPIO3_SEL_SHIFT 0 /* GPIO3_SEL - [3:0] */ | ||
98 | #define WM8904_GPIO3_SEL_WIDTH 4 /* GPIO3_SEL - [3:0] */ | ||
99 | |||
100 | /* | ||
101 | * R124 (0x7C) - GPIO Control 4 | ||
102 | */ | ||
103 | #define WM8904_GPI7_ENA 0x0200 /* GPI7_ENA */ | ||
104 | #define WM8904_GPI7_ENA_MASK 0x0200 /* GPI7_ENA */ | ||
105 | #define WM8904_GPI7_ENA_SHIFT 9 /* GPI7_ENA */ | ||
106 | #define WM8904_GPI7_ENA_WIDTH 1 /* GPI7_ENA */ | ||
107 | #define WM8904_GPI8_ENA 0x0100 /* GPI8_ENA */ | ||
108 | #define WM8904_GPI8_ENA_MASK 0x0100 /* GPI8_ENA */ | ||
109 | #define WM8904_GPI8_ENA_SHIFT 8 /* GPI8_ENA */ | ||
110 | #define WM8904_GPI8_ENA_WIDTH 1 /* GPI8_ENA */ | ||
111 | #define WM8904_GPIO_BCLK_MODE_ENA 0x0080 /* GPIO_BCLK_MODE_ENA */ | ||
112 | #define WM8904_GPIO_BCLK_MODE_ENA_MASK 0x0080 /* GPIO_BCLK_MODE_ENA */ | ||
113 | #define WM8904_GPIO_BCLK_MODE_ENA_SHIFT 7 /* GPIO_BCLK_MODE_ENA */ | ||
114 | #define WM8904_GPIO_BCLK_MODE_ENA_WIDTH 1 /* GPIO_BCLK_MODE_ENA */ | ||
115 | #define WM8904_GPIO_BCLK_SEL_MASK 0x000F /* GPIO_BCLK_SEL - [3:0] */ | ||
116 | #define WM8904_GPIO_BCLK_SEL_SHIFT 0 /* GPIO_BCLK_SEL - [3:0] */ | ||
117 | #define WM8904_GPIO_BCLK_SEL_WIDTH 4 /* GPIO_BCLK_SEL - [3:0] */ | ||
118 | |||
119 | #define WM8904_MIC_REGS 2 | ||
120 | #define WM8904_GPIO_REGS 4 | ||
121 | #define WM8904_DRC_REGS 4 | ||
122 | #define WM8904_EQ_REGS 25 | ||
20 | 123 | ||
21 | /** | 124 | /** |
22 | * DRC configurations are specified with a label and a set of register | 125 | * DRC configurations are specified with a label and a set of register |
@@ -52,6 +155,9 @@ struct wm8904_pdata { | |||
52 | 155 | ||
53 | int num_retune_mobile_cfgs; | 156 | int num_retune_mobile_cfgs; |
54 | struct wm8904_retune_mobile_cfg *retune_mobile_cfgs; | 157 | struct wm8904_retune_mobile_cfg *retune_mobile_cfgs; |
158 | |||
159 | u32 gpio_cfg[WM8904_GPIO_REGS]; | ||
160 | u32 mic_cfg[WM8904_MIC_REGS]; | ||
55 | }; | 161 | }; |
56 | 162 | ||
57 | #endif | 163 | #endif |
diff --git a/include/sound/wm8960.h b/include/sound/wm8960.h new file mode 100644 index 000000000000..74e9a95529c5 --- /dev/null +++ b/include/sound/wm8960.h | |||
@@ -0,0 +1,24 @@ | |||
1 | /* | ||
2 | * wm8960.h -- WM8960 Soc Audio driver platform data | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License version 2 as | ||
6 | * published by the Free Software Foundation. | ||
7 | */ | ||
8 | |||
9 | #ifndef _WM8960_PDATA_H | ||
10 | #define _WM8960_PDATA_H | ||
11 | |||
12 | #define WM8960_DRES_400R 0 | ||
13 | #define WM8960_DRES_200R 1 | ||
14 | #define WM8960_DRES_600R 2 | ||
15 | #define WM8960_DRES_150R 3 | ||
16 | #define WM8960_DRES_MAX 3 | ||
17 | |||
18 | struct wm8960_data { | ||
19 | bool capless; /* Headphone outputs configured in capless mode */ | ||
20 | |||
21 | int dres; /* Discharge resistance for headphone outputs */ | ||
22 | }; | ||
23 | |||
24 | #endif | ||
diff --git a/include/sound/wm9090.h b/include/sound/wm9090.h new file mode 100644 index 000000000000..3718928cde1a --- /dev/null +++ b/include/sound/wm9090.h | |||
@@ -0,0 +1,28 @@ | |||
1 | /* | ||
2 | * linux/sound/wm9090.h -- Platform data for WM9090 | ||
3 | * | ||
4 | * Copyright 2009, 2010 Wolfson Microelectronics. PLC. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __LINUX_SND_WM9090_H | ||
12 | #define __LINUX_SND_WM9090_H | ||
13 | |||
14 | struct wm9090_platform_data { | ||
15 | /* Line inputs 1 & 2 can optionally be differential */ | ||
16 | unsigned int lin1_diff:1; | ||
17 | unsigned int lin2_diff:1; | ||
18 | |||
19 | /* AGC configuration. This is intended to protect the speaker | ||
20 | * against overdriving and will therefore depend on the | ||
21 | * hardware setup with incorrect runtime configuration | ||
22 | * potentially causing hardware damage. | ||
23 | */ | ||
24 | unsigned int agc_ena:1; | ||
25 | u16 agc[3]; | ||
26 | }; | ||
27 | |||
28 | #endif | ||