diff options
-rw-r--r-- | include/sound/jack.h | 3 | ||||
-rw-r--r-- | sound/core/jack.c | 44 |
2 files changed, 23 insertions, 24 deletions
diff --git a/include/sound/jack.h b/include/sound/jack.h index 2e0315cdd0d6..85266a2f5c6f 100644 --- a/include/sound/jack.h +++ b/include/sound/jack.h | |||
@@ -30,6 +30,9 @@ struct input_dev; | |||
30 | /** | 30 | /** |
31 | * Jack types which can be reported. These values are used as a | 31 | * Jack types which can be reported. These values are used as a |
32 | * bitmask. | 32 | * bitmask. |
33 | * | ||
34 | * Note that this must be kept in sync with the lookup table in | ||
35 | * sound/core/jack.c. | ||
33 | */ | 36 | */ |
34 | enum snd_jack_types { | 37 | enum snd_jack_types { |
35 | SND_JACK_HEADPHONE = 0x0001, | 38 | SND_JACK_HEADPHONE = 0x0001, |
diff --git a/sound/core/jack.c b/sound/core/jack.c index dd4a12dc09aa..b2da10c9916a 100644 --- a/sound/core/jack.c +++ b/sound/core/jack.c | |||
@@ -23,6 +23,13 @@ | |||
23 | #include <sound/jack.h> | 23 | #include <sound/jack.h> |
24 | #include <sound/core.h> | 24 | #include <sound/core.h> |
25 | 25 | ||
26 | static int jack_types[] = { | ||
27 | SW_HEADPHONE_INSERT, | ||
28 | SW_MICROPHONE_INSERT, | ||
29 | SW_LINEOUT_INSERT, | ||
30 | SW_JACK_PHYSICAL_INSERT, | ||
31 | }; | ||
32 | |||
26 | static int snd_jack_dev_free(struct snd_device *device) | 33 | static int snd_jack_dev_free(struct snd_device *device) |
27 | { | 34 | { |
28 | struct snd_jack *jack = device->device_data; | 35 | struct snd_jack *jack = device->device_data; |
@@ -79,6 +86,7 @@ int snd_jack_new(struct snd_card *card, const char *id, int type, | |||
79 | { | 86 | { |
80 | struct snd_jack *jack; | 87 | struct snd_jack *jack; |
81 | int err; | 88 | int err; |
89 | int i; | ||
82 | static struct snd_device_ops ops = { | 90 | static struct snd_device_ops ops = { |
83 | .dev_free = snd_jack_dev_free, | 91 | .dev_free = snd_jack_dev_free, |
84 | .dev_register = snd_jack_dev_register, | 92 | .dev_register = snd_jack_dev_register, |
@@ -100,18 +108,10 @@ int snd_jack_new(struct snd_card *card, const char *id, int type, | |||
100 | 108 | ||
101 | jack->type = type; | 109 | jack->type = type; |
102 | 110 | ||
103 | if (type & SND_JACK_HEADPHONE) | 111 | for (i = 0; i < ARRAY_SIZE(jack_types); i++) |
104 | input_set_capability(jack->input_dev, EV_SW, | 112 | if (type & (1 << i)) |
105 | SW_HEADPHONE_INSERT); | 113 | input_set_capability(jack->input_dev, EV_SW, |
106 | if (type & SND_JACK_LINEOUT) | 114 | jack_types[i]); |
107 | input_set_capability(jack->input_dev, EV_SW, | ||
108 | SW_LINEOUT_INSERT); | ||
109 | if (type & SND_JACK_MICROPHONE) | ||
110 | input_set_capability(jack->input_dev, EV_SW, | ||
111 | SW_MICROPHONE_INSERT); | ||
112 | if (type & SND_JACK_MECHANICAL) | ||
113 | input_set_capability(jack->input_dev, EV_SW, | ||
114 | SW_JACK_PHYSICAL_INSERT); | ||
115 | 115 | ||
116 | err = snd_device_new(card, SNDRV_DEV_JACK, jack, &ops); | 116 | err = snd_device_new(card, SNDRV_DEV_JACK, jack, &ops); |
117 | if (err < 0) | 117 | if (err < 0) |
@@ -154,21 +154,17 @@ EXPORT_SYMBOL(snd_jack_set_parent); | |||
154 | */ | 154 | */ |
155 | void snd_jack_report(struct snd_jack *jack, int status) | 155 | void snd_jack_report(struct snd_jack *jack, int status) |
156 | { | 156 | { |
157 | int i; | ||
158 | |||
157 | if (!jack) | 159 | if (!jack) |
158 | return; | 160 | return; |
159 | 161 | ||
160 | if (jack->type & SND_JACK_HEADPHONE) | 162 | for (i = 0; i < ARRAY_SIZE(jack_types); i++) { |
161 | input_report_switch(jack->input_dev, SW_HEADPHONE_INSERT, | 163 | int testbit = 1 << i; |
162 | status & SND_JACK_HEADPHONE); | 164 | if (jack->type & testbit) |
163 | if (jack->type & SND_JACK_LINEOUT) | 165 | input_report_switch(jack->input_dev, jack_types[i], |
164 | input_report_switch(jack->input_dev, SW_LINEOUT_INSERT, | 166 | status & testbit); |
165 | status & SND_JACK_LINEOUT); | 167 | } |
166 | if (jack->type & SND_JACK_MICROPHONE) | ||
167 | input_report_switch(jack->input_dev, SW_MICROPHONE_INSERT, | ||
168 | status & SND_JACK_MICROPHONE); | ||
169 | if (jack->type & SND_JACK_MECHANICAL) | ||
170 | input_report_switch(jack->input_dev, SW_JACK_PHYSICAL_INSERT, | ||
171 | status & SND_JACK_MECHANICAL); | ||
172 | 168 | ||
173 | input_sync(jack->input_dev); | 169 | input_sync(jack->input_dev); |
174 | } | 170 | } |