mirror of
https://github.com/torvalds/linux.git
synced 2026-06-10 07:32:29 +02:00
n_gsm: Fix message length handling when building header
commit be7a7411d6 upstream.
Fix message length handling when building header
When the message length is greater than 127, the length field in the header
is built incorrectly. According to the spec, when the length is less than 128
the length field is a single byte formatted as: bbbbbbb1. When it is greater
than 127 then the field is two bytes of the format: bbbbbbb0 bbbbbbbb.
Signed-off-by: Ken Mills <ken.k.mills@intel.com>
Signed-off-by: Alan Cox <alan@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
2f968c28df
commit
bd7e2ae3d4
|
|
@ -716,8 +716,8 @@ static void __gsm_data_queue(struct gsm_dlci *dlci, struct gsm_msg *msg)
|
|||
if (msg->len < 128)
|
||||
*--dp = (msg->len << 1) | EA;
|
||||
else {
|
||||
*--dp = (msg->len >> 6) | EA;
|
||||
*--dp = (msg->len & 127) << 1;
|
||||
*--dp = (msg->len >> 7); /* bits 7 - 15 */
|
||||
*--dp = (msg->len & 127) << 1; /* bits 0 - 6 */
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user