Pārlūkot izejas kodu

Merge branch 'topic/jack' into for-linus

Takashi Iwai 16 gadi atpakaļ
vecāks
revīzija
5b56eec774

+ 3 - 0
Documentation/sound/alsa/DocBook/alsa-driver-api.tmpl

@@ -88,6 +88,9 @@
   <chapter><title>Miscellaneous Functions</title>
   <chapter><title>Miscellaneous Functions</title>
      <sect1><title>Hardware-Dependent Devices API</title>
      <sect1><title>Hardware-Dependent Devices API</title>
 !Esound/core/hwdep.c
 !Esound/core/hwdep.c
+     </sect1>
+     <sect1><title>Jack Abstraction Layer API</title>
+!Esound/core/jack.c
      </sect1>
      </sect1>
      <sect1><title>ISA DMA Helpers</title>
      <sect1><title>ISA DMA Helpers</title>
 !Esound/core/isadma.c
 !Esound/core/isadma.c

+ 1 - 0
include/linux/input.h

@@ -661,6 +661,7 @@ struct input_absinfo {
 #define SW_DOCK			0x05  /* set = plugged into dock */
 #define SW_DOCK			0x05  /* set = plugged into dock */
 #define SW_LINEOUT_INSERT	0x06  /* set = inserted */
 #define SW_LINEOUT_INSERT	0x06  /* set = inserted */
 #define SW_JACK_PHYSICAL_INSERT 0x07  /* set = mechanical switch set */
 #define SW_JACK_PHYSICAL_INSERT 0x07  /* set = mechanical switch set */
+#define SW_VIDEOOUT_INSERT	0x08  /* set = inserted */
 #define SW_MAX			0x0f
 #define SW_MAX			0x0f
 #define SW_CNT			(SW_MAX+1)
 #define SW_CNT			(SW_MAX+1)
 
 

+ 5 - 0
include/sound/jack.h

@@ -30,6 +30,9 @@ struct input_dev;
 /**
 /**
  * Jack types which can be reported.  These values are used as a
  * Jack types which can be reported.  These values are used as a
  * bitmask.
  * bitmask.
+ *
+ * Note that this must be kept in sync with the lookup table in
+ * sound/core/jack.c.
  */
  */
 enum snd_jack_types {
 enum snd_jack_types {
 	SND_JACK_HEADPHONE	= 0x0001,
 	SND_JACK_HEADPHONE	= 0x0001,
@@ -37,6 +40,8 @@ enum snd_jack_types {
 	SND_JACK_HEADSET	= SND_JACK_HEADPHONE | SND_JACK_MICROPHONE,
 	SND_JACK_HEADSET	= SND_JACK_HEADPHONE | SND_JACK_MICROPHONE,
 	SND_JACK_LINEOUT	= 0x0004,
 	SND_JACK_LINEOUT	= 0x0004,
 	SND_JACK_MECHANICAL	= 0x0008, /* If detected separately */
 	SND_JACK_MECHANICAL	= 0x0008, /* If detected separately */
+	SND_JACK_VIDEOOUT	= 0x0010,
+	SND_JACK_AVOUT		= SND_JACK_LINEOUT | SND_JACK_VIDEOOUT,
 };
 };
 
 
 struct snd_jack {
 struct snd_jack {

+ 21 - 24
sound/core/jack.c

@@ -23,6 +23,14 @@
 #include <sound/jack.h>
 #include <sound/jack.h>
 #include <sound/core.h>
 #include <sound/core.h>
 
 
+static int jack_types[] = {
+	SW_HEADPHONE_INSERT,
+	SW_MICROPHONE_INSERT,
+	SW_LINEOUT_INSERT,
+	SW_JACK_PHYSICAL_INSERT,
+	SW_VIDEOOUT_INSERT,
+};
+
 static int snd_jack_dev_free(struct snd_device *device)
 static int snd_jack_dev_free(struct snd_device *device)
 {
 {
 	struct snd_jack *jack = device->device_data;
 	struct snd_jack *jack = device->device_data;
@@ -79,6 +87,7 @@ int snd_jack_new(struct snd_card *card, const char *id, int type,
 {
 {
 	struct snd_jack *jack;
 	struct snd_jack *jack;
 	int err;
 	int err;
+	int i;
 	static struct snd_device_ops ops = {
 	static struct snd_device_ops ops = {
 		.dev_free = snd_jack_dev_free,
 		.dev_free = snd_jack_dev_free,
 		.dev_register = snd_jack_dev_register,
 		.dev_register = snd_jack_dev_register,
@@ -100,18 +109,10 @@ int snd_jack_new(struct snd_card *card, const char *id, int type,
 
 
 	jack->type = type;
 	jack->type = type;
 
 
-	if (type & SND_JACK_HEADPHONE)
-		input_set_capability(jack->input_dev, EV_SW,
-				     SW_HEADPHONE_INSERT);
-	if (type & SND_JACK_LINEOUT)
-		input_set_capability(jack->input_dev, EV_SW,
-				     SW_LINEOUT_INSERT);
-	if (type & SND_JACK_MICROPHONE)
-		input_set_capability(jack->input_dev, EV_SW,
-				     SW_MICROPHONE_INSERT);
-	if (type & SND_JACK_MECHANICAL)
-		input_set_capability(jack->input_dev, EV_SW,
-				     SW_JACK_PHYSICAL_INSERT);
+	for (i = 0; i < ARRAY_SIZE(jack_types); i++)
+		if (type & (1 << i))
+			input_set_capability(jack->input_dev, EV_SW,
+					     jack_types[i]);
 
 
 	err = snd_device_new(card, SNDRV_DEV_JACK, jack, &ops);
 	err = snd_device_new(card, SNDRV_DEV_JACK, jack, &ops);
 	if (err < 0)
 	if (err < 0)
@@ -154,21 +155,17 @@ EXPORT_SYMBOL(snd_jack_set_parent);
  */
  */
 void snd_jack_report(struct snd_jack *jack, int status)
 void snd_jack_report(struct snd_jack *jack, int status)
 {
 {
+	int i;
+
 	if (!jack)
 	if (!jack)
 		return;
 		return;
 
 
-	if (jack->type & SND_JACK_HEADPHONE)
-		input_report_switch(jack->input_dev, SW_HEADPHONE_INSERT,
-				    status & SND_JACK_HEADPHONE);
-	if (jack->type & SND_JACK_LINEOUT)
-		input_report_switch(jack->input_dev, SW_LINEOUT_INSERT,
-				    status & SND_JACK_LINEOUT);
-	if (jack->type & SND_JACK_MICROPHONE)
-		input_report_switch(jack->input_dev, SW_MICROPHONE_INSERT,
-				    status & SND_JACK_MICROPHONE);
-	if (jack->type & SND_JACK_MECHANICAL)
-		input_report_switch(jack->input_dev, SW_JACK_PHYSICAL_INSERT,
-				    status & SND_JACK_MECHANICAL);
+	for (i = 0; i < ARRAY_SIZE(jack_types); i++) {
+		int testbit = 1 << i;
+		if (jack->type & testbit)
+			input_report_switch(jack->input_dev, jack_types[i],
+					    status & testbit);
+	}
 
 
 	input_sync(jack->input_dev);
 	input_sync(jack->input_dev);
 }
 }