2013-06-18 17:21:38 +02:00
|
|
|
/**
|
2013-06-22 05:11:53 +02:00
|
|
|
* Auto initialization for used modules
|
2013-06-18 17:21:38 +02:00
|
|
|
*
|
2020-02-13 11:01:01 +01:00
|
|
|
* Copyright (C) 2020 Freie Universität Berlin
|
|
|
|
* 2020 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
* 2013 INRIA.
|
2013-06-18 17:21:38 +02:00
|
|
|
*
|
2014-07-31 19:45:27 +02:00
|
|
|
* 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.
|
2013-06-18 17:21:38 +02:00
|
|
|
*
|
2018-06-06 10:32:32 +02:00
|
|
|
* @ingroup sys_auto_init
|
2013-06-18 17:21:38 +02:00
|
|
|
* @{
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2013-06-18 17:21:38 +02:00
|
|
|
* @brief initializes any used module that has a trivial init function
|
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
2015-04-29 21:17:07 +02:00
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
2020-02-13 11:01:01 +01:00
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
2020-03-03 17:15:13 +01:00
|
|
|
* @author Martine S. Lenders <m.lenders@fu-berlin.de>
|
2013-06-18 17:21:38 +02:00
|
|
|
* @}
|
|
|
|
*/
|
2010-09-22 15:10:42 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
2021-09-22 14:01:41 +02:00
|
|
|
#include "sched.h"
|
2013-10-27 17:23:25 +01:00
|
|
|
#include "auto_init.h"
|
2020-03-03 17:15:13 +01:00
|
|
|
#include "kernel_defines.h"
|
2020-02-13 11:39:16 +01:00
|
|
|
#include "log.h"
|
2013-10-27 17:23:25 +01:00
|
|
|
|
2020-03-03 17:15:13 +01:00
|
|
|
void auto_init(void)
|
|
|
|
{
|
2021-10-05 14:11:41 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_ZTIMER)) {
|
2018-02-01 09:53:04 +01:00
|
|
|
LOG_DEBUG("Auto init ztimer.\n");
|
|
|
|
void ztimer_init(void);
|
|
|
|
ztimer_init();
|
|
|
|
}
|
2021-12-07 11:04:17 +01:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_ZTIMER64)) {
|
|
|
|
LOG_DEBUG("Auto init ztimer64.\n");
|
|
|
|
void ztimer64_init(void);
|
|
|
|
ztimer64_init();
|
|
|
|
}
|
2019-12-10 11:04:29 +01:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_XTIMER) &&
|
2021-10-05 14:11:41 +02:00
|
|
|
!IS_USED(MODULE_ZTIMER_XTIMER_COMPAT)) {
|
2020-03-03 17:15:13 +01:00
|
|
|
LOG_DEBUG("Auto init xtimer.\n");
|
|
|
|
extern void xtimer_init(void);
|
|
|
|
xtimer_init();
|
|
|
|
}
|
2021-10-05 14:11:41 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_RANDOM)) {
|
2021-06-29 13:05:29 +02:00
|
|
|
LOG_DEBUG("Auto init random.\n");
|
|
|
|
extern void auto_init_random(void);
|
|
|
|
auto_init_random();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
if (IS_USED(MODULE_SCHEDSTATISTICS)) {
|
|
|
|
LOG_DEBUG("Auto init schedstatistics.\n");
|
|
|
|
extern void init_schedstatistics(void);
|
|
|
|
init_schedstatistics();
|
|
|
|
}
|
2021-04-15 14:57:49 +02:00
|
|
|
if (IS_USED(MODULE_SCHED_ROUND_ROBIN)) {
|
|
|
|
LOG_DEBUG("Auto init sched_round_robin.\n");
|
|
|
|
extern void sched_round_robin_init(void);
|
|
|
|
sched_round_robin_init();
|
|
|
|
}
|
2020-06-08 17:04:58 +02:00
|
|
|
if (IS_USED(MODULE_DUMMY_THREAD)) {
|
|
|
|
extern void dummy_thread_create(void);
|
|
|
|
dummy_thread_create();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
if (IS_USED(MODULE_EVENT_THREAD)) {
|
|
|
|
LOG_DEBUG("Auto init event threads.\n");
|
|
|
|
extern void auto_init_event_thread(void);
|
|
|
|
auto_init_event_thread();
|
|
|
|
}
|
2020-09-08 01:16:45 +02:00
|
|
|
if (IS_USED(MODULE_SYS_BUS)) {
|
|
|
|
LOG_DEBUG("Auto init system buses.\n");
|
|
|
|
extern void auto_init_sys_bus(void);
|
|
|
|
auto_init_sys_bus();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
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");
|
2021-09-22 14:01:41 +02:00
|
|
|
extern kernel_pid_t gnrc_ipv6_init(void);
|
2020-03-03 17:15:13 +01:00
|
|
|
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");
|
2021-09-22 14:01:41 +02:00
|
|
|
extern int gnrc_tcp_init(void);
|
2020-03-03 17:15:13 +01:00
|
|
|
gnrc_tcp_init();
|
|
|
|
}
|
|
|
|
if (IS_USED(MODULE_AUTO_INIT_LWIP)) {
|
|
|
|
LOG_DEBUG("Bootstraping lwIP.\n");
|
|
|
|
extern void lwip_bootstrap(void);
|
|
|
|
lwip_bootstrap();
|
|
|
|
}
|
2021-06-04 18:13:33 +02:00
|
|
|
if (IS_USED(MODULE_SOCK_DTLS)) {
|
|
|
|
LOG_DEBUG("Auto init sock_dtls.\n");
|
|
|
|
extern void sock_dtls_init(void);
|
|
|
|
sock_dtls_init();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
if (IS_USED(MODULE_OPENTHREAD)) {
|
|
|
|
LOG_DEBUG("Bootstrapping openthread.\n");
|
|
|
|
extern void openthread_bootstrap(void);
|
|
|
|
openthread_bootstrap();
|
|
|
|
}
|
2020-06-25 22:35:50 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_OPENWSN)) {
|
|
|
|
LOG_DEBUG("Bootstrapping openwsn.\n");
|
|
|
|
extern void openwsn_bootstrap(void);
|
|
|
|
openwsn_bootstrap();
|
|
|
|
}
|
2021-07-05 14:30:19 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_MYNEWT_CORE)) {
|
|
|
|
LOG_DEBUG("Bootstrapping mynewt-core.\n");
|
|
|
|
extern void mynewt_core_init(void);
|
|
|
|
mynewt_core_init();
|
|
|
|
}
|
2020-08-14 15:50:26 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_UWB_CORE)) {
|
|
|
|
LOG_DEBUG("Bootstrapping uwb core.\n");
|
|
|
|
extern void uwb_core_init(void);
|
|
|
|
uwb_core_init();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
if (IS_USED(MODULE_GCOAP) &&
|
|
|
|
!IS_ACTIVE(CONFIG_GCOAP_NO_AUTO_INIT)) {
|
2020-03-03 17:15:13 +01:00
|
|
|
LOG_DEBUG("Auto init gcoap.\n");
|
|
|
|
extern void gcoap_init(void);
|
|
|
|
gcoap_init();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
if (IS_USED(MODULE_DEVFS)) {
|
|
|
|
LOG_DEBUG("Mounting /dev.\n");
|
|
|
|
extern void auto_init_devfs(void);
|
|
|
|
auto_init_devfs();
|
|
|
|
}
|
2021-12-04 15:23:30 +01:00
|
|
|
if (IS_USED(MODULE_VFS_AUTO_MOUNT)) {
|
|
|
|
LOG_DEBUG("Mounting filesystems.\n");
|
|
|
|
extern void auto_init_vfs(void);
|
|
|
|
auto_init_vfs();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
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();
|
|
|
|
}
|
2021-01-28 10:20:29 +01:00
|
|
|
if (IS_USED(MODULE_DSM)) {
|
|
|
|
LOG_DEBUG("Auto init dsm.\n");
|
|
|
|
extern void dsm_init(void);
|
|
|
|
dsm_init();
|
|
|
|
}
|
2020-03-03 17:15:13 +01:00
|
|
|
|
|
|
|
/* 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");
|
2020-03-04 15:50:25 +01:00
|
|
|
extern void gnrc_netif_init_devs(void);
|
|
|
|
gnrc_netif_init_devs();
|
2020-03-03 17:15:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
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");
|
2020-03-04 15:50:52 +01:00
|
|
|
extern void saul_init_devs(void);
|
|
|
|
saul_init_devs();
|
2020-03-03 17:15:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
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();
|
|
|
|
}
|
|
|
|
|
|
|
|
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();
|
|
|
|
}
|
|
|
|
|
2020-06-19 17:17:50 +02:00
|
|
|
if (IS_USED(MODULE_MBEDTLS)) {
|
|
|
|
LOG_DEBUG("Auto init mbed TLS.\n");
|
|
|
|
extern void auto_init_mbedtls(void);
|
|
|
|
auto_init_mbedtls();
|
|
|
|
}
|
|
|
|
|
2020-03-03 17:15:13 +01:00
|
|
|
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();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-11 09:59:22 +01:00
|
|
|
if (IS_USED(MODULE_TEST_UTILS_INTERACTIVE_SYNC) && !IS_USED(MODULE_SHELL)) {
|
2020-03-03 17:15:13 +01:00
|
|
|
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();
|
|
|
|
}
|
|
|
|
|
2021-07-02 17:47:01 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_DHCPV6_RELAY)) {
|
|
|
|
LOG_DEBUG("Auto init DHCPv6 relay agent.\n");
|
|
|
|
extern void dhcpv6_relay_auto_init(void);
|
|
|
|
dhcpv6_relay_auto_init();
|
|
|
|
}
|
|
|
|
|
2021-06-05 23:07:38 +02:00
|
|
|
if (IS_USED(MODULE_GNRC_DHCPV6_CLIENT_SIMPLE_PD)) {
|
|
|
|
LOG_DEBUG("Auto init DHCPv6 client for simple prefix delegation\n");
|
|
|
|
extern void gnrc_dhcpv6_client_simple_pd_init(void);
|
|
|
|
gnrc_dhcpv6_client_simple_pd_init();
|
2020-03-03 17:15:13 +01:00
|
|
|
}
|
2019-08-20 14:46:44 +02:00
|
|
|
|
2021-08-12 18:42:44 +02:00
|
|
|
if (IS_USED(MODULE_GNRC_IPV6_AUTO_SUBNETS_AUTO_INIT)) {
|
|
|
|
extern void gnrc_ipv6_auto_subnets_init(void);
|
|
|
|
gnrc_ipv6_auto_subnets_init();
|
|
|
|
}
|
|
|
|
|
2021-08-10 17:37:22 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_TELNET)) {
|
|
|
|
LOG_DEBUG("auto_init TELNET server\n");
|
|
|
|
extern void telnet_server_start(void);
|
|
|
|
telnet_server_start();
|
|
|
|
}
|
|
|
|
|
2019-08-20 14:46:44 +02:00
|
|
|
if (IS_USED(MODULE_AUTO_INIT_MULTIMEDIA)) {
|
|
|
|
LOG_DEBUG("auto_init MULTIMEDIA\n");
|
2019-08-29 11:20:56 +02:00
|
|
|
if (IS_USED(MODULE_DFPLAYER)) {
|
|
|
|
extern void auto_init_dfplayer(void);
|
|
|
|
auto_init_dfplayer();
|
|
|
|
}
|
2019-08-20 14:46:44 +02:00
|
|
|
}
|
2020-06-21 18:26:14 +02:00
|
|
|
|
|
|
|
if (IS_USED(MODULE_AUTO_INIT_SCREEN)) {
|
|
|
|
LOG_DEBUG("Auto init screen devices\n");
|
|
|
|
extern void auto_init_screen(void);
|
|
|
|
auto_init_screen();
|
|
|
|
}
|
2021-08-04 16:04:54 +02:00
|
|
|
|
|
|
|
if (IS_USED(MODULE_AUTO_INIT_BENCHMARK_UDP)) {
|
|
|
|
LOG_DEBUG("Auto init UDP benchmark\n");
|
|
|
|
extern void benchmark_udp_auto_init(void);
|
|
|
|
benchmark_udp_auto_init();
|
|
|
|
}
|
2022-01-01 23:39:04 +01:00
|
|
|
|
|
|
|
if (IS_USED(MODULE_AUTO_INIT_SOCK_DNS)) {
|
|
|
|
LOG_DEBUG("Auto init sock_dns.\n");
|
|
|
|
extern void auto_init_sock_dns(void);
|
|
|
|
auto_init_sock_dns();
|
|
|
|
}
|
2010-09-22 15:10:42 +02:00
|
|
|
}
|