Commit 9382187e authored by Krzysztof Halasa's avatar Krzysztof Halasa Committed by Linus Torvalds

[PATCH] fix for integer overflow in hd6457[02] driver code

The attached patch fixes an integer overflow in drivers for N2, C101,
PCI200SYN WAN cards (brv * port->settings.clock_rate overflowed at
requested clock rate of 8*1024*1024 bps, problem noted by Nagaraj Kanniah).
parent e05b0c00
...@@ -463,8 +463,8 @@ static void sca_set_port(port_t *port) ...@@ -463,8 +463,8 @@ static void sca_set_port(port_t *port)
brv >>= 1; /* brv = 2^9 = 512 max in specs */ brv >>= 1; /* brv = 2^9 = 512 max in specs */
/* Baud Rate = CLOCK_BASE / TMC / 2^BR */ /* Baud Rate = CLOCK_BASE / TMC / 2^BR */
tmc = CLOCK_BASE / (brv * port->settings.clock_rate); tmc = CLOCK_BASE / brv / port->settings.clock_rate;
}while(br > 1 && tmc <= 128); }while (br > 1 && tmc <= 128);
if (tmc < 1) { if (tmc < 1) {
tmc = 1; tmc = 1;
...@@ -473,7 +473,7 @@ static void sca_set_port(port_t *port) ...@@ -473,7 +473,7 @@ static void sca_set_port(port_t *port)
} else if (tmc > 255) } else if (tmc > 255)
tmc = 256; /* tmc=0 means 256 - low baud rates */ tmc = 256; /* tmc=0 means 256 - low baud rates */
port->settings.clock_rate = CLOCK_BASE / (brv * tmc); port->settings.clock_rate = CLOCK_BASE / brv / tmc;
} else { } else {
br = 9; /* Minimum clock rate */ br = 9; /* Minimum clock rate */
tmc = 256; /* 8bit = 0 */ tmc = 256; /* 8bit = 0 */
......
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