blob: 5d6286877e3b22042509ff84c97c07243ff04720 [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"
John Park398c74a2018-10-20 21:17:39 -070017#include "aos/ipc_lib/shared_mem.h"
Alex Perrycb7da4b2019-08-28 19:35:56 -070018#include "aos/logging/implementations.h"
19#include "aos/realtime.h"
brians343bc112013-02-10 01:53:46 +000020
Brian Silverman40486622014-12-30 17:38:55 -080021namespace FLAG__namespace_do_not_use_directly_use_DECLARE_double_instead {
Brian Silverman26438442015-10-11 19:36:47 -040022extern double FLAGS_tcmalloc_release_rate __attribute__((weak));
Brian Silverman40486622014-12-30 17:38:55 -080023}
24using FLAG__namespace_do_not_use_directly_use_DECLARE_double_instead::
25 FLAGS_tcmalloc_release_rate;
Brian Silverman40486622014-12-30 17:38:55 -080026
brians343bc112013-02-10 01:53:46 +000027namespace aos {
Brian Silverman2fe007c2014-12-28 12:20:01 -080028namespace logging {
29namespace internal {
brians343bc112013-02-10 01:53:46 +000030
John Park33858a32018-09-28 23:05:48 -070031// Implemented in aos/logging/context.cc.
Brian Silverman2fe007c2014-12-28 12:20:01 -080032void ReloadThreadName();
33
34} // namespace internal
35} // namespace logging
brians343bc112013-02-10 01:53:46 +000036namespace {
37
brians343bc112013-02-10 01:53:46 +000038// Common stuff that needs to happen at the beginning of both the realtime and
39// non-realtime initialization sequences. May be called twice.
40void InitStart() {
Brian Silvermanff485782014-06-18 19:59:09 -070041 ::aos::logging::Init();
Brian Silvermanfe1ef172014-04-12 17:12:45 -070042 WriteCoreDumps();
Austin Schuhe8bfc552019-12-03 23:48:23 -080043 google::InstallFailureSignalHandler();
brians343bc112013-02-10 01:53:46 +000044}
45
Austin Schuh3d4d5df2015-10-17 15:51:41 -070046const char *const kNoRealtimeEnvironmentVariable = "AOS_NO_REALTIME";
47
Brian Silverman8f8debf2018-03-11 19:30:23 -070048bool ShouldBeRealtime() {
49 return getenv(kNoRealtimeEnvironmentVariable) == nullptr;
50}
51
Austin Schuh3d4d5df2015-10-17 15:51:41 -070052} // namespace
53
Alex Perrycb7da4b2019-08-28 19:35:56 -070054void InitGoogle(int *argc, char ***argv) {
55 FLAGS_logtostderr = true;
56 google::InitGoogleLogging((*argv)[0]);
57 gflags::ParseCommandLineFlags(argc, argv, true);
58 google::InstallFailureSignalHandler();
brians343bc112013-02-10 01:53:46 +000059}
60
James Kuszmaulad8a8082020-02-14 21:21:58 -080061void InitNRT() {
Brian Silverman8a6dac92015-02-21 20:08:24 -050062 InitStart();
James Kuszmaulb4874eb2020-01-18 17:50:35 -080063 ExpandStackSize();
Brian Silverman8a6dac92015-02-21 20:08:24 -050064}
65
66void InitCreate() {
67 InitStart();
Austin Schuhf257f3c2019-10-27 21:00:43 -070068 AOS_LOG(INFO, "%s created shm\n", program_invocation_short_name);
Brian Silverman8a6dac92015-02-21 20:08:24 -050069}
70
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070071void Init(int relative_priority) {
Brian Silverman8f8debf2018-03-11 19:30:23 -070072 InitStart();
Brian Silverman8f8debf2018-03-11 19:30:23 -070073 GoRT(relative_priority);
74}
75
76void GoRT(int relative_priority) {
77 if (ShouldBeRealtime()) {
Austin Schuh9fe68f72019-08-10 19:32:03 -070078 InitRT();
Brian Silverman6da04272014-05-18 18:47:48 -070079
80 // Set our process to the appropriate priority.
brians343bc112013-02-10 01:53:46 +000081 struct sched_param param;
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070082 param.sched_priority = 30 + relative_priority;
brians343bc112013-02-10 01:53:46 +000083 if (sched_setscheduler(0, SCHED_FIFO, &param) != 0) {
Brian Silverman01be0002014-05-10 15:44:38 -070084 PDie("%s-init: setting SCHED_FIFO failed", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +000085 }
86 } else {
Austin Schuh9fe68f72019-08-10 19:32:03 -070087 fprintf(stderr,
88 "%s not doing realtime initialization because environment"
89 " variable %s is set\n",
90 program_invocation_short_name, kNoRealtimeEnvironmentVariable);
brians343bc112013-02-10 01:53:46 +000091 printf("no realtime for %s. see stderr\n", program_invocation_short_name);
92 }
93
Austin Schuhf257f3c2019-10-27 21:00:43 -070094 AOS_LOG(INFO, "%s initialized realtime\n", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +000095}
96
97void Cleanup() {
Brian Silverman01be0002014-05-10 15:44:38 -070098 aos_core_free_shared_mem();
brians343bc112013-02-10 01:53:46 +000099}
100
Brian Silvermane4d8b282015-12-24 13:44:48 -0800101void PinCurrentThreadToCPU(int number) {
102 cpu_set_t cpuset;
103 CPU_ZERO(&cpuset);
104 CPU_SET(number, &cpuset);
Austin Schuhf257f3c2019-10-27 21:00:43 -0700105 AOS_PRCHECK(pthread_setaffinity_np(pthread_self(), sizeof(cpuset), &cpuset));
Brian Silvermane4d8b282015-12-24 13:44:48 -0800106}
107
brians343bc112013-02-10 01:53:46 +0000108} // namespace aos