ALSA: i2c/cs8427: Fix int to char conversion

Compiling with clang yields the following warning:

sound/i2c/cs8427.c:140:31: warning: implicit conversion from 'int'
to 'char' changes value from 160 to -96 [-Wconstant-conversion]
    data[0] = CS8427_REG_AUTOINC | CS8427_REG_CORU_DATABUF;
            ~ ~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~

Because CS8427_REG_AUTOINC is defined as 128, it is too big for a
char field.
So change data from char to unsigned char, that it can hold the value.

This patch does not change the generated code.

Signed-off-by: Philipp Klocke <philipp97kl@gmail.com>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
Philipp Klocke 2018-10-18 12:33:02 +02:00 committed by Takashi Iwai
parent f90afe7955
commit eb7ebfa3c1
1 changed files with 1 additions and 1 deletions

View File

@ -118,7 +118,7 @@ static int snd_cs8427_send_corudata(struct snd_i2c_device *device,
struct cs8427 *chip = device->private_data; struct cs8427 *chip = device->private_data;
char *hw_data = udata ? char *hw_data = udata ?
chip->playback.hw_udata : chip->playback.hw_status; chip->playback.hw_udata : chip->playback.hw_status;
char data[32]; unsigned char data[32];
int err, idx; int err, idx;
if (!memcmp(hw_data, ndata, count)) if (!memcmp(hw_data, ndata, count))