Commit 35e28794 authored by Viresh Kumar's avatar Viresh Kumar Committed by Greg Kroah-Hartman

greybus: audio_codec: convert to bundle driver

Convert the legacy audio management and data protocol drivers to a
bundle driver.

The Audio bundle driver can support a single management and any number
of data cports, and so we expect multiple data cports to be present for
the bundle during initialization.
Signed-off-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Reviewed-by: default avatarJohan Hovold <johan@hovoldconsulting.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent 4b27be12
...@@ -15,9 +15,6 @@ ...@@ -15,9 +15,6 @@
#include "audio_apbridgea.h" #include "audio_apbridgea.h"
#include "audio_manager.h" #include "audio_manager.h"
#define GB_AUDIO_MGMT_DRIVER_NAME "gb_audio_mgmt"
#define GB_AUDIO_DATA_DRIVER_NAME "gb_audio_data"
static DEFINE_MUTEX(gb_codec_list_lock); static DEFINE_MUTEX(gb_codec_list_lock);
static LIST_HEAD(gb_codec_list); static LIST_HEAD(gb_codec_list);
...@@ -31,8 +28,8 @@ static int gbcodec_startup(struct snd_pcm_substream *substream, ...@@ -31,8 +28,8 @@ static int gbcodec_startup(struct snd_pcm_substream *substream,
__u16 i2s_port, cportid; __u16 i2s_port, cportid;
struct gbaudio_dai *gb_dai; struct gbaudio_dai *gb_dai;
struct gbaudio_codec_info *gb = struct gb_audio *audio = dev_get_drvdata(dai->dev);
(struct gbaudio_codec_info *)dev_get_drvdata(dai->dev); struct gbaudio_codec_info *gb = audio->gbcodec;
/* find the dai */ /* find the dai */
found = 0; found = 0;
...@@ -69,8 +66,8 @@ static void gbcodec_shutdown(struct snd_pcm_substream *substream, ...@@ -69,8 +66,8 @@ static void gbcodec_shutdown(struct snd_pcm_substream *substream,
__u16 i2s_port, cportid; __u16 i2s_port, cportid;
struct gbaudio_dai *gb_dai; struct gbaudio_dai *gb_dai;
struct gbaudio_codec_info *gb = struct gb_audio *audio = dev_get_drvdata(dai->dev);
(struct gbaudio_codec_info *)dev_get_drvdata(dai->dev); struct gbaudio_codec_info *gb = audio->gbcodec;
/* find the dai */ /* find the dai */
found = 0; found = 0;
...@@ -126,8 +123,8 @@ static int gbcodec_hw_params(struct snd_pcm_substream *substream, ...@@ -126,8 +123,8 @@ static int gbcodec_hw_params(struct snd_pcm_substream *substream,
uint32_t format, rate; uint32_t format, rate;
uint16_t data_cport; uint16_t data_cport;
struct gbaudio_dai *gb_dai; struct gbaudio_dai *gb_dai;
struct gbaudio_codec_info *gb = struct gb_audio *audio = dev_get_drvdata(dai->dev);
(struct gbaudio_codec_info *)dev_get_drvdata(dai->dev); struct gbaudio_codec_info *gb = audio->gbcodec;
/* find the dai */ /* find the dai */
found = 0; found = 0;
...@@ -203,8 +200,8 @@ static int gbcodec_prepare(struct snd_pcm_substream *substream, ...@@ -203,8 +200,8 @@ static int gbcodec_prepare(struct snd_pcm_substream *substream,
int ret, found; int ret, found;
uint16_t data_cport; uint16_t data_cport;
struct gbaudio_dai *gb_dai; struct gbaudio_dai *gb_dai;
struct gbaudio_codec_info *gb = struct gb_audio *audio = dev_get_drvdata(dai->dev);
(struct gbaudio_codec_info *)dev_get_drvdata(dai->dev); struct gbaudio_codec_info *gb = audio->gbcodec;
/* find the dai */ /* find the dai */
found = 0; found = 0;
...@@ -280,8 +277,8 @@ static int gbcodec_trigger(struct snd_pcm_substream *substream, int cmd, ...@@ -280,8 +277,8 @@ static int gbcodec_trigger(struct snd_pcm_substream *substream, int cmd,
int ret, found; int ret, found;
int tx, rx, start, stop; int tx, rx, start, stop;
struct gbaudio_dai *gb_dai; struct gbaudio_dai *gb_dai;
struct gbaudio_codec_info *gb = struct gb_audio *audio = dev_get_drvdata(dai->dev);
(struct gbaudio_codec_info *)dev_get_drvdata(dai->dev); struct gbaudio_codec_info *gb = audio->gbcodec;
/* find the dai */ /* find the dai */
found = 0; found = 0;
...@@ -386,7 +383,8 @@ static int gbcodec_write(struct snd_soc_codec *codec, unsigned int reg, ...@@ -386,7 +383,8 @@ static int gbcodec_write(struct snd_soc_codec *codec, unsigned int reg,
unsigned int value) unsigned int value)
{ {
int ret = 0; int ret = 0;
struct gbaudio_codec_info *gbcodec = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gbcodec = audio->gbcodec;
u8 *gbcodec_reg = gbcodec->reg; u8 *gbcodec_reg = gbcodec->reg;
if (reg == SND_SOC_NOPM) if (reg == SND_SOC_NOPM)
...@@ -406,7 +404,8 @@ static unsigned int gbcodec_read(struct snd_soc_codec *codec, ...@@ -406,7 +404,8 @@ static unsigned int gbcodec_read(struct snd_soc_codec *codec,
{ {
unsigned int val = 0; unsigned int val = 0;
struct gbaudio_codec_info *gbcodec = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gbcodec = audio->gbcodec;
u8 *gbcodec_reg = gbcodec->reg; u8 *gbcodec_reg = gbcodec->reg;
if (reg == SND_SOC_NOPM) if (reg == SND_SOC_NOPM)
...@@ -524,6 +523,7 @@ static struct gbaudio_codec_info *gbaudio_get_codec(struct device *dev, ...@@ -524,6 +523,7 @@ static struct gbaudio_codec_info *gbaudio_get_codec(struct device *dev,
int dev_id) int dev_id)
{ {
struct gbaudio_codec_info *gbcodec; struct gbaudio_codec_info *gbcodec;
struct gb_audio *audio = dev_get_drvdata(dev);
gbcodec = gbaudio_find_codec(dev, dev_id); gbcodec = gbaudio_find_codec(dev, dev_id);
if (gbcodec) if (gbcodec)
...@@ -539,7 +539,7 @@ static struct gbaudio_codec_info *gbaudio_get_codec(struct device *dev, ...@@ -539,7 +539,7 @@ static struct gbaudio_codec_info *gbaudio_get_codec(struct device *dev,
INIT_LIST_HEAD(&gbcodec->codec_ctl_list); INIT_LIST_HEAD(&gbcodec->codec_ctl_list);
INIT_LIST_HEAD(&gbcodec->widget_ctl_list); INIT_LIST_HEAD(&gbcodec->widget_ctl_list);
gbcodec->dev_id = dev_id; gbcodec->dev_id = dev_id;
dev_set_drvdata(dev, gbcodec); audio->gbcodec = gbcodec;
gbcodec->dev = dev; gbcodec->dev = dev;
snprintf(gbcodec->name, NAME_SIZE, "%s.%s", dev->driver->name, snprintf(gbcodec->name, NAME_SIZE, "%s.%s", dev->driver->name,
dev_name(dev)); dev_name(dev));
...@@ -556,12 +556,14 @@ static struct gbaudio_codec_info *gbaudio_get_codec(struct device *dev, ...@@ -556,12 +556,14 @@ static struct gbaudio_codec_info *gbaudio_get_codec(struct device *dev,
static void gbaudio_free_codec(struct device *dev, static void gbaudio_free_codec(struct device *dev,
struct gbaudio_codec_info *gbcodec) struct gbaudio_codec_info *gbcodec)
{ {
struct gb_audio *audio = dev_get_drvdata(dev);
mutex_lock(&gb_codec_list_lock); mutex_lock(&gb_codec_list_lock);
if (!gbcodec->mgmt_connection && if (!gbcodec->mgmt_connection &&
list_empty(&gbcodec->dai_list)) { list_empty(&gbcodec->dai_list)) {
list_del(&gbcodec->list); list_del(&gbcodec->list);
mutex_unlock(&gb_codec_list_lock); mutex_unlock(&gb_codec_list_lock);
dev_set_drvdata(dev, NULL); audio->gbcodec = NULL;
devm_kfree(dev, gbcodec); devm_kfree(dev, gbcodec);
} else { } else {
mutex_unlock(&gb_codec_list_lock); mutex_unlock(&gb_codec_list_lock);
...@@ -633,12 +635,16 @@ static int gbaudio_codec_probe(struct gb_connection *connection) ...@@ -633,12 +635,16 @@ static int gbaudio_codec_probe(struct gb_connection *connection)
gbcodec->mgmt_connection = connection; gbcodec->mgmt_connection = connection;
ret = gb_connection_enable(connection);
if (ret)
goto base_error;
/* fetch topology data */ /* fetch topology data */
ret = gb_audio_gb_get_topology(connection, &topology); ret = gb_audio_gb_get_topology(connection, &topology);
if (ret) { if (ret) {
dev_err(gbcodec->dev, dev_err(gbcodec->dev,
"%d:Error while fetching topology\n", ret); "%d:Error while fetching topology\n", ret);
goto base_error; goto err_connection_disable;
} }
/* process topology data */ /* process topology data */
...@@ -711,6 +717,8 @@ static int gbaudio_codec_probe(struct gb_connection *connection) ...@@ -711,6 +717,8 @@ static int gbaudio_codec_probe(struct gb_connection *connection)
gbcodec->topology = NULL; gbcodec->topology = NULL;
topology_error: topology_error:
kfree(topology); kfree(topology);
err_connection_disable:
gb_connection_disable(connection);
base_error: base_error:
gbcodec->mgmt_connection = NULL; gbcodec->mgmt_connection = NULL;
gbaudio_free_codec(dev, gbcodec); gbaudio_free_codec(dev, gbcodec);
...@@ -753,6 +761,7 @@ static void gbaudio_codec_remove(struct gb_connection *connection) ...@@ -753,6 +761,7 @@ static void gbaudio_codec_remove(struct gb_connection *connection)
dev->driver = NULL; dev->driver = NULL;
gbaudio_tplg_release(gbcodec); gbaudio_tplg_release(gbcodec);
kfree(gbcodec->topology); kfree(gbcodec->topology);
gb_connection_disable(connection);
gbcodec->mgmt_connection = NULL; gbcodec->mgmt_connection = NULL;
mutex_lock(&gbcodec->lock); mutex_lock(&gbcodec->lock);
gbcodec->codec_registered = 0; gbcodec->codec_registered = 0;
...@@ -760,7 +769,7 @@ static void gbaudio_codec_remove(struct gb_connection *connection) ...@@ -760,7 +769,7 @@ static void gbaudio_codec_remove(struct gb_connection *connection)
gbaudio_free_codec(dev, gbcodec); gbaudio_free_codec(dev, gbcodec);
} }
static int gbaudio_codec_report_event_recv(u8 type, struct gb_operation *op) static int gbaudio_codec_request_handler(struct gb_operation *op)
{ {
struct gb_connection *connection = op->connection; struct gb_connection *connection = op->connection;
struct gb_audio_streaming_event_request *req = op->request->payload; struct gb_audio_streaming_event_request *req = op->request->payload;
...@@ -772,22 +781,12 @@ static int gbaudio_codec_report_event_recv(u8 type, struct gb_operation *op) ...@@ -772,22 +781,12 @@ static int gbaudio_codec_report_event_recv(u8 type, struct gb_operation *op)
return 0; return 0;
} }
static struct gb_protocol gb_audio_mgmt_protocol = {
.name = GB_AUDIO_MGMT_DRIVER_NAME,
.id = GREYBUS_PROTOCOL_AUDIO_MGMT,
.major = 0,
.minor = 1,
.connection_init = gbaudio_codec_probe,
.connection_exit = gbaudio_codec_remove,
.request_recv = gbaudio_codec_report_event_recv,
};
static int gbaudio_dai_probe(struct gb_connection *connection) static int gbaudio_dai_probe(struct gb_connection *connection)
{ {
struct gbaudio_dai *dai; struct gbaudio_dai *dai;
struct device *dev = &connection->bundle->dev; struct device *dev = &connection->bundle->dev;
int dev_id = connection->intf->interface_id; int dev_id = connection->intf->interface_id;
struct gbaudio_codec_info *gbcodec = dev_get_drvdata(dev); struct gbaudio_codec_info *gbcodec;
struct gb_audio_manager_module_descriptor desc; struct gb_audio_manager_module_descriptor desc;
int ret; int ret;
...@@ -798,12 +797,16 @@ static int gbaudio_dai_probe(struct gb_connection *connection) ...@@ -798,12 +797,16 @@ static int gbaudio_dai_probe(struct gb_connection *connection)
if (!gbcodec) if (!gbcodec)
return -ENOMEM; return -ENOMEM;
ret = gb_connection_enable(connection);
if (ret)
goto err_free_codec;
/* add/update dai_list*/ /* add/update dai_list*/
dai = gbaudio_add_dai(gbcodec, connection->intf_cport_id, connection, dai = gbaudio_add_dai(gbcodec, connection->intf_cport_id, connection,
NULL); NULL);
if (!dai) { if (!dai) {
ret = -ENOMEM; ret = -ENOMEM;
goto err_free_codec; goto err_connection_disable;
} }
/* update dai_added count */ /* update dai_added count */
...@@ -829,6 +832,8 @@ static int gbaudio_dai_probe(struct gb_connection *connection) ...@@ -829,6 +832,8 @@ static int gbaudio_dai_probe(struct gb_connection *connection)
return 0; return 0;
err_connection_disable:
gb_connection_disable(connection);
err_free_codec: err_free_codec:
gbaudio_free_codec(dev, gbcodec); gbaudio_free_codec(dev, gbcodec);
return ret; return ret;
...@@ -859,10 +864,11 @@ static void gbaudio_dai_remove(struct gb_connection *connection) ...@@ -859,10 +864,11 @@ static void gbaudio_dai_remove(struct gb_connection *connection)
gbcodec->dai_added--; gbcodec->dai_added--;
mutex_unlock(&gbcodec->lock); mutex_unlock(&gbcodec->lock);
gb_connection_disable(connection);
gbaudio_free_codec(dev, gbcodec); gbaudio_free_codec(dev, gbcodec);
} }
static int gbaudio_dai_report_event_recv(u8 type, struct gb_operation *op) static int gbaudio_dai_request_handler(struct gb_operation *op)
{ {
struct gb_connection *connection = op->connection; struct gb_connection *connection = op->connection;
...@@ -871,50 +877,165 @@ static int gbaudio_dai_report_event_recv(u8 type, struct gb_operation *op) ...@@ -871,50 +877,165 @@ static int gbaudio_dai_report_event_recv(u8 type, struct gb_operation *op)
return 0; return 0;
} }
static struct gb_protocol gb_audio_data_protocol = { static int gb_audio_add_mgmt_connection(struct gb_audio *audio,
.name = GB_AUDIO_DATA_DRIVER_NAME, struct greybus_descriptor_cport *cport_desc,
.id = GREYBUS_PROTOCOL_AUDIO_DATA, struct gb_bundle *bundle)
.major = 0, {
.minor = 1, struct gb_connection *connection;
.connection_init = gbaudio_dai_probe,
.connection_exit = gbaudio_dai_remove,
.request_recv = gbaudio_dai_report_event_recv,
};
/* /* Management Cport */
* This is the basic hook get things initialized and registered w/ gb if (audio->mgmt_connection) {
*/ dev_err(&bundle->dev,
"Can't have multiple Management connections\n");
return -ENODEV;
}
connection = gb_connection_create(bundle, le16_to_cpu(cport_desc->id),
gbaudio_codec_request_handler);
if (IS_ERR(connection))
return PTR_ERR(connection);
connection->private = audio;
audio->mgmt_connection = connection;
return 0;
}
static int gb_audio_add_data_connection(struct gb_audio *audio,
struct greybus_descriptor_cport *cport_desc,
struct gb_bundle *bundle, int index)
{
struct gb_connection *connection;
connection = gb_connection_create(bundle, le16_to_cpu(cport_desc->id),
gbaudio_dai_request_handler);
if (IS_ERR(connection))
return PTR_ERR(connection);
connection->private = audio;
audio->data_connection[index] = connection;
return 0;
}
static int __init gb_audio_protocol_init(void) static int gb_audio_probe(struct gb_bundle *bundle,
const struct greybus_bundle_id *id)
{ {
int err; struct greybus_descriptor_cport *cport_desc;
struct gb_audio *audio;
int ret, i;
int count = bundle->num_cports - 1;
/* There should be at least one Management and one Data cport */
if (bundle->num_cports < 2)
return -ENODEV;
err = gb_protocol_register(&gb_audio_mgmt_protocol); /*
if (err) { * There can be only one Management connection and any number of data
pr_err("Can't register i2s mgmt protocol driver: %d\n", -err); * connections.
return err; */
audio = kzalloc(sizeof(*audio) +
count * sizeof(*audio->data_connection), GFP_KERNEL);
if (!audio)
return -ENOMEM;
audio->num_data_connections = count;
greybus_set_drvdata(bundle, audio);
/* Create all connections */
for (count = 0, i = 0; i < bundle->num_cports; i++) {
cport_desc = &bundle->cport_desc[i];
switch (cport_desc->protocol_id) {
case GREYBUS_PROTOCOL_AUDIO_MGMT:
ret = gb_audio_add_mgmt_connection(audio, cport_desc,
bundle);
if (ret)
goto destroy_connections;
break;
case GREYBUS_PROTOCOL_AUDIO_DATA:
ret = gb_audio_add_data_connection(audio, cport_desc,
bundle, count);
if (ret)
goto destroy_connections;
count++;
break;
default:
dev_err(&bundle->dev, "Unsupported protocol: 0x%02x\n",
cport_desc->protocol_id);
ret = -ENODEV;
goto destroy_connections;
}
} }
err = gb_protocol_register(&gb_audio_data_protocol); /* There must be a management cport */
if (err) { if (!audio->mgmt_connection) {
pr_err("Can't register Audio protocol driver: %d\n", -err); ret = -EINVAL;
goto err_unregister_audio_mgmt; dev_err(&bundle->dev, "Missing management connection\n");
goto destroy_connections;
}
/* Initialize management connection */
ret = gbaudio_codec_probe(audio->mgmt_connection);
if (ret)
goto destroy_connections;
/* Initialize data connections */
for (i = 0; i < audio->num_data_connections; i++) {
ret = gbaudio_dai_probe(audio->data_connection[i]);
if (ret)
goto remove_dai;
} }
return 0; return 0;
err_unregister_audio_mgmt: remove_dai:
gb_protocol_deregister(&gb_audio_mgmt_protocol); while (i--)
return err; gbaudio_dai_remove(audio->data_connection[i]);
gbaudio_codec_remove(audio->mgmt_connection);
destroy_connections:
while (count--)
gb_connection_destroy(audio->data_connection[count]);
if (audio->mgmt_connection)
gb_connection_destroy(audio->mgmt_connection);
kfree(audio);
return ret;
} }
module_init(gb_audio_protocol_init);
static void __exit gb_audio_protocol_exit(void) static void gb_audio_disconnect(struct gb_bundle *bundle)
{ {
gb_protocol_deregister(&gb_audio_data_protocol); struct gb_audio *audio = greybus_get_drvdata(bundle);
gb_protocol_deregister(&gb_audio_mgmt_protocol); int i;
for (i = audio->num_data_connections - 1; i >= 0; i--) {
gbaudio_dai_remove(audio->data_connection[i]);
gb_connection_destroy(audio->data_connection[i]);
}
gbaudio_codec_remove(audio->mgmt_connection);
gb_connection_destroy(audio->mgmt_connection);
kfree(audio);
} }
module_exit(gb_audio_protocol_exit);
static const struct greybus_bundle_id gb_audio_id_table[] = {
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_AUDIO_MGMT) },
{ }
};
MODULE_DEVICE_TABLE(greybus, gb_audio_id_table);
static struct greybus_driver gb_audio_driver = {
.name = "gb-audio",
.probe = gb_audio_probe,
.disconnect = gb_audio_disconnect,
.id_table = gb_audio_id_table,
};
module_greybus_driver(gb_audio_driver);
MODULE_DESCRIPTION("Greybus Audio codec driver"); MODULE_DESCRIPTION("Greybus Audio codec driver");
MODULE_AUTHOR("Vaibhav Agarwal <vaibhav.agarwal@linaro.org>"); MODULE_AUTHOR("Vaibhav Agarwal <vaibhav.agarwal@linaro.org>");
......
...@@ -142,6 +142,13 @@ struct gbaudio_codec_info { ...@@ -142,6 +142,13 @@ struct gbaudio_codec_info {
struct mutex lock; struct mutex lock;
}; };
struct gb_audio {
struct gb_connection *mgmt_connection;
size_t num_data_connections;
struct gbaudio_codec_info *gbcodec;
struct gb_connection *data_connection[0];
};
struct gbaudio_dai *gbaudio_add_dai(struct gbaudio_codec_info *gbcodec, struct gbaudio_dai *gbaudio_add_dai(struct gbaudio_codec_info *gbcodec,
int data_cport, int data_cport,
struct gb_connection *connection, struct gb_connection *connection,
......
...@@ -92,7 +92,8 @@ static int gbcodec_mixer_ctl_info(struct snd_kcontrol *kcontrol, ...@@ -92,7 +92,8 @@ static int gbcodec_mixer_ctl_info(struct snd_kcontrol *kcontrol,
struct gbaudio_ctl_pvt *data; struct gbaudio_ctl_pvt *data;
struct gb_audio_ctl_elem_info *info; struct gb_audio_ctl_elem_info *info;
struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol); struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
struct gbaudio_codec_info *gbcodec = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gbcodec = audio->gbcodec;
data = (struct gbaudio_ctl_pvt *)kcontrol->private_value; data = (struct gbaudio_ctl_pvt *)kcontrol->private_value;
info = (struct gb_audio_ctl_elem_info *)data->info; info = (struct gb_audio_ctl_elem_info *)data->info;
...@@ -138,7 +139,8 @@ static int gbcodec_mixer_ctl_get(struct snd_kcontrol *kcontrol, ...@@ -138,7 +139,8 @@ static int gbcodec_mixer_ctl_get(struct snd_kcontrol *kcontrol,
struct gbaudio_ctl_pvt *data; struct gbaudio_ctl_pvt *data;
struct gb_audio_ctl_elem_value gbvalue; struct gb_audio_ctl_elem_value gbvalue;
struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol); struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
struct gbaudio_codec_info *gb = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gb = audio->gbcodec;
data = (struct gbaudio_ctl_pvt *)kcontrol->private_value; data = (struct gbaudio_ctl_pvt *)kcontrol->private_value;
info = (struct gb_audio_ctl_elem_info *)data->info; info = (struct gb_audio_ctl_elem_info *)data->info;
...@@ -185,7 +187,8 @@ static int gbcodec_mixer_ctl_put(struct snd_kcontrol *kcontrol, ...@@ -185,7 +187,8 @@ static int gbcodec_mixer_ctl_put(struct snd_kcontrol *kcontrol,
struct gbaudio_ctl_pvt *data; struct gbaudio_ctl_pvt *data;
struct gb_audio_ctl_elem_value gbvalue; struct gb_audio_ctl_elem_value gbvalue;
struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol); struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
struct gbaudio_codec_info *gb = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gb = audio->gbcodec;
data = (struct gbaudio_ctl_pvt *)kcontrol->private_value; data = (struct gbaudio_ctl_pvt *)kcontrol->private_value;
info = (struct gb_audio_ctl_elem_info *)data->info; info = (struct gb_audio_ctl_elem_info *)data->info;
...@@ -279,7 +282,8 @@ static int gbcodec_mixer_dapm_ctl_get(struct snd_kcontrol *kcontrol, ...@@ -279,7 +282,8 @@ static int gbcodec_mixer_dapm_ctl_get(struct snd_kcontrol *kcontrol,
struct snd_soc_dapm_widget_list *wlist = snd_kcontrol_chip(kcontrol); struct snd_soc_dapm_widget_list *wlist = snd_kcontrol_chip(kcontrol);
struct snd_soc_dapm_widget *widget = wlist->widgets[0]; struct snd_soc_dapm_widget *widget = wlist->widgets[0];
struct snd_soc_codec *codec = widget->codec; struct snd_soc_codec *codec = widget->codec;
struct gbaudio_codec_info *gb = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gb = audio->gbcodec;
data = (struct gbaudio_ctl_pvt *)kcontrol->private_value; data = (struct gbaudio_ctl_pvt *)kcontrol->private_value;
info = (struct gb_audio_ctl_elem_info *)data->info; info = (struct gb_audio_ctl_elem_info *)data->info;
...@@ -313,7 +317,8 @@ static int gbcodec_mixer_dapm_ctl_put(struct snd_kcontrol *kcontrol, ...@@ -313,7 +317,8 @@ static int gbcodec_mixer_dapm_ctl_put(struct snd_kcontrol *kcontrol,
struct snd_soc_dapm_widget_list *wlist = snd_kcontrol_chip(kcontrol); struct snd_soc_dapm_widget_list *wlist = snd_kcontrol_chip(kcontrol);
struct snd_soc_dapm_widget *widget = wlist->widgets[0]; struct snd_soc_dapm_widget *widget = wlist->widgets[0];
struct snd_soc_codec *codec = widget->codec; struct snd_soc_codec *codec = widget->codec;
struct gbaudio_codec_info *gb = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gb = audio->gbcodec;
data = (struct gbaudio_ctl_pvt *)kcontrol->private_value; data = (struct gbaudio_ctl_pvt *)kcontrol->private_value;
info = (struct gb_audio_ctl_elem_info *)data->info; info = (struct gb_audio_ctl_elem_info *)data->info;
...@@ -519,7 +524,8 @@ static int gbaudio_widget_event(struct snd_soc_dapm_widget *w, ...@@ -519,7 +524,8 @@ static int gbaudio_widget_event(struct snd_soc_dapm_widget *w,
int wid; int wid;
int ret; int ret;
struct snd_soc_codec *codec = w->codec; struct snd_soc_codec *codec = w->codec;
struct gbaudio_codec_info *gbcodec = snd_soc_codec_get_drvdata(codec); struct gb_audio *audio = snd_soc_codec_get_drvdata(codec);
struct gbaudio_codec_info *gbcodec = audio->gbcodec;
dev_dbg(codec->dev, "%s %s %d\n", __func__, w->name, event); dev_dbg(codec->dev, "%s %s %d\n", __func__, w->name, event);
......
...@@ -249,8 +249,6 @@ static const struct greybus_bundle_id legacy_id_table[] = { ...@@ -249,8 +249,6 @@ static const struct greybus_bundle_id legacy_id_table[] = {
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_SENSOR) }, { GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_SENSOR) },
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_LIGHTS) }, { GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_LIGHTS) },
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_LOOPBACK) }, { GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_LOOPBACK) },
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_AUDIO_MGMT) },
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_AUDIO_DATA) },
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_SVC) }, { GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_SVC) },
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_FIRMWARE) }, { GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_FIRMWARE) },
{ GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_RAW) }, { GREYBUS_DEVICE_CLASS(GREYBUS_CLASS_RAW) },
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment