1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys
Cenk Gündoğan 6065be76e1 ndp: warn gcc-7 about intentional fall-through
Since gcc-7 `Wimplicit-fallthrough` is activated by using `-Wextra`.
This leads to the following problem when compiling `gnrc_networking`:

```
RIOT/sys/net/gnrc/network_layer/ndp/internal/gnrc_ndp_internal.c: In function ‘gnrc_ndp_internal_set_state’:
RIOT/sys/net/gnrc/network_layer/ndp/internal/gnrc_ndp_internal.c:106:15: error: this statement may fall through [-Werror=implicit-fallthrough=]
   t = ipv6_iface->reach_time;
  ~~^~~~~~~~~~~~~~~~~~~~~~~~
RIOT/sys/net/gnrc/network_layer/ndp/internal/gnrc_ndp_internal.c:109:9: note: here
case GNRC_IPV6_NC_STATE_DELAY:
         ^~~~
```

The fall-through in this code is intentional. There are several ways to
warn the comiler about such intentional fall-throughs, which include
e.g. attributed empty statements (`__attribute__ ((fallthrough));`).
I don't like tis approach however. The best way would probably be to
remove this fall-through from the code. However, to keep the diff
minimal, and since ndp will change in the future, I went for warning
the compiler using comments.

The compiler checks comments for several *fall through* regexs to
decide whether a fallthrough was intentional or not.

You can read more about this gcc option in [1]. A note about
fallthrough comment regexs is at the bottom of this article.

[1] https://developers.redhat.com/blog/2017/03/10/wimplicit-fallthrough-in-gcc-7/
2017-05-30 14:23:37 +02:00
..
analog_util sys: s/adc_util/analog_util/ and added DAC mapping 2016-03-14 20:39:31 +01:00
arduino sys/arduino: Make SerialPort constructor explicit 2017-02-17 08:02:36 +01:00
auto_init saul/gpio: differentiate SENSE_BTN and ACT_SWITCH 2017-05-09 10:47:31 +02:00
base64 sys/base64: corrected output size determination 2017-01-10 18:30:38 +01:00
bitfield core: Fix/refactor function naming in core/incude/irq.h 2016-03-20 16:47:34 +01:00
bloom sys/bloom: pass bitfield to bloom instead of allocating memory 2015-10-05 11:41:53 +02:00
cbor adapt to changed byteorder.h 2017-04-13 11:35:35 +02:00
checksum tests: provide unittests for ucrc16 2016-12-27 00:58:11 +01:00
color sys/color: added RGB inversion and complementary color 2016-03-16 11:43:26 +01:00
cpp11-compat s adapted doc 2017-05-18 14:53:03 +02:00
crypto sys/crypto: remove 3DES 2017-04-25 18:34:18 +02:00
div sys/div: Add support for big 64 bit numbers 2016-11-28 11:00:42 +01:00
ecc sys/ecc/hamming256: fix variableScope 2016-09-05 02:22:37 +02:00
embunit cleanup: apply headerguard script output 2017-05-24 17:54:02 +02:00
fmt sys: fmt: add fmt_float() and print_float() 2017-05-20 14:47:29 +02:00
fs doc: fix doc hierarchy 2017-03-20 11:59:10 +01:00
hashes sys/hashes: add AES-CMAC implementation 2017-05-08 13:52:11 +02:00
include net/gcoap: make input parameters const 2017-05-26 16:34:40 +02:00
isrpipe sys: add isrpipe 2016-12-16 09:48:08 +01:00
libc/include/sys cleanup: apply headerguard script output 2017-05-24 17:54:02 +02:00
log cleanup: apply headerguard script output 2017-05-24 17:54:02 +02:00
luid sys/drivers: renamed uuid module to luid 2017-02-27 11:01:20 +01:00
mineplex sys: added 5x5 font 'Mineplex' 2016-11-09 11:59:45 +01:00
net ndp: warn gcc-7 about intentional fall-through 2017-05-30 14:23:37 +02:00
newlib newlib: Use vfs for file I/O syscalls 2017-03-07 17:59:57 +01:00
od od: simplify od module to only provide od_hex_dump 2017-03-28 19:14:59 +02:00
oneway-malloc sys: fix include headers guards 2016-10-26 21:53:58 +02:00
phydat sys/phydat: adding illuminance unit (Lux) 2016-06-06 11:04:11 +02:00
pipe tests: adapt for arduino uno and duemilanove support 2016-09-21 21:12:58 +02:00
pm_layered pm_layerd: fix initial value for PM_BLOCKER_INITIAL 2017-03-28 19:32:32 +02:00
posix cleanup: apply headerguard script output 2017-05-24 17:54:02 +02:00
ps Merge pull request #6975 from OTAkeys/pr/ps_schedstatistics_fix 2017-05-17 13:50:42 +02:00
quad_math add some missing header guards 2017-05-24 17:54:01 +02:00
random cleanup: apply headerguard script output 2017-05-24 17:54:02 +02:00
rtt_stdio rtt_stdio: update for new xtimer api 2016-11-29 20:44:31 +01:00
saul_reg sys/saul_reg: fixed return value for rm() 2016-04-15 15:06:25 +02:00
sema sys/sema: re-test value after owning mutex 2017-03-06 18:03:27 +01:00
seq seq: bitwise and instead of mod 2016-04-08 23:53:46 +02:00
shell Merge pull request #7059 from OTAkeys/pr/fix_ls_handler 2017-05-24 17:55:52 +02:00
timex timex: unambiguous time conversion macros 2017-01-19 13:18:08 +01:00
trickle timex: unambiguous time conversion macros 2017-01-19 13:18:08 +01:00
tsrb sys: add thread-safe ringbuffer implementation 2015-09-25 09:08:34 +02:00
uart_stdio uart_stdio: Bind uart_stdio to vfs fds for stdin/out/err 2017-03-07 17:59:58 +01:00
ubjson cleanup: apply headerguard script output 2017-05-24 17:54:02 +02:00
universal_address universal_address: fix cppcheck warning 2017-04-14 14:36:15 +02:00
vfs sys/vfs: A virtual file system (VFS) layer for RIOT 2017-03-07 17:59:57 +01:00
xtimer some (ptr == 0) -> (ptr == NULL) fixes (found by coccinelle) 2017-04-20 23:31:32 +02:00
doc.txt
Makefile Merge pull request #6072 from MichelRottleuthner/fatfs_testing 2017-05-23 09:03:19 +02:00
Makefile.include sys/vfs: A virtual file system (VFS) layer for RIOT 2017-03-07 17:59:57 +01:00