blob: c40f22c97dd97803fd7773a2d68e1f1c17314989 [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
Austin Schuh707c8352020-03-15 14:27:25 -070027DEFINE_bool(coredump, false, "If true, write core dumps on failure.");
28
brians343bc112013-02-10 01:53:46 +000029namespace aos {
Brian Silverman2fe007c2014-12-28 12:20:01 -080030namespace logging {
31namespace internal {
brians343bc112013-02-10 01:53:46 +000032
John Park33858a32018-09-28 23:05:48 -070033// Implemented in aos/logging/context.cc.
Brian Silverman2fe007c2014-12-28 12:20:01 -080034void ReloadThreadName();
35
36} // namespace internal
37} // namespace logging
brians343bc112013-02-10 01:53:46 +000038namespace {
39
brians343bc112013-02-10 01:53:46 +000040// Common stuff that needs to happen at the beginning of both the realtime and
41// non-realtime initialization sequences. May be called twice.
42void InitStart() {
Brian Silvermanff485782014-06-18 19:59:09 -070043 ::aos::logging::Init();
Austin Schuh707c8352020-03-15 14:27:25 -070044 if (FLAGS_coredump) {
45 WriteCoreDumps();
46 }
Austin Schuhe8bfc552019-12-03 23:48:23 -080047 google::InstallFailureSignalHandler();
brians343bc112013-02-10 01:53:46 +000048}
49
Austin Schuh3d4d5df2015-10-17 15:51:41 -070050const char *const kNoRealtimeEnvironmentVariable = "AOS_NO_REALTIME";
51
Brian Silverman8f8debf2018-03-11 19:30:23 -070052bool ShouldBeRealtime() {
53 return getenv(kNoRealtimeEnvironmentVariable) == nullptr;
54}
55
Austin Schuh3d4d5df2015-10-17 15:51:41 -070056} // namespace
57
Alex Perrycb7da4b2019-08-28 19:35:56 -070058void InitGoogle(int *argc, char ***argv) {
59 FLAGS_logtostderr = true;
60 google::InitGoogleLogging((*argv)[0]);
61 gflags::ParseCommandLineFlags(argc, argv, true);
62 google::InstallFailureSignalHandler();
brians343bc112013-02-10 01:53:46 +000063}
64
James Kuszmaulad8a8082020-02-14 21:21:58 -080065void InitNRT() {
Brian Silverman8a6dac92015-02-21 20:08:24 -050066 InitStart();
James Kuszmaulb4874eb2020-01-18 17:50:35 -080067 ExpandStackSize();
Brian Silverman8a6dac92015-02-21 20:08:24 -050068}
69
70void InitCreate() {
71 InitStart();
Austin Schuhf257f3c2019-10-27 21:00:43 -070072 AOS_LOG(INFO, "%s created shm\n", program_invocation_short_name);
Brian Silverman8a6dac92015-02-21 20:08:24 -050073}
74
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070075void Init(int relative_priority) {
Brian Silverman8f8debf2018-03-11 19:30:23 -070076 InitStart();
Brian Silverman8f8debf2018-03-11 19:30:23 -070077 GoRT(relative_priority);
78}
79
80void GoRT(int relative_priority) {
81 if (ShouldBeRealtime()) {
Austin Schuh9fe68f72019-08-10 19:32:03 -070082 InitRT();
Brian Silverman6da04272014-05-18 18:47:48 -070083
84 // Set our process to the appropriate priority.
brians343bc112013-02-10 01:53:46 +000085 struct sched_param param;
Brian Silvermanf3cfbd72013-10-28 16:26:09 -070086 param.sched_priority = 30 + relative_priority;
brians343bc112013-02-10 01:53:46 +000087 if (sched_setscheduler(0, SCHED_FIFO, &param) != 0) {
Brian Silverman01be0002014-05-10 15:44:38 -070088 PDie("%s-init: setting SCHED_FIFO failed", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +000089 }
90 } else {
Austin Schuh9fe68f72019-08-10 19:32:03 -070091 fprintf(stderr,
92 "%s not doing realtime initialization because environment"
93 " variable %s is set\n",
94 program_invocation_short_name, kNoRealtimeEnvironmentVariable);
brians343bc112013-02-10 01:53:46 +000095 printf("no realtime for %s. see stderr\n", program_invocation_short_name);
96 }
97
Austin Schuhf257f3c2019-10-27 21:00:43 -070098 AOS_LOG(INFO, "%s initialized realtime\n", program_invocation_short_name);
brians343bc112013-02-10 01:53:46 +000099}
100
101void Cleanup() {
Brian Silverman01be0002014-05-10 15:44:38 -0700102 aos_core_free_shared_mem();
brians343bc112013-02-10 01:53:46 +0000103}
104
Brian Silvermane4d8b282015-12-24 13:44:48 -0800105void PinCurrentThreadToCPU(int number) {
106 cpu_set_t cpuset;
107 CPU_ZERO(&cpuset);
108 CPU_SET(number, &cpuset);
Austin Schuhf257f3c2019-10-27 21:00:43 -0700109 AOS_PRCHECK(pthread_setaffinity_np(pthread_self(), sizeof(cpuset), &cpuset));
Brian Silvermane4d8b282015-12-24 13:44:48 -0800110}
111
brians343bc112013-02-10 01:53:46 +0000112} // namespace aos