blob: 727b6d3ba454a4dece3e6e776e75c9d1dde82b2c [file] [log] [blame]
Thomas Gleixner62810db2019-05-20 19:08:11 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Takashi Iwai1835a0f2011-10-27 22:12:46 +02002/*
3 * Jack-detection handling for HD-audio
4 *
5 * Copyright (c) 2011 Takashi Iwai <tiwai@suse.de>
Takashi Iwai1835a0f2011-10-27 22:12:46 +02006 */
7
8#ifndef __SOUND_HDA_JACK_H
9#define __SOUND_HDA_JACK_H
10
David Henningssona5062de2014-09-23 09:04:49 +020011#include <linux/err.h>
Takashi Iwai911761c2018-11-28 14:25:37 +010012#include <sound/jack.h>
David Henningssona5062de2014-09-23 09:04:49 +020013
Takashi Iwai128bc4b2012-05-07 17:42:31 +020014struct auto_pin_cfg;
David Henningsson954df2a2012-09-25 11:30:59 +020015struct hda_jack_tbl;
Takashi Iwai1a4f69d2014-09-11 15:22:46 +020016struct hda_jack_callback;
David Henningsson954df2a2012-09-25 11:30:59 +020017
Takashi Iwai1a4f69d2014-09-11 15:22:46 +020018typedef void (*hda_jack_callback_fn) (struct hda_codec *, struct hda_jack_callback *);
19
20struct hda_jack_callback {
Takashi Iwai2ebab402016-02-09 10:23:52 +010021 hda_nid_t nid;
Nikhil Mahale5204a052019-11-19 14:17:08 +053022 int dev_id;
Takashi Iwai1a4f69d2014-09-11 15:22:46 +020023 hda_jack_callback_fn func;
24 unsigned int private_data; /* arbitrary data */
Takashi Iwaie6ce1802018-11-28 14:17:58 +010025 unsigned int unsol_res; /* unsolicited event bits */
26 struct hda_jack_tbl *jack; /* associated jack entry */
Takashi Iwai1a4f69d2014-09-11 15:22:46 +020027 struct hda_jack_callback *next;
28};
Takashi Iwai128bc4b2012-05-07 17:42:31 +020029
Takashi Iwai1835a0f2011-10-27 22:12:46 +020030struct hda_jack_tbl {
31 hda_nid_t nid;
Nikhil Mahale5204a052019-11-19 14:17:08 +053032 int dev_id;
Takashi Iwai3a938972011-10-28 01:16:55 +020033 unsigned char tag; /* unsol event tag */
Takashi Iwai1a4f69d2014-09-11 15:22:46 +020034 struct hda_jack_callback *callback;
Takashi Iwai3a938972011-10-28 01:16:55 +020035 /* jack-detection stuff */
Takashi Iwai1835a0f2011-10-27 22:12:46 +020036 unsigned int pin_sense; /* cached pin-sense value */
Takashi Iwai3a938972011-10-28 01:16:55 +020037 unsigned int jack_detect:1; /* capable of jack-detection? */
Takashi Iwai1835a0f2011-10-27 22:12:46 +020038 unsigned int jack_dirty:1; /* needs to update? */
David Henningsson80c8bfb2012-06-04 09:33:51 +020039 unsigned int phantom_jack:1; /* a fixed, always present port? */
David Henningsson0f568952013-11-07 13:38:24 +010040 unsigned int block_report:1; /* in a transitional state - do not report to userspace */
Dylan Reid0619ba82012-11-19 19:48:07 +010041 hda_nid_t gating_jack; /* valid when gating jack plugged */
42 hda_nid_t gated_jack; /* gated is dependent on this jack */
Takashi Iwaiaad37db2011-11-02 08:54:51 +010043 int type;
Takashi Iwai911761c2018-11-28 14:25:37 +010044 int button_state;
Takashi Iwaiaad37db2011-11-02 08:54:51 +010045 struct snd_jack *jack;
Takashi Iwai1835a0f2011-10-27 22:12:46 +020046};
47
Takashi Iwai911761c2018-11-28 14:25:37 +010048struct hda_jack_keymap {
49 enum snd_jack_types type;
50 int key;
51};
52
Takashi Iwai1835a0f2011-10-27 22:12:46 +020053struct hda_jack_tbl *
Nikhil Mahale5204a052019-11-19 14:17:08 +053054snd_hda_jack_tbl_get_mst(struct hda_codec *codec, hda_nid_t nid, int dev_id);
55
56/**
57 * snd_hda_jack_tbl_get - query the jack-table entry for the given NID
58 * @codec: the HDA codec
59 * @nid: pin NID to refer to
60 */
61static inline struct hda_jack_tbl *
62snd_hda_jack_tbl_get(struct hda_codec *codec, hda_nid_t nid)
63{
64 return snd_hda_jack_tbl_get_mst(codec, nid, 0);
65}
66
Takashi Iwai3a938972011-10-28 01:16:55 +020067struct hda_jack_tbl *
Nikhil Mahale5204a052019-11-19 14:17:08 +053068snd_hda_jack_tbl_get_from_tag(struct hda_codec *codec,
69 unsigned char tag, int dev_id);
Takashi Iwai1835a0f2011-10-27 22:12:46 +020070
Takashi Iwai1835a0f2011-10-27 22:12:46 +020071void snd_hda_jack_tbl_clear(struct hda_codec *codec);
72
Takashi Iwai1835a0f2011-10-27 22:12:46 +020073void snd_hda_jack_set_dirty_all(struct hda_codec *codec);
74
Nikhil Mahale5204a052019-11-19 14:17:08 +053075int snd_hda_jack_detect_enable(struct hda_codec *codec, hda_nid_t nid,
76 int dev_id);
77
Takashi Iwai1a4f69d2014-09-11 15:22:46 +020078struct hda_jack_callback *
Nikhil Mahale5204a052019-11-19 14:17:08 +053079snd_hda_jack_detect_enable_callback_mst(struct hda_codec *codec, hda_nid_t nid,
80 int dev_id, hda_jack_callback_fn cb);
81
82/**
83 * snd_hda_jack_detect_enable - enable the jack-detection
84 * @codec: the HDA codec
85 * @nid: pin NID to enable
86 * @func: callback function to register
87 *
88 * In the case of error, the return value will be a pointer embedded with
89 * errno. Check and handle the return value appropriately with standard
90 * macros such as @IS_ERR() and @PTR_ERR().
91 */
92static inline struct hda_jack_callback *
Takashi Iwaibda17b822014-09-11 14:39:09 +020093snd_hda_jack_detect_enable_callback(struct hda_codec *codec, hda_nid_t nid,
Nikhil Mahale5204a052019-11-19 14:17:08 +053094 hda_jack_callback_fn cb)
95{
96 return snd_hda_jack_detect_enable_callback_mst(codec, nid, 0, cb);
97}
David Henningsson954df2a2012-09-25 11:30:59 +020098
Dylan Reid0619ba82012-11-19 19:48:07 +010099int snd_hda_jack_set_gating_jack(struct hda_codec *codec, hda_nid_t gated_nid,
100 hda_nid_t gating_nid);
Takashi Iwai1835a0f2011-10-27 22:12:46 +0200101
Nikhil Mahale5204a052019-11-19 14:17:08 +0530102u32 snd_hda_jack_pin_sense(struct hda_codec *codec, hda_nid_t nid, int dev_id);
Takashi Iwai60ea8ca2013-07-19 16:59:46 +0200103
104/* the jack state returned from snd_hda_jack_detect_state() */
105enum {
106 HDA_JACK_NOT_PRESENT, HDA_JACK_PRESENT, HDA_JACK_PHANTOM,
107};
108
Nikhil Mahale5204a052019-11-19 14:17:08 +0530109int snd_hda_jack_detect_state_mst(struct hda_codec *codec, hda_nid_t nid,
110 int dev_id);
111
112/**
113 * snd_hda_jack_detect_state - query pin Presence Detect status
114 * @codec: the CODEC to sense
115 * @nid: the pin NID to sense
116 *
117 * Query and return the pin's Presence Detect status, as either
118 * HDA_JACK_NOT_PRESENT, HDA_JACK_PRESENT or HDA_JACK_PHANTOM.
119 */
120static inline int
121snd_hda_jack_detect_state(struct hda_codec *codec, hda_nid_t nid)
122{
123 return snd_hda_jack_detect_state_mst(codec, nid, 0);
124}
125
126/**
127 * snd_hda_jack_detect_mst - Detect the jack
128 * @codec: the HDA codec
129 * @nid: pin NID to check jack detection
130 * @dev_id: pin device entry id
131 */
132static inline bool
133snd_hda_jack_detect_mst(struct hda_codec *codec, hda_nid_t nid, int dev_id)
134{
135 return snd_hda_jack_detect_state_mst(codec, nid, dev_id) !=
136 HDA_JACK_NOT_PRESENT;
137}
Takashi Iwai60ea8ca2013-07-19 16:59:46 +0200138
Takashi Iwai95a962c2014-10-29 16:03:58 +0100139/**
140 * snd_hda_jack_detect - Detect the jack
141 * @codec: the HDA codec
142 * @nid: pin NID to check jack detection
143 */
Nikhil Mahale5204a052019-11-19 14:17:08 +0530144static inline bool
145snd_hda_jack_detect(struct hda_codec *codec, hda_nid_t nid)
Takashi Iwai60ea8ca2013-07-19 16:59:46 +0200146{
Nikhil Mahale5204a052019-11-19 14:17:08 +0530147 return snd_hda_jack_detect_mst(codec, nid, 0);
Takashi Iwai60ea8ca2013-07-19 16:59:46 +0200148}
Takashi Iwai1835a0f2011-10-27 22:12:46 +0200149
Takashi Iwaia9c74172012-02-13 11:41:42 +0100150bool is_jack_detectable(struct hda_codec *codec, hda_nid_t nid);
Takashi Iwai1835a0f2011-10-27 22:12:46 +0200151
Nikhil Mahale5204a052019-11-19 14:17:08 +0530152int snd_hda_jack_add_kctl_mst(struct hda_codec *codec, hda_nid_t nid,
153 int dev_id, const char *name, bool phantom_jack,
154 int type, const struct hda_jack_keymap *keymap);
155
156/**
157 * snd_hda_jack_add_kctl - Add a kctl for the given pin
158 * @codec: the HDA codec
159 * @nid: pin NID to assign
160 * @name: string name for the jack
161 * @phantom_jack: flag to deal as a phantom jack
162 * @type: jack type bits to be reported, 0 for guessing from pincfg
163 * @keymap: optional jack / key mapping
164 *
165 * This assigns a jack-detection kctl to the given pin. The kcontrol
166 * will have the given name and index.
167 */
168static inline int
169snd_hda_jack_add_kctl(struct hda_codec *codec, hda_nid_t nid,
170 const char *name, bool phantom_jack,
171 int type, const struct hda_jack_keymap *keymap)
172{
173 return snd_hda_jack_add_kctl_mst(codec, nid, 0,
174 name, phantom_jack, type, keymap);
175}
176
Takashi Iwai01a61e12011-10-28 00:03:22 +0200177int snd_hda_jack_add_kctls(struct hda_codec *codec,
178 const struct auto_pin_cfg *cfg);
179
Takashi Iwai01a61e12011-10-28 00:03:22 +0200180void snd_hda_jack_report_sync(struct hda_codec *codec);
181
David Henningsson954df2a2012-09-25 11:30:59 +0200182void snd_hda_jack_unsol_event(struct hda_codec *codec, unsigned int res);
Takashi Iwai01a61e12011-10-28 00:03:22 +0200183
David Henningsson26a6cb62012-10-09 15:04:21 +0200184void snd_hda_jack_poll_all(struct hda_codec *codec);
185
Takashi Iwai1835a0f2011-10-27 22:12:46 +0200186#endif /* __SOUND_HDA_JACK_H */