Commit c0cb7ef0 authored by Allan Stephens's avatar Allan Stephens Committed by David S. Miller

[TIPC]: Enhancements to message header writing

This patch makes two enhancements to the routine used to
set bit fields within a TIPC message header:

 1) It now ignores any bits of the new field value that are not
    covered by the mask being used.  (Previously, if the new value
    exceeded the size of the mask the extra bits could corrupt
    other fields in the message header word being updated.)

 2) The code has been optimized to minimize the number of run-time
    endianness conversion operations by leveraging the fact that the
    mask (and, in some cases, the value as well) is constant and the
    necessary conversion can be performed by the compiler.
Signed-off-by: default avatarAllan Stephens <allan.stephens@windriver.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 37695420
...@@ -70,8 +70,10 @@ static inline void msg_set_bits(struct tipc_msg *m, u32 w, ...@@ -70,8 +70,10 @@ static inline void msg_set_bits(struct tipc_msg *m, u32 w,
u32 pos, u32 mask, u32 val) u32 pos, u32 mask, u32 val)
{ {
val = (val & mask) << pos; val = (val & mask) << pos;
m->hdr[w] &= ~htonl(mask << pos); val = htonl(val);
m->hdr[w] |= htonl(val); mask = htonl(mask << pos);
m->hdr[w] &= ~mask;
m->hdr[w] |= val;
} }
/* /*
......
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