staging: fbtft: differentiate between buffer and data types to fix sparse warning

sparse was complaning about an incorrect type cast:
drivers/staging/fbtft/fbtft-bus.c:60:1: warning: incorrect type in assignment (different base types)
drivers/staging/fbtft/fbtft-bus.c:60:1:    expected unsigned short [unsigned] [short] [usertype] <noident>
drivers/staging/fbtft/fbtft-bus.c:60:1:    got restricted __be16 [usertype] <noident>
drivers/staging/fbtft/fbtft-bus.c:60:1: warning: incorrect type in assignment (different base types)
drivers/staging/fbtft/fbtft-bus.c:60:1:    expected unsigned short [unsigned] [short] [usertype] <noident>
drivers/staging/fbtft/fbtft-bus.c:60:1:    got restricted __be16 [usertype] <noident>

The solution is to add an extra parameter to the macro to
differentiate between buffer type and data type.

Cc: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Signed-off-by: Alfonso Lima Astor <alfonsolimaastor@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Alfonso Lima Astor 2017-10-17 18:46:29 +01:00 committed by Greg Kroah-Hartman
parent 4aca3ca4b7
commit 8d8825b420
1 changed files with 12 additions and 12 deletions

View File

@ -10,33 +10,33 @@
* *
*****************************************************************************/ *****************************************************************************/
#define define_fbtft_write_reg(func, type, modifier) \ #define define_fbtft_write_reg(func, buffer_type, data_type, modifier) \
void func(struct fbtft_par *par, int len, ...) \ void func(struct fbtft_par *par, int len, ...) \
{ \ { \
va_list args; \ va_list args; \
int i, ret; \ int i, ret; \
int offset = 0; \ int offset = 0; \
type *buf = (type *)par->buf; \ buffer_type *buf = (buffer_type *)par->buf; \
\ \
if (unlikely(par->debug & DEBUG_WRITE_REGISTER)) { \ if (unlikely(par->debug & DEBUG_WRITE_REGISTER)) { \
va_start(args, len); \ va_start(args, len); \
for (i = 0; i < len; i++) { \ for (i = 0; i < len; i++) { \
buf[i] = (type)va_arg(args, unsigned int); \ buf[i] = modifier((data_type)va_arg(args, unsigned int)); \
} \ } \
va_end(args); \ va_end(args); \
fbtft_par_dbg_hex(DEBUG_WRITE_REGISTER, par, par->info->device, type, buf, len, "%s: ", __func__); \ fbtft_par_dbg_hex(DEBUG_WRITE_REGISTER, par, par->info->device, buffer_type, buf, len, "%s: ", __func__); \
} \ } \
\ \
va_start(args, len); \ va_start(args, len); \
\ \
if (par->startbyte) { \ if (par->startbyte) { \
*(u8 *)par->buf = par->startbyte; \ *(u8 *)par->buf = par->startbyte; \
buf = (type *)(par->buf + 1); \ buf = (buffer_type *)(par->buf + 1); \
offset = 1; \ offset = 1; \
} \ } \
\ \
*buf = modifier((type)va_arg(args, unsigned int)); \ *buf = modifier((data_type)va_arg(args, unsigned int)); \
ret = fbtft_write_buf_dc(par, par->buf, sizeof(type) + offset, 0); \ ret = fbtft_write_buf_dc(par, par->buf, sizeof(data_type) + offset, 0); \
if (ret < 0) \ if (ret < 0) \
goto out; \ goto out; \
len--; \ len--; \
@ -47,18 +47,18 @@ void func(struct fbtft_par *par, int len, ...) \
if (len) { \ if (len) { \
i = len; \ i = len; \
while (i--) \ while (i--) \
*buf++ = modifier((type)va_arg(args, unsigned int)); \ *buf++ = modifier((data_type)va_arg(args, unsigned int)); \
fbtft_write_buf_dc(par, par->buf, \ fbtft_write_buf_dc(par, par->buf, \
len * (sizeof(type) + offset), 1); \ len * (sizeof(data_type) + offset), 1); \
} \ } \
out: \ out: \
va_end(args); \ va_end(args); \
} \ } \
EXPORT_SYMBOL(func); EXPORT_SYMBOL(func);
define_fbtft_write_reg(fbtft_write_reg8_bus8, u8, ) define_fbtft_write_reg(fbtft_write_reg8_bus8, u8, u8, )
define_fbtft_write_reg(fbtft_write_reg16_bus8, u16, cpu_to_be16) define_fbtft_write_reg(fbtft_write_reg16_bus8, __be16, u16, cpu_to_be16)
define_fbtft_write_reg(fbtft_write_reg16_bus16, u16, ) define_fbtft_write_reg(fbtft_write_reg16_bus16, u16, u16, )
void fbtft_write_reg8_bus9(struct fbtft_par *par, int len, ...) void fbtft_write_reg8_bus9(struct fbtft_par *par, int len, ...)
{ {