Commit b9e8caa7 authored by Frans Klaver's avatar Frans Klaver Committed by Greg Kroah-Hartman

staging: fusb302: don't bitshift __le16 type

The header field in struct pd_message is declared as an __le16 type. The
data in the message is supposed to be little endian. This means we don't
have to go and shift the individual bytes into position when we're
filling the buffer, we can just copy the contents right away. As an
added benefit we don't get fishy results on big endian systems anymore.
Signed-off-by: default avatarFrans Klaver <fransklaver@gmail.com>
Reviewed-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 1877e4ba
...@@ -1039,8 +1039,8 @@ static int fusb302_pd_send_message(struct fusb302_chip *chip, ...@@ -1039,8 +1039,8 @@ static int fusb302_pd_send_message(struct fusb302_chip *chip,
} }
/* packsym tells the FUSB302 chip that the next X bytes are payload */ /* packsym tells the FUSB302 chip that the next X bytes are payload */
buf[pos++] = FUSB302_TKN_PACKSYM | (len & 0x1F); buf[pos++] = FUSB302_TKN_PACKSYM | (len & 0x1F);
buf[pos++] = msg->header & 0xFF; memcpy(&buf[pos], &msg->header, sizeof(msg->header));
buf[pos++] = (msg->header >> 8) & 0xFF; pos += sizeof(msg->header);
len -= 2; len -= 2;
memcpy(&buf[pos], msg->payload, len); memcpy(&buf[pos], msg->payload, len);
......
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