1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 23:32:59 +01:00
RIOT/sys/auto_init/auto_init.c
Kaspar Schleiser 825ffddbf9 sys/test_utils/dummy_thread: initial commit
This commit adds a module that just creates a thread that does nothing,
at boot time, in auto_init().
2020-06-09 13:25:14 +02:00

262 lines
8.0 KiB
C

/**
* Auto initialization for used modules
*
* Copyright (C) 2020 Freie Universität Berlin
* 2020 Kaspar Schleiser <kaspar@schleiser.de>
* 2013 INRIA.
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*
* @ingroup sys_auto_init
* @{
* @file
* @brief initializes any used module that has a trivial init function
* @author Oliver Hahm <oliver.hahm@inria.fr>
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
* @author Kaspar Schleiser <kaspar@schleiser.de>
* @author Martine S. Lenders <m.lenders@fu-berlin.de>
* @}
*/
#include <stdint.h>
#include <stdio.h>
#include "auto_init.h"
#include "kernel_defines.h"
#include "log.h"
void auto_init(void)
{
if (IS_USED(MODULE_AUTO_INIT_RANDOM)) {
LOG_DEBUG("Auto init random.\n");
extern void auto_init_random(void);
auto_init_random();
}
if (IS_USED(MODULE_AUTO_INIT_ZTIMER)) {
LOG_DEBUG("Auto init ztimer.\n");
void ztimer_init(void);
ztimer_init();
}
if (IS_USED(MODULE_AUTO_INIT_XTIMER) &&
!IS_USED(MODULE_ZTIMER_XTIMER_COMPAT)) {
LOG_DEBUG("Auto init xtimer.\n");
extern void xtimer_init(void);
xtimer_init();
}
if (IS_USED(MODULE_SCHEDSTATISTICS)) {
LOG_DEBUG("Auto init schedstatistics.\n");
extern void init_schedstatistics(void);
init_schedstatistics();
}
if (IS_USED(MODULE_DUMMY_THREAD)) {
extern void dummy_thread_create(void);
dummy_thread_create();
}
if (IS_USED(MODULE_EVENT_THREAD)) {
LOG_DEBUG("Auto init event threads.\n");
extern void auto_init_event_thread(void);
auto_init_event_thread();
}
if (IS_USED(MODULE_MCI)) {
LOG_DEBUG("Auto init mci.\n");
extern void mci_initialize(void);
mci_initialize();
}
if (IS_USED(MODULE_PROFILING)) {
LOG_DEBUG("Auto init profiling.\n");
extern void profiling_init(void);
profiling_init();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_PKTBUF)) {
LOG_DEBUG("Auto init gnrc_pktbuf.\n");
extern void gnrc_pktbuf_init(void);
gnrc_pktbuf_init();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_PKTDUMP)) {
LOG_DEBUG("Auto init gnrc_pktdump.\n");
extern void gnrc_pktdump_init(void);
gnrc_pktdump_init();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_SIXLOWPAN)) {
LOG_DEBUG("Auto init gnrc_sixlowpan.\n");
extern void gnrc_sixlowpan_init(void);
gnrc_sixlowpan_init();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_IPV6)) {
LOG_DEBUG("Auto init gnrc_ipv6.\n");
extern void gnrc_ipv6_init(void);
gnrc_ipv6_init();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_UDP)) {
LOG_DEBUG("Auto init gnrc_udp.\n");
extern void gnrc_udp_init(void);
gnrc_udp_init();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_TCP)) {
LOG_DEBUG("Auto init gnrc_tcp.\n");
extern void gnrc_tcp_init(void);
gnrc_tcp_init();
}
if (IS_USED(MODULE_AUTO_INIT_LWIP)) {
LOG_DEBUG("Bootstraping lwIP.\n");
extern void lwip_bootstrap(void);
lwip_bootstrap();
}
if (IS_USED(MODULE_OPENTHREAD)) {
LOG_DEBUG("Bootstrapping openthread.\n");
extern void openthread_bootstrap(void);
openthread_bootstrap();
}
if (IS_USED(MODULE_GCOAP) &&
!IS_ACTIVE(CONFIG_GCOAP_NO_AUTO_INIT)) {
LOG_DEBUG("Auto init gcoap.\n");
extern void gcoap_init(void);
gcoap_init();
}
if (IS_USED(MODULE_DEVFS)) {
LOG_DEBUG("Mounting /dev.\n");
extern void auto_init_devfs(void);
auto_init_devfs();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_IPV6_NIB)) {
LOG_DEBUG("Auto init gnrc_ipv6_nib.\n");
extern void gnrc_ipv6_nib_init(void);
gnrc_ipv6_nib_init();
}
if (IS_USED(MODULE_SKALD)) {
LOG_DEBUG("Auto init Skald.\n");
extern void skald_init(void);
skald_init();
}
if (IS_USED(MODULE_CORD_COMMON)) {
LOG_DEBUG("Auto init cord_common.\n");
extern void cord_common_init(void);
cord_common_init();
}
if (IS_USED(MODULE_CORD_EP_STANDALONE)) {
LOG_DEBUG("Auto init cord_ep_standalone.\n");
extern void cord_ep_standalone_run(void);
cord_ep_standalone_run();
}
if (IS_USED(MODULE_ASYMCUTE)) {
LOG_DEBUG("Auto init Asymcute.\n");
extern void asymcute_handler_run(void);
asymcute_handler_run();
}
if (IS_USED(MODULE_NIMBLE)) {
LOG_DEBUG("Auto init NimBLE.\n");
extern void nimble_riot_init(void);
nimble_riot_init();
}
if (IS_USED(MODULE_AUTO_INIT_LORAMAC)) {
LOG_DEBUG("Auto init loramac.\n");
extern void auto_init_loramac(void);
auto_init_loramac();
}
if (IS_USED(MODULE_SOCK_DTLS)) {
LOG_DEBUG("Auto init sock_dtls.\n");
extern void sock_dtls_init(void);
sock_dtls_init();
}
/* initialize USB devices */
if (IS_USED(MODULE_AUTO_INIT_USBUS)) {
LOG_DEBUG("Auto init USB.\n");
extern void auto_init_usb(void);
auto_init_usb();
}
/* initialize network devices */
if (IS_USED(MODULE_AUTO_INIT_GNRC_NETIF)) {
LOG_DEBUG("Auto init gnrc_netif.\n");
extern void gnrc_netif_init_devs(void);
gnrc_netif_init_devs();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_UHCPC)) {
LOG_DEBUG("Auto init gnrc_uhcpc.\n");
extern void auto_init_gnrc_uhcpc(void);
auto_init_gnrc_uhcpc();
}
/* initialize NDN module after the network devices are initialized */
if (IS_USED(MODULE_NDN_RIOT)) {
LOG_DEBUG("Auto init NDN.\n");
extern void ndn_init(void);
ndn_init();
}
/* initialize sensors and actuators */
if (IS_USED(MODULE_SHT1X)) {
/* The sht1x module needs to be initialized regardless of SAUL being used,
* as the shell commands rely on auto-initialization. auto_init_sht1x also
* performs SAUL registration, but only if module auto_init_saul is used.
*/
LOG_DEBUG("Auto init sht1x.\n");
extern void auto_init_sht1x(void);
auto_init_sht1x();
}
if (IS_USED(MODULE_AUTO_INIT_SAUL)) {
LOG_DEBUG("Auto init SAUL.\n");
extern void saul_init_devs(void);
saul_init_devs();
}
if (IS_USED(MODULE_AUTO_INIT_GNRC_RPL)) {
LOG_DEBUG("Auto init gnrc_rpl.\n");
extern void auto_init_gnrc_rpl(void);
auto_init_gnrc_rpl();
}
/* initialize storage devices */
if (IS_USED(MODULE_AUTO_INIT_STORAGE)) {
LOG_DEBUG("Auto init STORAGE.\n");
if (IS_USED(MODULE_SDCARD_SPI)) {
extern void auto_init_sdcard_spi(void);
auto_init_sdcard_spi();
}
}
if (IS_USED(MODULE_AUTO_INIT_CAN)) {
LOG_DEBUG("Auto init CAN.\n");
extern void auto_init_candev(void);
auto_init_candev();
}
if (IS_USED(MODULE_SUIT)) {
LOG_DEBUG("Auto init SUIT conditions.\n");
extern void suit_init_conditions(void);
suit_init_conditions();
}
if (IS_USED(MODULE_AUTO_INIT_SECURITY)) {
if (IS_USED(MODULE_CRYPTOAUTHLIB)) {
LOG_DEBUG("Auto init cryptoauthlib.\n");
extern void auto_init_atca(void);
auto_init_atca();
}
}
if (IS_USED(MODULE_TEST_UTILS_INTERACTIVE_SYNC) && !IS_USED(MODULE_SHELL)) {
extern void test_utils_interactive_sync(void);
test_utils_interactive_sync();
}
if (IS_USED(MODULE_AUTO_INIT_DHCPV6_CLIENT)) {
LOG_DEBUG("Auto init DHCPv6 client.\n");
extern void dhcpv6_client_auto_init(void);
dhcpv6_client_auto_init();
}
if (IS_USED(MODULE_GNRC_DHCPV6_CLIENT_6LBR)) {
LOG_DEBUG("Auto init 6LoWPAN border router DHCPv6 client\n");
extern void gnrc_dhcpv6_client_6lbr_init(void);
gnrc_dhcpv6_client_6lbr_init();
}
}