tipc: use only positive error codes in messages

In commit e3a77561e7 ("tipc: split up function tipc_msg_eval()"),
we have updated the function tipc_msg_lookup_dest() to set the error
codes to negative values at destination lookup failures. Thus when
the function sets the error code to -TIPC_ERR_NO_NAME, its inserted
into the 4 bit error field of the message header as 0xf instead of
TIPC_ERR_NO_NAME (1). The value 0xf is an unknown error code.

In this commit, we set only positive error code.

Fixes: e3a77561e7 ("tipc: split up function tipc_msg_eval()")
Signed-off-by: Parthasarathy Bhuvaragan <parthasarathy.bhuvaragan@ericsson.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Parthasarathy Bhuvaragan 2017-09-29 10:02:54 +02:00 committed by David S. Miller
parent 5a59a3a0ef
commit aad06212d3

View File

@ -551,7 +551,7 @@ bool tipc_msg_lookup_dest(struct net *net, struct sk_buff *skb, int *err)
return false; return false;
if (msg_errcode(msg)) if (msg_errcode(msg))
return false; return false;
*err = -TIPC_ERR_NO_NAME; *err = TIPC_ERR_NO_NAME;
if (skb_linearize(skb)) if (skb_linearize(skb))
return false; return false;
msg = buf_msg(skb); msg = buf_msg(skb);