2014-05-12 13:09:12 +02:00
|
|
|
Valgrind Support
|
2013-09-30 14:07:10 +02:00
|
|
|
================
|
|
|
|
|
2014-02-10 15:28:55 +01:00
|
|
|
Rebuild your application using the all-valgrind target like this:
|
2014-02-11 18:15:43 +01:00
|
|
|
|
2014-02-04 18:41:38 +01:00
|
|
|
make -B clean all-valgrind
|
2013-09-30 14:07:10 +02:00
|
|
|
|
2014-05-12 13:09:12 +02:00
|
|
|
That way native will tell Valgrind about RIOT's stacks and prevent
|
|
|
|
Valgrind from reporting lots of false positives.
|
|
|
|
The debug information flag `-g` is not strictly necessary, but passing
|
|
|
|
it allows Valgrind to tell you precisely which code triggered the error.
|
2013-09-30 14:07:10 +02:00
|
|
|
|
2014-02-04 18:41:38 +01:00
|
|
|
To run your application run:
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2014-05-12 13:09:12 +02:00
|
|
|
make term-valgrind
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2014-05-12 13:09:12 +02:00
|
|
|
All this does is run your application under Valgrind.
|
|
|
|
Now Valgrind will print some information whenever it detects an
|
2014-02-04 18:41:38 +01:00
|
|
|
invalid memory access.
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2016-01-26 17:38:15 +01:00
|
|
|
In order to debug the program when this occurs you can use the targets
|
|
|
|
debug-valgrind-server and debug-valgrind. Therefore, you need to open two
|
|
|
|
terminals and run:
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2016-01-26 17:38:15 +01:00
|
|
|
make debug-valgrind-server
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2016-01-26 17:38:15 +01:00
|
|
|
in the first one and run:
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2016-01-26 17:38:15 +01:00
|
|
|
make debug-valgrind
|
2013-09-30 14:07:10 +02:00
|
|
|
|
2016-01-26 17:38:15 +01:00
|
|
|
in the seconde one. This starts per default gdb attached to valgrinds gdb
|
|
|
|
server (vgdb).
|
2013-09-30 14:07:10 +02:00
|
|
|
|
2014-05-12 13:09:12 +02:00
|
|
|
Network Support
|
2013-09-30 14:07:10 +02:00
|
|
|
===============
|
|
|
|
|
2017-02-15 13:07:34 +01:00
|
|
|
If you compile RIOT for the native cpu and include the `netdev_tap`
|
2013-06-26 23:29:09 +02:00
|
|
|
module, you need to specify a network interface like this:
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2014-05-12 13:09:12 +02:00
|
|
|
make term PORT=tap0
|
2013-06-26 23:29:09 +02:00
|
|
|
|
2016-03-08 16:39:36 +01:00
|
|
|
**Please note:** in case you're using RIOT's default network stack, the GNRC
|
2016-03-22 16:41:51 +01:00
|
|
|
stack, you may also use `gnrc_netdev_default` module and also add
|
2016-03-08 16:39:36 +01:00
|
|
|
`auto_init_gnrc_netif` in order to automatically initialize the interface.
|
2013-06-26 23:29:09 +02:00
|
|
|
|
2016-03-08 16:39:36 +01:00
|
|
|
|
|
|
|
Setting Up A Virtual Network
|
|
|
|
============================
|
2013-06-26 23:29:09 +02:00
|
|
|
|
2015-06-14 01:29:55 +02:00
|
|
|
There is a shellscript in RIOT/dist/tools/tapsetup called `tapsetup` which you
|
2013-06-26 23:29:09 +02:00
|
|
|
can use to create a network of tap interfaces.
|
|
|
|
|
|
|
|
Usage:
|
|
|
|
To create a bridge and two (or count at your option) tap interfaces:
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2019-07-23 13:30:59 +02:00
|
|
|
sudo ../../dist/tools/tapsetup/tapsetup [-c [<count>]]
|
2013-10-24 12:58:28 +02:00
|
|
|
|
2015-06-14 01:29:55 +02:00
|
|
|
On OSX you need to start the RIOT instance at some point during the script's
|
|
|
|
execution. The script will instruct you when to do that.
|
2013-08-18 20:34:53 +02:00
|
|
|
|
2015-06-14 01:29:55 +02:00
|
|
|
To delete the bridge and all tap interfaces:
|
2013-08-18 20:34:53 +02:00
|
|
|
|
2019-07-23 13:30:59 +02:00
|
|
|
sudo ../../dist/tools/tapsetup/tapsetup -d
|
2014-05-12 13:09:12 +02:00
|
|
|
|
2015-06-14 01:29:55 +02:00
|
|
|
For OSX you **have** to run this after killing your RIOT instance and rerun
|
2019-07-23 13:30:59 +02:00
|
|
|
`sudo ../../dist/tools/tapsetup [-c [<count>]]` before restarting.
|
2014-05-12 13:09:12 +02:00
|
|
|
|
2016-03-08 16:39:36 +01:00
|
|
|
**Please note:** If you want to communicate between RIOT and your host
|
|
|
|
operating system, you must not use the `tapsetup` script, but create and
|
|
|
|
activate the tap interface manually. On Linux you can do so, by calling
|
|
|
|
|
|
|
|
sudo ip tuntap add tap0 mode tap user ${USER}
|
|
|
|
sudo ip link set tap0 up
|
|
|
|
|
2014-05-12 13:09:12 +02:00
|
|
|
|
|
|
|
Daemonization
|
2013-08-18 20:34:53 +02:00
|
|
|
=============
|
|
|
|
|
|
|
|
You can daemonize a riot process. This is useful for larger networks.
|
|
|
|
Valgrind will fork along with the riot process and dump its output in
|
|
|
|
the terminal.
|
|
|
|
|
|
|
|
Usage:
|
2014-05-12 13:09:12 +02:00
|
|
|
|
2014-02-01 12:10:08 +01:00
|
|
|
./bin/native/default.elf -d
|
2013-08-18 20:34:53 +02:00
|
|
|
|
2014-05-12 13:09:12 +02:00
|
|
|
Compile Time Options
|
2014-04-04 08:21:23 +02:00
|
|
|
====================
|
|
|
|
|
|
|
|
Compile with
|
2014-05-12 13:09:12 +02:00
|
|
|
|
2014-04-04 08:21:23 +02:00
|
|
|
CFLAGS=-DNATIVE_AUTO_EXIT make
|
|
|
|
|
|
|
|
to exit the riot core after the last thread has exited.
|