drivers: staging: rts5208: fix endianness handling
authorOmri Arad <omriarad3@gmail.com>
Sat, 14 Jan 2017 16:58:02 +0000 (18:58 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 16 Jan 2017 17:08:57 +0000 (18:08 +0100)
'cb' and 'sgb' were assigned __le values but were not marked as such,
this fixes the following sparse warnings:

drivers/staging/rts5208/rtsx_transport.c:220:34: warning: incorrect type in assignment (different base types)
drivers/staging/rts5208/rtsx_transport.c:220:34:    expected unsigned int [unsigned] [usertype] <noident>
drivers/staging/rts5208/rtsx_transport.c:220:34:    got restricted __le32 [usertype] <noident>
drivers/staging/rts5208/rtsx_transport.c:319:44: warning: incorrect type in assignment (different base types)
drivers/staging/rts5208/rtsx_transport.c:319:44:    expected unsigned long long [unsigned] [long] [long long] [usertype] <noident>
drivers/staging/rts5208/rtsx_transport.c:319:44:    got restricted __le64 [usertype] <noident>
drivers/staging/rts5208/rtsx_transport.c:319:44: warning: incorrect type in assignment (different base types)
drivers/staging/rts5208/rtsx_transport.c:319:44:    expected unsigned long long [unsigned] [long] [long long] [usertype] <noident>
drivers/staging/rts5208/rtsx_transport.c:319:44:    got restricted __le64 [usertype] <noident>

Signed-off-by: Omri Arad <omriarad3@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/rts5208/rtsx_transport.c

index 4d8e7c5c26d55c4afcdd3cd45f357901f3093895..23799013c4329952b278ff6656970324f2fd1b6c 100644 (file)
@@ -207,7 +207,7 @@ handle_errors:
 void rtsx_add_cmd(struct rtsx_chip *chip,
                  u8 cmd_type, u16 reg_addr, u8 mask, u8 data)
 {
-       u32 *cb = (u32 *)(chip->host_cmds_ptr);
+       __le32 *cb = (__le32 *)(chip->host_cmds_ptr);
        u32 val = 0;
 
        val |= (u32)(cmd_type & 0x03) << 30;
@@ -300,7 +300,7 @@ finish_send_cmd:
 static inline void rtsx_add_sg_tbl(
        struct rtsx_chip *chip, u32 addr, u32 len, u8 option)
 {
-       u64 *sgb = (u64 *)(chip->host_sg_tbl_ptr);
+       __le64 *sgb = (__le64 *)(chip->host_sg_tbl_ptr);
        u64 val = 0;
        u32 temp_len = 0;
        u8  temp_opt = 0;