From df70b21c7031f75915e4d493fc75a675a51705eb Mon Sep 17 00:00:00 2001 From: David Kopf Date: Sun, 31 Jul 2011 15:36:01 -0400 Subject: [PATCH] gcc 4.4.1 - 4.6.0 compiler bug workaround. --- core/net/uip6.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/core/net/uip6.c b/core/net/uip6.c index 1ae674b3b..5e7cdc6d9 100644 --- a/core/net/uip6.c +++ b/core/net/uip6.c @@ -355,7 +355,16 @@ uip_ipchksum(void) static u16_t upper_layer_chksum(u8_t proto) { - u16_t upper_layer_len; +/* gcc 4.4.0 - 4.6.1 (maybe 4.3...) with -Os on 8 bit CPUS incorrectly compiles: + * int bar (int); + * int foo (unsigned char a, unsigned char b) { + * int len = (a << 8) + b; //len becomes 0xff00&+b + * return len + bar (len); + * } + * upper_layer_len triggers this bug unless it is declared volatile. + * See https://sourceforge.net/apps/mantisbt/contiki/view.php?id=3 + */ + volatile u16_t upper_layer_len; u16_t sum; upper_layer_len = (((u16_t)(UIP_IP_BUF->len[0]) << 8) + UIP_IP_BUF->len[1] - uip_ext_len) ;