Commit 3a0be1a6 authored by Pierre-Louis Bossart's avatar Pierre-Louis Bossart Committed by Vinod Koul

soundwire: stream: remove unnecessary variable initializations

A number of variables don't need to be initialized.

In a couple of cases where we loop on a list of runtimes, the code
handling of the 'bus' variable leads to warnings that it may not be
initialized. Add a specific error case to trap such cases.
Signed-off-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://lore.kernel.org/r/20190806005522.22642-10-pierre-louis.bossart@linux.intel.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent e0279b6b
...@@ -369,7 +369,7 @@ static int sdw_enable_disable_master_ports(struct sdw_master_runtime *m_rt, ...@@ -369,7 +369,7 @@ static int sdw_enable_disable_master_ports(struct sdw_master_runtime *m_rt,
static int sdw_enable_disable_ports(struct sdw_master_runtime *m_rt, bool en) static int sdw_enable_disable_ports(struct sdw_master_runtime *m_rt, bool en)
{ {
struct sdw_port_runtime *s_port, *m_port; struct sdw_port_runtime *s_port, *m_port;
struct sdw_slave_runtime *s_rt = NULL; struct sdw_slave_runtime *s_rt;
int ret = 0; int ret = 0;
/* Enable/Disable Slave port(s) */ /* Enable/Disable Slave port(s) */
...@@ -417,7 +417,7 @@ static int sdw_prep_deprep_slave_ports(struct sdw_bus *bus, ...@@ -417,7 +417,7 @@ static int sdw_prep_deprep_slave_ports(struct sdw_bus *bus,
struct sdw_port_runtime *p_rt, struct sdw_port_runtime *p_rt,
bool prep) bool prep)
{ {
struct completion *port_ready = NULL; struct completion *port_ready;
struct sdw_dpn_prop *dpn_prop; struct sdw_dpn_prop *dpn_prop;
struct sdw_prepare_ch prep_ch; struct sdw_prepare_ch prep_ch;
unsigned int time_left; unsigned int time_left;
...@@ -537,7 +537,7 @@ static int sdw_prep_deprep_master_ports(struct sdw_master_runtime *m_rt, ...@@ -537,7 +537,7 @@ static int sdw_prep_deprep_master_ports(struct sdw_master_runtime *m_rt,
*/ */
static int sdw_prep_deprep_ports(struct sdw_master_runtime *m_rt, bool prep) static int sdw_prep_deprep_ports(struct sdw_master_runtime *m_rt, bool prep)
{ {
struct sdw_slave_runtime *s_rt = NULL; struct sdw_slave_runtime *s_rt;
struct sdw_port_runtime *p_rt; struct sdw_port_runtime *p_rt;
int ret = 0; int ret = 0;
...@@ -605,7 +605,7 @@ static int sdw_notify_config(struct sdw_master_runtime *m_rt) ...@@ -605,7 +605,7 @@ static int sdw_notify_config(struct sdw_master_runtime *m_rt)
*/ */
static int sdw_program_params(struct sdw_bus *bus) static int sdw_program_params(struct sdw_bus *bus)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
int ret = 0; int ret = 0;
list_for_each_entry(m_rt, &bus->m_rt_list, bus_node) { list_for_each_entry(m_rt, &bus->m_rt_list, bus_node) {
...@@ -642,8 +642,8 @@ static int sdw_bank_switch(struct sdw_bus *bus, int m_rt_count) ...@@ -642,8 +642,8 @@ static int sdw_bank_switch(struct sdw_bus *bus, int m_rt_count)
int col_index, row_index; int col_index, row_index;
bool multi_link; bool multi_link;
struct sdw_msg *wr_msg; struct sdw_msg *wr_msg;
u8 *wbuf = NULL; u8 *wbuf;
int ret = 0; int ret;
u16 addr; u16 addr;
wr_msg = kzalloc(sizeof(*wr_msg), GFP_KERNEL); wr_msg = kzalloc(sizeof(*wr_msg), GFP_KERNEL);
...@@ -741,9 +741,9 @@ static int sdw_ml_sync_bank_switch(struct sdw_bus *bus) ...@@ -741,9 +741,9 @@ static int sdw_ml_sync_bank_switch(struct sdw_bus *bus)
static int do_bank_switch(struct sdw_stream_runtime *stream) static int do_bank_switch(struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
const struct sdw_master_ops *ops; const struct sdw_master_ops *ops;
struct sdw_bus *bus = NULL; struct sdw_bus *bus;
bool multi_link = false; bool multi_link = false;
int ret = 0; int ret = 0;
...@@ -886,7 +886,7 @@ static struct sdw_master_runtime ...@@ -886,7 +886,7 @@ static struct sdw_master_runtime
*sdw_find_master_rt(struct sdw_bus *bus, *sdw_find_master_rt(struct sdw_bus *bus,
struct sdw_stream_runtime *stream) struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
/* Retrieve Bus handle if already available */ /* Retrieve Bus handle if already available */
list_for_each_entry(m_rt, &stream->master_list, stream_node) { list_for_each_entry(m_rt, &stream->master_list, stream_node) {
...@@ -955,7 +955,7 @@ static struct sdw_slave_runtime ...@@ -955,7 +955,7 @@ static struct sdw_slave_runtime
struct sdw_stream_config *stream_config, struct sdw_stream_config *stream_config,
struct sdw_stream_runtime *stream) struct sdw_stream_runtime *stream)
{ {
struct sdw_slave_runtime *s_rt = NULL; struct sdw_slave_runtime *s_rt;
s_rt = kzalloc(sizeof(*s_rt), GFP_KERNEL); s_rt = kzalloc(sizeof(*s_rt), GFP_KERNEL);
if (!s_rt) if (!s_rt)
...@@ -1261,7 +1261,7 @@ int sdw_stream_add_master(struct sdw_bus *bus, ...@@ -1261,7 +1261,7 @@ int sdw_stream_add_master(struct sdw_bus *bus,
unsigned int num_ports, unsigned int num_ports,
struct sdw_stream_runtime *stream) struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
int ret; int ret;
mutex_lock(&bus->bus_lock); mutex_lock(&bus->bus_lock);
...@@ -1428,7 +1428,7 @@ struct sdw_dpn_prop *sdw_get_slave_dpn_prop(struct sdw_slave *slave, ...@@ -1428,7 +1428,7 @@ struct sdw_dpn_prop *sdw_get_slave_dpn_prop(struct sdw_slave *slave,
*/ */
static void sdw_acquire_bus_lock(struct sdw_stream_runtime *stream) static void sdw_acquire_bus_lock(struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
struct sdw_bus *bus = NULL; struct sdw_bus *bus = NULL;
/* Iterate for all Master(s) in Master list */ /* Iterate for all Master(s) in Master list */
...@@ -1462,9 +1462,9 @@ static void sdw_release_bus_lock(struct sdw_stream_runtime *stream) ...@@ -1462,9 +1462,9 @@ static void sdw_release_bus_lock(struct sdw_stream_runtime *stream)
static int _sdw_prepare_stream(struct sdw_stream_runtime *stream) static int _sdw_prepare_stream(struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
struct sdw_bus *bus = NULL; struct sdw_bus *bus = NULL;
struct sdw_master_prop *prop = NULL; struct sdw_master_prop *prop;
struct sdw_bus_params params; struct sdw_bus_params params;
int ret; int ret;
...@@ -1493,6 +1493,11 @@ static int _sdw_prepare_stream(struct sdw_stream_runtime *stream) ...@@ -1493,6 +1493,11 @@ static int _sdw_prepare_stream(struct sdw_stream_runtime *stream)
} }
} }
if (!bus) {
pr_err("Configuration error in %s\n", __func__);
return -EINVAL;
}
ret = do_bank_switch(stream); ret = do_bank_switch(stream);
if (ret < 0) { if (ret < 0) {
dev_err(bus->dev, "Bank switch failed: %d\n", ret); dev_err(bus->dev, "Bank switch failed: %d\n", ret);
...@@ -1549,7 +1554,7 @@ EXPORT_SYMBOL(sdw_prepare_stream); ...@@ -1549,7 +1554,7 @@ EXPORT_SYMBOL(sdw_prepare_stream);
static int _sdw_enable_stream(struct sdw_stream_runtime *stream) static int _sdw_enable_stream(struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
struct sdw_bus *bus = NULL; struct sdw_bus *bus = NULL;
int ret; int ret;
...@@ -1573,6 +1578,11 @@ static int _sdw_enable_stream(struct sdw_stream_runtime *stream) ...@@ -1573,6 +1578,11 @@ static int _sdw_enable_stream(struct sdw_stream_runtime *stream)
} }
} }
if (!bus) {
pr_err("Configuration error in %s\n", __func__);
return -EINVAL;
}
ret = do_bank_switch(stream); ret = do_bank_switch(stream);
if (ret < 0) { if (ret < 0) {
dev_err(bus->dev, "Bank switch failed: %d\n", ret); dev_err(bus->dev, "Bank switch failed: %d\n", ret);
...@@ -1592,7 +1602,7 @@ static int _sdw_enable_stream(struct sdw_stream_runtime *stream) ...@@ -1592,7 +1602,7 @@ static int _sdw_enable_stream(struct sdw_stream_runtime *stream)
*/ */
int sdw_enable_stream(struct sdw_stream_runtime *stream) int sdw_enable_stream(struct sdw_stream_runtime *stream)
{ {
int ret = 0; int ret;
if (!stream) { if (!stream) {
pr_err("SoundWire: Handle not found for stream\n"); pr_err("SoundWire: Handle not found for stream\n");
...@@ -1612,12 +1622,12 @@ EXPORT_SYMBOL(sdw_enable_stream); ...@@ -1612,12 +1622,12 @@ EXPORT_SYMBOL(sdw_enable_stream);
static int _sdw_disable_stream(struct sdw_stream_runtime *stream) static int _sdw_disable_stream(struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
struct sdw_bus *bus = NULL;
int ret; int ret;
list_for_each_entry(m_rt, &stream->master_list, stream_node) { list_for_each_entry(m_rt, &stream->master_list, stream_node) {
bus = m_rt->bus; struct sdw_bus *bus = m_rt->bus;
/* Disable port(s) */ /* Disable port(s) */
ret = sdw_enable_disable_ports(m_rt, false); ret = sdw_enable_disable_ports(m_rt, false);
if (ret < 0) { if (ret < 0) {
...@@ -1628,7 +1638,8 @@ static int _sdw_disable_stream(struct sdw_stream_runtime *stream) ...@@ -1628,7 +1638,8 @@ static int _sdw_disable_stream(struct sdw_stream_runtime *stream)
stream->state = SDW_STREAM_DISABLED; stream->state = SDW_STREAM_DISABLED;
list_for_each_entry(m_rt, &stream->master_list, stream_node) { list_for_each_entry(m_rt, &stream->master_list, stream_node) {
bus = m_rt->bus; struct sdw_bus *bus = m_rt->bus;
/* Program params */ /* Program params */
ret = sdw_program_params(bus); ret = sdw_program_params(bus);
if (ret < 0) { if (ret < 0) {
...@@ -1639,13 +1650,14 @@ static int _sdw_disable_stream(struct sdw_stream_runtime *stream) ...@@ -1639,13 +1650,14 @@ static int _sdw_disable_stream(struct sdw_stream_runtime *stream)
ret = do_bank_switch(stream); ret = do_bank_switch(stream);
if (ret < 0) { if (ret < 0) {
dev_err(bus->dev, "Bank switch failed: %d\n", ret); pr_err("Bank switch failed: %d\n", ret);
return ret; return ret;
} }
/* make sure alternate bank (previous current) is also disabled */ /* make sure alternate bank (previous current) is also disabled */
list_for_each_entry(m_rt, &stream->master_list, stream_node) { list_for_each_entry(m_rt, &stream->master_list, stream_node) {
bus = m_rt->bus; struct sdw_bus *bus = m_rt->bus;
/* Disable port(s) */ /* Disable port(s) */
ret = sdw_enable_disable_ports(m_rt, false); ret = sdw_enable_disable_ports(m_rt, false);
if (ret < 0) { if (ret < 0) {
...@@ -1666,7 +1678,7 @@ static int _sdw_disable_stream(struct sdw_stream_runtime *stream) ...@@ -1666,7 +1678,7 @@ static int _sdw_disable_stream(struct sdw_stream_runtime *stream)
*/ */
int sdw_disable_stream(struct sdw_stream_runtime *stream) int sdw_disable_stream(struct sdw_stream_runtime *stream)
{ {
int ret = 0; int ret;
if (!stream) { if (!stream) {
pr_err("SoundWire: Handle not found for stream\n"); pr_err("SoundWire: Handle not found for stream\n");
...@@ -1686,8 +1698,8 @@ EXPORT_SYMBOL(sdw_disable_stream); ...@@ -1686,8 +1698,8 @@ EXPORT_SYMBOL(sdw_disable_stream);
static int _sdw_deprepare_stream(struct sdw_stream_runtime *stream) static int _sdw_deprepare_stream(struct sdw_stream_runtime *stream)
{ {
struct sdw_master_runtime *m_rt = NULL; struct sdw_master_runtime *m_rt;
struct sdw_bus *bus = NULL; struct sdw_bus *bus;
int ret = 0; int ret = 0;
list_for_each_entry(m_rt, &stream->master_list, stream_node) { list_for_each_entry(m_rt, &stream->master_list, stream_node) {
...@@ -1725,7 +1737,7 @@ static int _sdw_deprepare_stream(struct sdw_stream_runtime *stream) ...@@ -1725,7 +1737,7 @@ static int _sdw_deprepare_stream(struct sdw_stream_runtime *stream)
*/ */
int sdw_deprepare_stream(struct sdw_stream_runtime *stream) int sdw_deprepare_stream(struct sdw_stream_runtime *stream)
{ {
int ret = 0; int ret;
if (!stream) { if (!stream) {
pr_err("SoundWire: Handle not found for stream\n"); pr_err("SoundWire: Handle not found for stream\n");
......
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