Commit f46c1e81 authored by Corey Minyard's avatar Corey Minyard Committed by Kleber Sacilotto de Souza

ipmi: fix unsigned long underflow

BugLink: http://bugs.launchpad.net/bugs/1744794

commit 392a17b1 upstream.

When I set the timeout to a specific value such as 500ms, the timeout
event will not happen in time due to the overflow in function
check_msg_timeout:
...
	ent->timeout -= timeout_period;
	if (ent->timeout > 0)
		return;
...

The type of timeout_period is long, but ent->timeout is unsigned long.
This patch makes the type consistent.
Reported-by: default avatarWeilong Chen <chenweilong@huawei.com>
Signed-off-by: default avatarCorey Minyard <cminyard@mvista.com>
Tested-by: default avatarWeilong Chen <chenweilong@huawei.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent 82834ff4
...@@ -4029,7 +4029,8 @@ smi_from_recv_msg(ipmi_smi_t intf, struct ipmi_recv_msg *recv_msg, ...@@ -4029,7 +4029,8 @@ smi_from_recv_msg(ipmi_smi_t intf, struct ipmi_recv_msg *recv_msg,
} }
static void check_msg_timeout(ipmi_smi_t intf, struct seq_table *ent, static void check_msg_timeout(ipmi_smi_t intf, struct seq_table *ent,
struct list_head *timeouts, long timeout_period, struct list_head *timeouts,
unsigned long timeout_period,
int slot, unsigned long *flags, int slot, unsigned long *flags,
unsigned int *waiting_msgs) unsigned int *waiting_msgs)
{ {
...@@ -4042,8 +4043,8 @@ static void check_msg_timeout(ipmi_smi_t intf, struct seq_table *ent, ...@@ -4042,8 +4043,8 @@ static void check_msg_timeout(ipmi_smi_t intf, struct seq_table *ent,
if (!ent->inuse) if (!ent->inuse)
return; return;
ent->timeout -= timeout_period; if (timeout_period < ent->timeout) {
if (ent->timeout > 0) { ent->timeout -= timeout_period;
(*waiting_msgs)++; (*waiting_msgs)++;
return; return;
} }
...@@ -4109,7 +4110,8 @@ static void check_msg_timeout(ipmi_smi_t intf, struct seq_table *ent, ...@@ -4109,7 +4110,8 @@ static void check_msg_timeout(ipmi_smi_t intf, struct seq_table *ent,
} }
} }
static unsigned int ipmi_timeout_handler(ipmi_smi_t intf, long timeout_period) static unsigned int ipmi_timeout_handler(ipmi_smi_t intf,
unsigned long timeout_period)
{ {
struct list_head timeouts; struct list_head timeouts;
struct ipmi_recv_msg *msg, *msg2; struct ipmi_recv_msg *msg, *msg2;
......
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