aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarek Lindner <lindner_marek@yahoo.de>2010-10-19 05:59:15 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2010-10-19 13:04:16 -0400
commit1bc80e95274a96f1bd6af25bb65f33cef57f6704 (patch)
tree6dd07cd851554f2844a6a94604c6054d184b0b8b
parent15f00687e3b7b88c23d498d2c65e5911d8efa214 (diff)
Staging: batman-adv: process OGMs bigger than MAX_AGGREGATION_BYTES
Reported-by: Sam Yeung <sam.cwyeung@gmail.com> Signed-off-by: Marek Lindner <lindner_marek@yahoo.de> Signed-off-by: Sven Eckelmann <sven.eckelmann@gmx.de> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r--drivers/staging/batman-adv/aggregation.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/drivers/staging/batman-adv/aggregation.c b/drivers/staging/batman-adv/aggregation.c
index 16b268ea7aef..08624d44e231 100644
--- a/drivers/staging/batman-adv/aggregation.c
+++ b/drivers/staging/batman-adv/aggregation.c
@@ -257,9 +257,7 @@ void receive_aggr_bat_packet(struct ethhdr *ethhdr, unsigned char *packet_buff,
257 257
258 batman_packet = (struct batman_packet *)packet_buff; 258 batman_packet = (struct batman_packet *)packet_buff;
259 259
260 while (aggregated_packet(buff_pos, packet_len, 260 do {
261 batman_packet->num_hna)) {
262
263 /* network to host order for our 32bit seqno, and the 261 /* network to host order for our 32bit seqno, and the
264 orig_interval. */ 262 orig_interval. */
265 batman_packet->seqno = ntohl(batman_packet->seqno); 263 batman_packet->seqno = ntohl(batman_packet->seqno);
@@ -272,5 +270,6 @@ void receive_aggr_bat_packet(struct ethhdr *ethhdr, unsigned char *packet_buff,
272 buff_pos += BAT_PACKET_LEN + hna_len(batman_packet); 270 buff_pos += BAT_PACKET_LEN + hna_len(batman_packet);
273 batman_packet = (struct batman_packet *) 271 batman_packet = (struct batman_packet *)
274 (packet_buff + buff_pos); 272 (packet_buff + buff_pos);
275 } 273 } while (aggregated_packet(buff_pos, packet_len,
274 batman_packet->num_hna));
276} 275}