xref: /openbmc/linux/sound/pci/hda/hda_jack.h (revision 03ab8e6297acd1bc0eedaa050e2a1635c576fd11)
162810dbdSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-or-later */
21835a0f9STakashi Iwai /*
31835a0f9STakashi Iwai  * Jack-detection handling for HD-audio
41835a0f9STakashi Iwai  *
51835a0f9STakashi Iwai  * Copyright (c) 2011 Takashi Iwai <tiwai@suse.de>
61835a0f9STakashi Iwai  */
71835a0f9STakashi Iwai 
81835a0f9STakashi Iwai #ifndef __SOUND_HDA_JACK_H
91835a0f9STakashi Iwai #define __SOUND_HDA_JACK_H
101835a0f9STakashi Iwai 
11a5062deeSDavid Henningsson #include <linux/err.h>
12911761c2STakashi Iwai #include <sound/jack.h>
13a5062deeSDavid Henningsson 
14128bc4baSTakashi Iwai struct auto_pin_cfg;
15954df2a9SDavid Henningsson struct hda_jack_tbl;
161a4f69d5STakashi Iwai struct hda_jack_callback;
17954df2a9SDavid Henningsson 
181a4f69d5STakashi Iwai typedef void (*hda_jack_callback_fn) (struct hda_codec *, struct hda_jack_callback *);
191a4f69d5STakashi Iwai 
201a4f69d5STakashi Iwai struct hda_jack_callback {
212ebab40eSTakashi Iwai 	hda_nid_t nid;
225204a05dSNikhil Mahale 	int dev_id;
231a4f69d5STakashi Iwai 	hda_jack_callback_fn func;
241a4f69d5STakashi Iwai 	unsigned int private_data;	/* arbitrary data */
25e6ce180fSTakashi Iwai 	unsigned int unsol_res;		/* unsolicited event bits */
26e6ce180fSTakashi Iwai 	struct hda_jack_tbl *jack;	/* associated jack entry */
271a4f69d5STakashi Iwai 	struct hda_jack_callback *next;
281a4f69d5STakashi Iwai };
29128bc4baSTakashi Iwai 
301835a0f9STakashi Iwai struct hda_jack_tbl {
311835a0f9STakashi Iwai 	hda_nid_t nid;
325204a05dSNikhil Mahale 	int dev_id;
333a93897eSTakashi Iwai 	unsigned char tag;		/* unsol event tag */
341a4f69d5STakashi Iwai 	struct hda_jack_callback *callback;
353a93897eSTakashi Iwai 	/* jack-detection stuff */
361835a0f9STakashi Iwai 	unsigned int pin_sense;		/* cached pin-sense value */
373a93897eSTakashi Iwai 	unsigned int jack_detect:1;	/* capable of jack-detection? */
381835a0f9STakashi Iwai 	unsigned int jack_dirty:1;	/* needs to update? */
3980c8bfbeSDavid Henningsson 	unsigned int phantom_jack:1;    /* a fixed, always present port? */
400f568959SDavid Henningsson 	unsigned int block_report:1;    /* in a transitional state - do not report to userspace */
410619ba8cSDylan Reid 	hda_nid_t gating_jack;		/* valid when gating jack plugged */
420619ba8cSDylan Reid 	hda_nid_t gated_jack;		/* gated is dependent on this jack */
4304f7791bSHui Wang 	hda_nid_t key_report_jack;	/* key reports to this jack */
44aad37dbdSTakashi Iwai 	int type;
45911761c2STakashi Iwai 	int button_state;
46aad37dbdSTakashi Iwai 	struct snd_jack *jack;
471835a0f9STakashi Iwai };
481835a0f9STakashi Iwai 
49911761c2STakashi Iwai struct hda_jack_keymap {
50911761c2STakashi Iwai 	enum snd_jack_types type;
51911761c2STakashi Iwai 	int key;
52911761c2STakashi Iwai };
53911761c2STakashi Iwai 
541835a0f9STakashi Iwai struct hda_jack_tbl *
555204a05dSNikhil Mahale snd_hda_jack_tbl_get_mst(struct hda_codec *codec, hda_nid_t nid, int dev_id);
565204a05dSNikhil Mahale 
575204a05dSNikhil Mahale /**
585204a05dSNikhil Mahale  * snd_hda_jack_tbl_get - query the jack-table entry for the given NID
595204a05dSNikhil Mahale  * @codec: the HDA codec
605204a05dSNikhil Mahale  * @nid: pin NID to refer to
615204a05dSNikhil Mahale  */
625204a05dSNikhil Mahale static inline struct hda_jack_tbl *
snd_hda_jack_tbl_get(struct hda_codec * codec,hda_nid_t nid)635204a05dSNikhil Mahale snd_hda_jack_tbl_get(struct hda_codec *codec, hda_nid_t nid)
645204a05dSNikhil Mahale {
655204a05dSNikhil Mahale 	return snd_hda_jack_tbl_get_mst(codec, nid, 0);
665204a05dSNikhil Mahale }
675204a05dSNikhil Mahale 
683a93897eSTakashi Iwai struct hda_jack_tbl *
695204a05dSNikhil Mahale snd_hda_jack_tbl_get_from_tag(struct hda_codec *codec,
705204a05dSNikhil Mahale 			      unsigned char tag, int dev_id);
711835a0f9STakashi Iwai 
72*37c4fd0dSTakashi Iwai void snd_hda_jack_tbl_disconnect(struct hda_codec *codec);
731835a0f9STakashi Iwai void snd_hda_jack_tbl_clear(struct hda_codec *codec);
741835a0f9STakashi Iwai 
751835a0f9STakashi Iwai void snd_hda_jack_set_dirty_all(struct hda_codec *codec);
761835a0f9STakashi Iwai 
775204a05dSNikhil Mahale int snd_hda_jack_detect_enable(struct hda_codec *codec, hda_nid_t nid,
785204a05dSNikhil Mahale 			       int dev_id);
795204a05dSNikhil Mahale 
801a4f69d5STakashi Iwai struct hda_jack_callback *
815204a05dSNikhil Mahale snd_hda_jack_detect_enable_callback_mst(struct hda_codec *codec, hda_nid_t nid,
8274610eafSPierre-Louis Bossart 					int dev_id, hda_jack_callback_fn func);
835204a05dSNikhil Mahale 
845204a05dSNikhil Mahale /**
855204a05dSNikhil Mahale  * snd_hda_jack_detect_enable - enable the jack-detection
865204a05dSNikhil Mahale  * @codec: the HDA codec
875204a05dSNikhil Mahale  * @nid: pin NID to enable
885204a05dSNikhil Mahale  * @func: callback function to register
895204a05dSNikhil Mahale  *
905204a05dSNikhil Mahale  * In the case of error, the return value will be a pointer embedded with
915204a05dSNikhil Mahale  * errno.  Check and handle the return value appropriately with standard
925204a05dSNikhil Mahale  * macros such as @IS_ERR() and @PTR_ERR().
935204a05dSNikhil Mahale  */
945204a05dSNikhil Mahale static inline struct hda_jack_callback *
snd_hda_jack_detect_enable_callback(struct hda_codec * codec,hda_nid_t nid,hda_jack_callback_fn cb)95bda17b82STakashi Iwai snd_hda_jack_detect_enable_callback(struct hda_codec *codec, hda_nid_t nid,
965204a05dSNikhil Mahale 				    hda_jack_callback_fn cb)
975204a05dSNikhil Mahale {
985204a05dSNikhil Mahale 	return snd_hda_jack_detect_enable_callback_mst(codec, nid, 0, cb);
995204a05dSNikhil Mahale }
100954df2a9SDavid Henningsson 
1010619ba8cSDylan Reid int snd_hda_jack_set_gating_jack(struct hda_codec *codec, hda_nid_t gated_nid,
1020619ba8cSDylan Reid 				 hda_nid_t gating_nid);
1031835a0f9STakashi Iwai 
10404f7791bSHui Wang int snd_hda_jack_bind_keymap(struct hda_codec *codec, hda_nid_t key_nid,
10504f7791bSHui Wang 			     const struct hda_jack_keymap *keymap,
10604f7791bSHui Wang 			     hda_nid_t jack_nid);
10704f7791bSHui Wang 
10804f7791bSHui Wang void snd_hda_jack_set_button_state(struct hda_codec *codec, hda_nid_t jack_nid,
10904f7791bSHui Wang 				   int button_state);
11004f7791bSHui Wang 
1115204a05dSNikhil Mahale u32 snd_hda_jack_pin_sense(struct hda_codec *codec, hda_nid_t nid, int dev_id);
11260ea8ca2STakashi Iwai 
11360ea8ca2STakashi Iwai /* the jack state returned from snd_hda_jack_detect_state() */
11460ea8ca2STakashi Iwai enum {
11560ea8ca2STakashi Iwai 	HDA_JACK_NOT_PRESENT, HDA_JACK_PRESENT, HDA_JACK_PHANTOM,
11660ea8ca2STakashi Iwai };
11760ea8ca2STakashi Iwai 
1185204a05dSNikhil Mahale int snd_hda_jack_detect_state_mst(struct hda_codec *codec, hda_nid_t nid,
1195204a05dSNikhil Mahale 				  int dev_id);
1205204a05dSNikhil Mahale 
1215204a05dSNikhil Mahale /**
1225204a05dSNikhil Mahale  * snd_hda_jack_detect_state - query pin Presence Detect status
1235204a05dSNikhil Mahale  * @codec: the CODEC to sense
1245204a05dSNikhil Mahale  * @nid: the pin NID to sense
1255204a05dSNikhil Mahale  *
1265204a05dSNikhil Mahale  * Query and return the pin's Presence Detect status, as either
1275204a05dSNikhil Mahale  * HDA_JACK_NOT_PRESENT, HDA_JACK_PRESENT or HDA_JACK_PHANTOM.
1285204a05dSNikhil Mahale  */
1295204a05dSNikhil Mahale static inline int
snd_hda_jack_detect_state(struct hda_codec * codec,hda_nid_t nid)1305204a05dSNikhil Mahale snd_hda_jack_detect_state(struct hda_codec *codec, hda_nid_t nid)
1315204a05dSNikhil Mahale {
1325204a05dSNikhil Mahale 	return snd_hda_jack_detect_state_mst(codec, nid, 0);
1335204a05dSNikhil Mahale }
1345204a05dSNikhil Mahale 
1355204a05dSNikhil Mahale /**
1365204a05dSNikhil Mahale  * snd_hda_jack_detect_mst - Detect the jack
1375204a05dSNikhil Mahale  * @codec: the HDA codec
1385204a05dSNikhil Mahale  * @nid: pin NID to check jack detection
1395204a05dSNikhil Mahale  * @dev_id: pin device entry id
1405204a05dSNikhil Mahale  */
1415204a05dSNikhil Mahale static inline bool
snd_hda_jack_detect_mst(struct hda_codec * codec,hda_nid_t nid,int dev_id)1425204a05dSNikhil Mahale snd_hda_jack_detect_mst(struct hda_codec *codec, hda_nid_t nid, int dev_id)
1435204a05dSNikhil Mahale {
1445204a05dSNikhil Mahale 	return snd_hda_jack_detect_state_mst(codec, nid, dev_id) !=
1455204a05dSNikhil Mahale 			HDA_JACK_NOT_PRESENT;
1465204a05dSNikhil Mahale }
14760ea8ca2STakashi Iwai 
14895a962c3STakashi Iwai /**
14995a962c3STakashi Iwai  * snd_hda_jack_detect - Detect the jack
15095a962c3STakashi Iwai  * @codec: the HDA codec
15195a962c3STakashi Iwai  * @nid: pin NID to check jack detection
15295a962c3STakashi Iwai  */
1535204a05dSNikhil Mahale static inline bool
snd_hda_jack_detect(struct hda_codec * codec,hda_nid_t nid)1545204a05dSNikhil Mahale snd_hda_jack_detect(struct hda_codec *codec, hda_nid_t nid)
15560ea8ca2STakashi Iwai {
1565204a05dSNikhil Mahale 	return snd_hda_jack_detect_mst(codec, nid, 0);
15760ea8ca2STakashi Iwai }
1581835a0f9STakashi Iwai 
159a9c74173STakashi Iwai bool is_jack_detectable(struct hda_codec *codec, hda_nid_t nid);
1601835a0f9STakashi Iwai 
1615204a05dSNikhil Mahale int snd_hda_jack_add_kctl_mst(struct hda_codec *codec, hda_nid_t nid,
1625204a05dSNikhil Mahale 			      int dev_id, const char *name, bool phantom_jack,
163911761c2STakashi Iwai 			      int type, const struct hda_jack_keymap *keymap);
1645204a05dSNikhil Mahale 
1655204a05dSNikhil Mahale /**
1665204a05dSNikhil Mahale  * snd_hda_jack_add_kctl - Add a kctl for the given pin
1675204a05dSNikhil Mahale  * @codec: the HDA codec
1685204a05dSNikhil Mahale  * @nid: pin NID to assign
1695204a05dSNikhil Mahale  * @name: string name for the jack
1705204a05dSNikhil Mahale  * @phantom_jack: flag to deal as a phantom jack
1715204a05dSNikhil Mahale  * @type: jack type bits to be reported, 0 for guessing from pincfg
1725204a05dSNikhil Mahale  * @keymap: optional jack / key mapping
1735204a05dSNikhil Mahale  *
1745204a05dSNikhil Mahale  * This assigns a jack-detection kctl to the given pin.  The kcontrol
1755204a05dSNikhil Mahale  * will have the given name and index.
1765204a05dSNikhil Mahale  */
1775204a05dSNikhil Mahale static inline int
snd_hda_jack_add_kctl(struct hda_codec * codec,hda_nid_t nid,const char * name,bool phantom_jack,int type,const struct hda_jack_keymap * keymap)1785204a05dSNikhil Mahale snd_hda_jack_add_kctl(struct hda_codec *codec, hda_nid_t nid,
1795204a05dSNikhil Mahale 		      const char *name, bool phantom_jack,
1805204a05dSNikhil Mahale 		      int type, const struct hda_jack_keymap *keymap)
1815204a05dSNikhil Mahale {
1825204a05dSNikhil Mahale 	return snd_hda_jack_add_kctl_mst(codec, nid, 0,
1835204a05dSNikhil Mahale 					 name, phantom_jack, type, keymap);
1845204a05dSNikhil Mahale }
1855204a05dSNikhil Mahale 
18601a61e12STakashi Iwai int snd_hda_jack_add_kctls(struct hda_codec *codec,
18701a61e12STakashi Iwai 			   const struct auto_pin_cfg *cfg);
18801a61e12STakashi Iwai 
18901a61e12STakashi Iwai void snd_hda_jack_report_sync(struct hda_codec *codec);
19001a61e12STakashi Iwai 
191954df2a9SDavid Henningsson void snd_hda_jack_unsol_event(struct hda_codec *codec, unsigned int res);
19201a61e12STakashi Iwai 
19326a6cb6cSDavid Henningsson void snd_hda_jack_poll_all(struct hda_codec *codec);
19426a6cb6cSDavid Henningsson 
1951835a0f9STakashi Iwai #endif /* __SOUND_HDA_JACK_H */
196