blob: 51e22cf154a4a6111acb9875f499d3d87289046d [file] [log] [blame]
John Park398c74a2018-10-20 21:17:39 -07001#include "aos/init.h"
brians343bc112013-02-10 01:53:46 +00002
3#include <stdio.h>
4#include <string.h>
5#include <sys/mman.h>
6#include <errno.h>
7#include <sched.h>
8#include <sys/resource.h>
brians343bc112013-02-10 01:53:46 +00009#include <sys/types.h>
10#include <unistd.h>
11#include <stdlib.h>
12#include <stdint.h>
Brian Silverman2fe007c2014-12-28 12:20:01 -080013#include <sys/prctl.h>
Brian Silverman40486622014-12-30 17:38:55 -080014#include <malloc.h>
brians343bc112013-02-10 01:53:46 +000015
John Park33858a32018-09-28 23:05:48 -070016#include "aos/die.h"
Alex Perrycb7da4b2019-08-28 19:35:56 -070017#include "aos/logging/implementations.h"
18#include "aos/realtime.h"
brians343bc112013-02-10 01:53:46 +000019
Brian Silverman40486622014-12-30 17:38:55 -080020namespace FLAG__namespace_do_not_use_directly_use_DECLARE_double_instead {
Brian Silverman26438442015-10-11 19:36:47 -040021extern double FLAGS_tcmalloc_release_rate __attribute__((weak));
Brian Silverman40486622014-12-30 17:38:55 -080022}
23using FLAG__namespace_do_not_use_directly_use_DECLARE_double_instead::
24 FLAGS_tcmalloc_release_rate;
Brian Silverman40486622014-12-30 17:38:55 -080025
Austin Schuh707c8352020-03-15 14:27:25 -070026DEFINE_bool(coredump, false, "If true, write core dumps on failure.");
27
brians343bc112013-02-10 01:53:46 +000028namespace aos {
Brian Silverman2fe007c2014-12-28 12:20:01 -080029namespace logging {
30namespace internal {
brians343bc112013-02-10 01:53:46 +000031
John Park33858a32018-09-28 23:05:48 -070032// Implemented in aos/logging/context.cc.
Brian Silverman2fe007c2014-12-28 12:20:01 -080033void ReloadThreadName();
34
35} // namespace internal
36} // namespace logging
brians343bc112013-02-10 01:53:46 +000037namespace {
38
brians343bc112013-02-10 01:53:46 +000039// Common stuff that needs to happen at the beginning of both the realtime and
40// non-realtime initialization sequences. May be called twice.
41void InitStart() {
Austin Schuh707c8352020-03-15 14:27:25 -070042 if (FLAGS_coredump) {
43 WriteCoreDumps();
44 }
Austin Schuhe8bfc552019-12-03 23:48:23 -080045 google::InstallFailureSignalHandler();
brians343bc112013-02-10 01:53:46 +000046}
47
Austin Schuh3d4d5df2015-10-17 15:51:41 -070048const char *const kNoRealtimeEnvironmentVariable = "AOS_NO_REALTIME";
49
Brian Silverman8f8debf2018-03-11 19:30:23 -070050bool ShouldBeRealtime() {
51 return getenv(kNoRealtimeEnvironmentVariable) == nullptr;
52}
53
Austin Schuh3d4d5df2015-10-17 15:51:41 -070054} // namespace
55
Alex Perrycb7da4b2019-08-28 19:35:56 -070056void InitGoogle(int *argc, char ***argv) {
57 FLAGS_logtostderr = true;
58 google::InitGoogleLogging((*argv)[0]);
59 gflags::ParseCommandLineFlags(argc, argv, true);
60 google::InstallFailureSignalHandler();
brians343bc112013-02-10 01:53:46 +000061}
62
James Kuszmaulad8a8082020-02-14 21:21:58 -080063void InitNRT() {
Brian Silverman8a6dac92015-02-21 20:08:24 -050064 InitStart();
James Kuszmaulb4874eb2020-01-18 17:50:35 -080065 ExpandStackSize();
Brian Silverman8a6dac92015-02-21 20:08:24 -050066}
67
68void InitCreate() {
69 InitStart();
Austin Schuhf257f3c2019-10-27 21:00:43 -070070 AOS_LOG(INFO, "%s created shm\n", program_invocation_short_name);
Brian Silverman8a6dac92015-02-21 20:08:24 -050071}
72
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070073void Init(int relative_priority) {
Brian Silverman8f8debf2018-03-11 19:30:23 -070074 InitStart();
Brian Silverman8f8debf2018-03-11 19:30:23 -070075 GoRT(relative_priority);
76}
77
78void GoRT(int relative_priority) {
79 if (ShouldBeRealtime()) {
Austin Schuh9fe68f72019-08-10 19:32:03 -070080 InitRT();
Brian Silverman6da04272014-05-18 18:47:48 -070081
82 // Set our process to the appropriate priority.
brians343bc112013-02-10 01:53:46 +000083 struct sched_param param;
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070084 param.sched_priority = 30 + relative_priority;
brians343bc112013-02-10 01:53:46 +000085 if (sched_setscheduler(0, SCHED_FIFO, &param) != 0) {
Brian Silverman01be0002014-05-10 15:44:38 -070086 PDie("%s-init: setting SCHED_FIFO failed", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +000087 }
88 } else {
Austin Schuh9fe68f72019-08-10 19:32:03 -070089 fprintf(stderr,
90 "%s not doing realtime initialization because environment"
91 " variable %s is set\n",
92 program_invocation_short_name, kNoRealtimeEnvironmentVariable);
brians343bc112013-02-10 01:53:46 +000093 printf("no realtime for %s. see stderr\n", program_invocation_short_name);
94 }
95
Austin Schuhf257f3c2019-10-27 21:00:43 -070096 AOS_LOG(INFO, "%s initialized realtime\n", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +000097}
98
Brian Silvermane4d8b282015-12-24 13:44:48 -080099void PinCurrentThreadToCPU(int number) {
100 cpu_set_t cpuset;
101 CPU_ZERO(&cpuset);
102 CPU_SET(number, &cpuset);
Austin Schuhf257f3c2019-10-27 21:00:43 -0700103 AOS_PRCHECK(pthread_setaffinity_np(pthread_self(), sizeof(cpuset), &cpuset));
Brian Silvermane4d8b282015-12-24 13:44:48 -0800104}
105
brians343bc112013-02-10 01:53:46 +0000106} // namespace aos