hso: Fix for endian issues on big endian machines
Some fields are always little endian and have to be converted on big endian machines. Signed-off-by: Jan Dumon <j.dumon@option.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
ec157937d9
commit
d9ced80d10
1 changed files with 7 additions and 5 deletions
|
@ -1028,7 +1028,8 @@ static void read_bulk_callback(struct urb *urb)
|
||||||
if (odev->parent->port_spec & HSO_INFO_CRC_BUG) {
|
if (odev->parent->port_spec & HSO_INFO_CRC_BUG) {
|
||||||
u32 rest;
|
u32 rest;
|
||||||
u8 crc_check[4] = { 0xDE, 0xAD, 0xBE, 0xEF };
|
u8 crc_check[4] = { 0xDE, 0xAD, 0xBE, 0xEF };
|
||||||
rest = urb->actual_length % odev->in_endp->wMaxPacketSize;
|
rest = urb->actual_length %
|
||||||
|
le16_to_cpu(odev->in_endp->wMaxPacketSize);
|
||||||
if (((rest == 5) || (rest == 6)) &&
|
if (((rest == 5) || (rest == 6)) &&
|
||||||
!memcmp(((u8 *) urb->transfer_buffer) +
|
!memcmp(((u8 *) urb->transfer_buffer) +
|
||||||
urb->actual_length - 4, crc_check, 4)) {
|
urb->actual_length - 4, crc_check, 4)) {
|
||||||
|
@ -1234,7 +1235,7 @@ static void hso_std_serial_read_bulk_callback(struct urb *urb)
|
||||||
u8 crc_check[4] = { 0xDE, 0xAD, 0xBE, 0xEF };
|
u8 crc_check[4] = { 0xDE, 0xAD, 0xBE, 0xEF };
|
||||||
rest =
|
rest =
|
||||||
urb->actual_length %
|
urb->actual_length %
|
||||||
serial->in_endp->wMaxPacketSize;
|
le16_to_cpu(serial->in_endp->wMaxPacketSize);
|
||||||
if (((rest == 5) || (rest == 6)) &&
|
if (((rest == 5) || (rest == 6)) &&
|
||||||
!memcmp(((u8 *) urb->transfer_buffer) +
|
!memcmp(((u8 *) urb->transfer_buffer) +
|
||||||
urb->actual_length - 4, crc_check, 4)) {
|
urb->actual_length - 4, crc_check, 4)) {
|
||||||
|
@ -2843,8 +2844,9 @@ struct hso_shared_int *hso_create_shared_int(struct usb_interface *interface)
|
||||||
dev_err(&interface->dev, "Could not allocate intr urb?");
|
dev_err(&interface->dev, "Could not allocate intr urb?");
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
mux->shared_intr_buf = kzalloc(mux->intr_endp->wMaxPacketSize,
|
mux->shared_intr_buf =
|
||||||
GFP_KERNEL);
|
kzalloc(le16_to_cpu(mux->intr_endp->wMaxPacketSize),
|
||||||
|
GFP_KERNEL);
|
||||||
if (!mux->shared_intr_buf) {
|
if (!mux->shared_intr_buf) {
|
||||||
dev_err(&interface->dev, "Could not allocate intr buf?");
|
dev_err(&interface->dev, "Could not allocate intr buf?");
|
||||||
goto exit;
|
goto exit;
|
||||||
|
@ -3241,7 +3243,7 @@ static int hso_mux_submit_intr_urb(struct hso_shared_int *shared_int,
|
||||||
usb_rcvintpipe(usb,
|
usb_rcvintpipe(usb,
|
||||||
shared_int->intr_endp->bEndpointAddress & 0x7F),
|
shared_int->intr_endp->bEndpointAddress & 0x7F),
|
||||||
shared_int->shared_intr_buf,
|
shared_int->shared_intr_buf,
|
||||||
shared_int->intr_endp->wMaxPacketSize,
|
1,
|
||||||
intr_callback, shared_int,
|
intr_callback, shared_int,
|
||||||
shared_int->intr_endp->bInterval);
|
shared_int->intr_endp->bInterval);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue