diff options
| -rw-r--r-- | include/linux/input.h | 1 | ||||
| -rw-r--r-- | include/sound/jack.h | 1 | ||||
| -rw-r--r-- | sound/core/jack.c | 6 |
3 files changed, 8 insertions, 0 deletions
diff --git a/include/linux/input.h b/include/linux/input.h index 1a958cd90ce9..9a6355f74db2 100644 --- a/include/linux/input.h +++ b/include/linux/input.h | |||
| @@ -660,6 +660,7 @@ struct input_absinfo { | |||
| 660 | #define SW_MICROPHONE_INSERT 0x04 /* set = inserted */ | 660 | #define SW_MICROPHONE_INSERT 0x04 /* set = inserted */ |
| 661 | #define SW_DOCK 0x05 /* set = plugged into dock */ | 661 | #define SW_DOCK 0x05 /* set = plugged into dock */ |
| 662 | #define SW_LINEOUT_INSERT 0x06 /* set = inserted */ | 662 | #define SW_LINEOUT_INSERT 0x06 /* set = inserted */ |
| 663 | #define SW_JACK_PHYSICAL_INSERT 0x07 /* set = mechanical switch set */ | ||
| 663 | #define SW_MAX 0x0f | 664 | #define SW_MAX 0x0f |
| 664 | #define SW_CNT (SW_MAX+1) | 665 | #define SW_CNT (SW_MAX+1) |
| 665 | 666 | ||
diff --git a/include/sound/jack.h b/include/sound/jack.h index 7cb25f4b50bb..2e0315cdd0d6 100644 --- a/include/sound/jack.h +++ b/include/sound/jack.h | |||
| @@ -36,6 +36,7 @@ enum snd_jack_types { | |||
| 36 | SND_JACK_MICROPHONE = 0x0002, | 36 | SND_JACK_MICROPHONE = 0x0002, |
| 37 | SND_JACK_HEADSET = SND_JACK_HEADPHONE | SND_JACK_MICROPHONE, | 37 | SND_JACK_HEADSET = SND_JACK_HEADPHONE | SND_JACK_MICROPHONE, |
| 38 | SND_JACK_LINEOUT = 0x0004, | 38 | SND_JACK_LINEOUT = 0x0004, |
| 39 | SND_JACK_MECHANICAL = 0x0008, /* If detected separately */ | ||
| 39 | }; | 40 | }; |
| 40 | 41 | ||
| 41 | struct snd_jack { | 42 | struct snd_jack { |
diff --git a/sound/core/jack.c b/sound/core/jack.c index 284432f427f4..dd4a12dc09aa 100644 --- a/sound/core/jack.c +++ b/sound/core/jack.c | |||
| @@ -109,6 +109,9 @@ int snd_jack_new(struct snd_card *card, const char *id, int type, | |||
| 109 | if (type & SND_JACK_MICROPHONE) | 109 | if (type & SND_JACK_MICROPHONE) |
| 110 | input_set_capability(jack->input_dev, EV_SW, | 110 | input_set_capability(jack->input_dev, EV_SW, |
| 111 | SW_MICROPHONE_INSERT); | 111 | SW_MICROPHONE_INSERT); |
| 112 | if (type & SND_JACK_MECHANICAL) | ||
| 113 | input_set_capability(jack->input_dev, EV_SW, | ||
| 114 | SW_JACK_PHYSICAL_INSERT); | ||
| 112 | 115 | ||
| 113 | err = snd_device_new(card, SNDRV_DEV_JACK, jack, &ops); | 116 | err = snd_device_new(card, SNDRV_DEV_JACK, jack, &ops); |
| 114 | if (err < 0) | 117 | if (err < 0) |
| @@ -163,6 +166,9 @@ void snd_jack_report(struct snd_jack *jack, int status) | |||
| 163 | if (jack->type & SND_JACK_MICROPHONE) | 166 | if (jack->type & SND_JACK_MICROPHONE) |
| 164 | input_report_switch(jack->input_dev, SW_MICROPHONE_INSERT, | 167 | input_report_switch(jack->input_dev, SW_MICROPHONE_INSERT, |
| 165 | status & SND_JACK_MICROPHONE); | 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); | ||
| 166 | 172 | ||
| 167 | input_sync(jack->input_dev); | 173 | input_sync(jack->input_dev); |
| 168 | } | 174 | } |
