blob: 71eeabdf574aff5320d1b6f64cf00d1be1ed11ac [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 Schuh62288252020-11-18 23:26:04 -080042 RegisterMallocHook();
Austin Schuh707c8352020-03-15 14:27:25 -070043 if (FLAGS_coredump) {
44 WriteCoreDumps();
45 }
Austin Schuhe8bfc552019-12-03 23:48:23 -080046 google::InstallFailureSignalHandler();
brians343bc112013-02-10 01:53:46 +000047}
48
Austin Schuh3d4d5df2015-10-17 15:51:41 -070049const char *const kNoRealtimeEnvironmentVariable = "AOS_NO_REALTIME";
50
Brian Silverman8f8debf2018-03-11 19:30:23 -070051bool ShouldBeRealtime() {
52 return getenv(kNoRealtimeEnvironmentVariable) == nullptr;
53}
54
Austin Schuh3d4d5df2015-10-17 15:51:41 -070055} // namespace
56
Alex Perrycb7da4b2019-08-28 19:35:56 -070057void InitGoogle(int *argc, char ***argv) {
58 FLAGS_logtostderr = true;
59 google::InitGoogleLogging((*argv)[0]);
60 gflags::ParseCommandLineFlags(argc, argv, true);
61 google::InstallFailureSignalHandler();
Austin Schuh62288252020-11-18 23:26:04 -080062
63 RegisterMallocHook();
brians343bc112013-02-10 01:53:46 +000064}
65
James Kuszmaulad8a8082020-02-14 21:21:58 -080066void InitNRT() {
Brian Silverman8a6dac92015-02-21 20:08:24 -050067 InitStart();
James Kuszmaulb4874eb2020-01-18 17:50:35 -080068 ExpandStackSize();
Brian Silverman8a6dac92015-02-21 20:08:24 -050069}
70
71void InitCreate() {
72 InitStart();
Austin Schuhf257f3c2019-10-27 21:00:43 -070073 AOS_LOG(INFO, "%s created shm\n", program_invocation_short_name);
Brian Silverman8a6dac92015-02-21 20:08:24 -050074}
75
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070076void Init(int relative_priority) {
Brian Silverman8f8debf2018-03-11 19:30:23 -070077 InitStart();
Brian Silverman8f8debf2018-03-11 19:30:23 -070078 GoRT(relative_priority);
79}
80
81void GoRT(int relative_priority) {
82 if (ShouldBeRealtime()) {
Austin Schuh9fe68f72019-08-10 19:32:03 -070083 InitRT();
Brian Silverman6da04272014-05-18 18:47:48 -070084
85 // Set our process to the appropriate priority.
brians343bc112013-02-10 01:53:46 +000086 struct sched_param param;
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070087 param.sched_priority = 30 + relative_priority;
brians343bc112013-02-10 01:53:46 +000088 if (sched_setscheduler(0, SCHED_FIFO, &param) != 0) {
Brian Silverman01be0002014-05-10 15:44:38 -070089 PDie("%s-init: setting SCHED_FIFO failed", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +000090 }
91 } else {
Austin Schuh9fe68f72019-08-10 19:32:03 -070092 fprintf(stderr,
93 "%s not doing realtime initialization because environment"
94 " variable %s is set\n",
95 program_invocation_short_name, kNoRealtimeEnvironmentVariable);
brians343bc112013-02-10 01:53:46 +000096 printf("no realtime for %s. see stderr\n", program_invocation_short_name);
97 }
98
Austin Schuhf257f3c2019-10-27 21:00:43 -070099 AOS_LOG(INFO, "%s initialized realtime\n", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +0000100}
101
Brian Silvermane4d8b282015-12-24 13:44:48 -0800102void PinCurrentThreadToCPU(int number) {
103 cpu_set_t cpuset;
104 CPU_ZERO(&cpuset);
105 CPU_SET(number, &cpuset);
Austin Schuhf257f3c2019-10-27 21:00:43 -0700106 AOS_PRCHECK(pthread_setaffinity_np(pthread_self(), sizeof(cpuset), &cpuset));
Brian Silvermane4d8b282015-12-24 13:44:48 -0800107}
108
brians343bc112013-02-10 01:53:46 +0000109} // namespace aos