Commit 5580ba7b authored by Dan Carpenter's avatar Dan Carpenter Committed by Takashi Iwai

ALSA: oxfw: some signedness bugs

This code tends to use unsigned variables by default and it causes
signedness bugs when we use negative variables for error handling.
The "i" and "j" variables are used to iterated over small positive
values and so they should be type "int".  The "len" variable doesn't
*need* to be signed but it should be signed to make the code easier to
read and audit.
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Reviewed-by: default avatarTakashi Sakamoto <o-takashi@sakamocchi.jp>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 0d3aba30
...@@ -19,7 +19,7 @@ static int hw_rule_rate(struct snd_pcm_hw_params *params, ...@@ -19,7 +19,7 @@ static int hw_rule_rate(struct snd_pcm_hw_params *params,
.min = UINT_MAX, .max = 0, .integer = 1 .min = UINT_MAX, .max = 0, .integer = 1
}; };
struct snd_oxfw_stream_formation formation; struct snd_oxfw_stream_formation formation;
unsigned int i, err; int i, err;
for (i = 0; i < SND_OXFW_STREAM_FORMAT_ENTRIES; i++) { for (i = 0; i < SND_OXFW_STREAM_FORMAT_ENTRIES; i++) {
if (formats[i] == NULL) if (formats[i] == NULL)
...@@ -47,7 +47,7 @@ static int hw_rule_channels(struct snd_pcm_hw_params *params, ...@@ -47,7 +47,7 @@ static int hw_rule_channels(struct snd_pcm_hw_params *params,
const struct snd_interval *r = const struct snd_interval *r =
hw_param_interval_c(params, SNDRV_PCM_HW_PARAM_RATE); hw_param_interval_c(params, SNDRV_PCM_HW_PARAM_RATE);
struct snd_oxfw_stream_formation formation; struct snd_oxfw_stream_formation formation;
unsigned int i, j, err; int i, j, err;
unsigned int count, list[SND_OXFW_STREAM_FORMAT_ENTRIES] = {0}; unsigned int count, list[SND_OXFW_STREAM_FORMAT_ENTRIES] = {0};
count = 0; count = 0;
...@@ -80,7 +80,7 @@ static int hw_rule_channels(struct snd_pcm_hw_params *params, ...@@ -80,7 +80,7 @@ static int hw_rule_channels(struct snd_pcm_hw_params *params,
static void limit_channels_and_rates(struct snd_pcm_hardware *hw, u8 **formats) static void limit_channels_and_rates(struct snd_pcm_hardware *hw, u8 **formats)
{ {
struct snd_oxfw_stream_formation formation; struct snd_oxfw_stream_formation formation;
unsigned int i, err; int i, err;
hw->channels_min = UINT_MAX; hw->channels_min = UINT_MAX;
hw->channels_max = 0; hw->channels_max = 0;
......
...@@ -15,7 +15,7 @@ static void proc_read_formation(struct snd_info_entry *entry, ...@@ -15,7 +15,7 @@ static void proc_read_formation(struct snd_info_entry *entry,
struct snd_oxfw_stream_formation formation, curr; struct snd_oxfw_stream_formation formation, curr;
u8 *format; u8 *format;
char flag; char flag;
unsigned int i, err; int i, err;
/* Show input. */ /* Show input. */
err = snd_oxfw_stream_get_current_formation(oxfw, err = snd_oxfw_stream_get_current_formation(oxfw,
......
...@@ -61,7 +61,8 @@ static int set_stream_format(struct snd_oxfw *oxfw, struct amdtp_stream *s, ...@@ -61,7 +61,8 @@ static int set_stream_format(struct snd_oxfw *oxfw, struct amdtp_stream *s,
u8 **formats; u8 **formats;
struct snd_oxfw_stream_formation formation; struct snd_oxfw_stream_formation formation;
enum avc_general_plug_dir dir; enum avc_general_plug_dir dir;
unsigned int i, err, len; unsigned int len;
int i, err;
if (s == &oxfw->tx_stream) { if (s == &oxfw->tx_stream) {
formats = oxfw->tx_stream_formats; formats = oxfw->tx_stream_formats;
......
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