xref: /aosp_15_r20/system/chre/platform/freertos/init.cc (revision 84e339476a462649f82315436d70fd732297a399)
1*84e33947SAndroid Build Coastguard Worker /*
2*84e33947SAndroid Build Coastguard Worker  * Copyright (C) 2020 The Android Open Source Project
3*84e33947SAndroid Build Coastguard Worker  *
4*84e33947SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*84e33947SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*84e33947SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*84e33947SAndroid Build Coastguard Worker  *
8*84e33947SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*84e33947SAndroid Build Coastguard Worker  *
10*84e33947SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*84e33947SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*84e33947SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*84e33947SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*84e33947SAndroid Build Coastguard Worker  * limitations under the License.
15*84e33947SAndroid Build Coastguard Worker  */
16*84e33947SAndroid Build Coastguard Worker 
17*84e33947SAndroid Build Coastguard Worker #include "chre/core/init.h"
18*84e33947SAndroid Build Coastguard Worker 
19*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_ENABLE_CHPP
20*84e33947SAndroid Build Coastguard Worker #include "chpp/platform/chpp_init.h"
21*84e33947SAndroid Build Coastguard Worker #endif
22*84e33947SAndroid Build Coastguard Worker #include "chre/core/event_loop_manager.h"
23*84e33947SAndroid Build Coastguard Worker #include "chre/core/static_nanoapps.h"
24*84e33947SAndroid Build Coastguard Worker #include "chre/platform/shared/dram_vote_client.h"
25*84e33947SAndroid Build Coastguard Worker #include "chre/target_platform/init.h"
26*84e33947SAndroid Build Coastguard Worker 
27*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_USE_BUFFERED_LOGGING
28*84e33947SAndroid Build Coastguard Worker #include "chre/platform/shared/log_buffer_manager.h"
29*84e33947SAndroid Build Coastguard Worker #include "chre/target_platform/macros.h"
30*84e33947SAndroid Build Coastguard Worker #endif
31*84e33947SAndroid Build Coastguard Worker 
32*84e33947SAndroid Build Coastguard Worker #include "task.h"
33*84e33947SAndroid Build Coastguard Worker 
34*84e33947SAndroid Build Coastguard Worker namespace chre {
35*84e33947SAndroid Build Coastguard Worker namespace freertos {
36*84e33947SAndroid Build Coastguard Worker namespace {
37*84e33947SAndroid Build Coastguard Worker 
38*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_FREERTOS_TASK_PRIORITY
39*84e33947SAndroid Build Coastguard Worker constexpr UBaseType_t kChreTaskPriority =
40*84e33947SAndroid Build Coastguard Worker     tskIDLE_PRIORITY + CHRE_FREERTOS_TASK_PRIORITY;
41*84e33947SAndroid Build Coastguard Worker #else
42*84e33947SAndroid Build Coastguard Worker constexpr UBaseType_t kChreTaskPriority = tskIDLE_PRIORITY + 1;
43*84e33947SAndroid Build Coastguard Worker #endif
44*84e33947SAndroid Build Coastguard Worker 
45*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_FREERTOS_STACK_DEPTH_IN_WORDS
46*84e33947SAndroid Build Coastguard Worker constexpr configSTACK_DEPTH_TYPE kChreTaskStackDepthWords =
47*84e33947SAndroid Build Coastguard Worker     CHRE_FREERTOS_STACK_DEPTH_IN_WORDS;
48*84e33947SAndroid Build Coastguard Worker #else
49*84e33947SAndroid Build Coastguard Worker constexpr configSTACK_DEPTH_TYPE kChreTaskStackDepthWords = 0x800;
50*84e33947SAndroid Build Coastguard Worker #endif
51*84e33947SAndroid Build Coastguard Worker 
52*84e33947SAndroid Build Coastguard Worker TaskHandle_t gChreTaskHandle;
53*84e33947SAndroid Build Coastguard Worker 
54*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_USE_BUFFERED_LOGGING
55*84e33947SAndroid Build Coastguard Worker 
56*84e33947SAndroid Build Coastguard Worker TaskHandle_t gChreFlushTaskHandle;
57*84e33947SAndroid Build Coastguard Worker 
58*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_HIGH_POWER_TEXT_ATTRIBUTE
59*84e33947SAndroid Build Coastguard Worker CHRE_HIGH_POWER_TEXT_ATTRIBUTE
60*84e33947SAndroid Build Coastguard Worker #endif
61*84e33947SAndroid Build Coastguard Worker uint8_t gSecondaryLogBufferData[CHRE_LOG_BUFFER_DATA_SIZE];
62*84e33947SAndroid Build Coastguard Worker 
63*84e33947SAndroid Build Coastguard Worker uint8_t gPrimaryLogBufferData[CHRE_LOG_BUFFER_DATA_SIZE];
64*84e33947SAndroid Build Coastguard Worker 
65*84e33947SAndroid Build Coastguard Worker #endif
66*84e33947SAndroid Build Coastguard Worker 
67*84e33947SAndroid Build Coastguard Worker // This function is intended to be the task action function for FreeRTOS.
68*84e33947SAndroid Build Coastguard Worker // It Initializes CHRE, runs the event loop, and only exits if it receives
69*84e33947SAndroid Build Coastguard Worker // a message to shutdown. Note that depending on the hardware platform this
70*84e33947SAndroid Build Coastguard Worker // runs on, CHRE might create additional threads, which are cleaned up when
71*84e33947SAndroid Build Coastguard Worker // CHRE exits.
chreThreadEntry(void * context)72*84e33947SAndroid Build Coastguard Worker void chreThreadEntry(void *context) {
73*84e33947SAndroid Build Coastguard Worker   UNUSED_VAR(context);
74*84e33947SAndroid Build Coastguard Worker 
75*84e33947SAndroid Build Coastguard Worker   chre::init();
76*84e33947SAndroid Build Coastguard Worker   chre::EventLoopManagerSingleton::get()->lateInit();
77*84e33947SAndroid Build Coastguard Worker   chre::loadStaticNanoapps();
78*84e33947SAndroid Build Coastguard Worker 
79*84e33947SAndroid Build Coastguard Worker   chre::EventLoopManagerSingleton::get()->getEventLoop().run();
80*84e33947SAndroid Build Coastguard Worker 
81*84e33947SAndroid Build Coastguard Worker   // we only get here if the CHRE EventLoop exited
82*84e33947SAndroid Build Coastguard Worker   chre::deinit();
83*84e33947SAndroid Build Coastguard Worker 
84*84e33947SAndroid Build Coastguard Worker   DramVoteClientSingleton::deinit();
85*84e33947SAndroid Build Coastguard Worker 
86*84e33947SAndroid Build Coastguard Worker   vTaskDelete(nullptr);
87*84e33947SAndroid Build Coastguard Worker   gChreTaskHandle = nullptr;
88*84e33947SAndroid Build Coastguard Worker }
89*84e33947SAndroid Build Coastguard Worker 
90*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_USE_BUFFERED_LOGGING
chreFlushLogsToHostThreadEntry(void * context)91*84e33947SAndroid Build Coastguard Worker void chreFlushLogsToHostThreadEntry(void *context) {
92*84e33947SAndroid Build Coastguard Worker   UNUSED_VAR(context);
93*84e33947SAndroid Build Coastguard Worker 
94*84e33947SAndroid Build Coastguard Worker   // Never exits
95*84e33947SAndroid Build Coastguard Worker   chre::LogBufferManagerSingleton::get()->startSendLogsToHostLoop();
96*84e33947SAndroid Build Coastguard Worker }
97*84e33947SAndroid Build Coastguard Worker #endif
98*84e33947SAndroid Build Coastguard Worker 
99*84e33947SAndroid Build Coastguard Worker }  // namespace
100*84e33947SAndroid Build Coastguard Worker 
101*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_USE_BUFFERED_LOGGING
102*84e33947SAndroid Build Coastguard Worker const char *getChreFlushTaskName();
103*84e33947SAndroid Build Coastguard Worker #endif
104*84e33947SAndroid Build Coastguard Worker 
init()105*84e33947SAndroid Build Coastguard Worker BaseType_t init() {
106*84e33947SAndroid Build Coastguard Worker   BaseType_t rc =
107*84e33947SAndroid Build Coastguard Worker       xTaskCreate(chreThreadEntry, getChreTaskName(), kChreTaskStackDepthWords,
108*84e33947SAndroid Build Coastguard Worker                   nullptr /* args */, kChreTaskPriority, &gChreTaskHandle);
109*84e33947SAndroid Build Coastguard Worker   CHRE_ASSERT(rc == pdPASS);
110*84e33947SAndroid Build Coastguard Worker 
111*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_ENABLE_CHPP
112*84e33947SAndroid Build Coastguard Worker   chpp::init();
113*84e33947SAndroid Build Coastguard Worker #endif
114*84e33947SAndroid Build Coastguard Worker 
115*84e33947SAndroid Build Coastguard Worker   return rc;
116*84e33947SAndroid Build Coastguard Worker }
117*84e33947SAndroid Build Coastguard Worker 
initLogger()118*84e33947SAndroid Build Coastguard Worker BaseType_t initLogger() {
119*84e33947SAndroid Build Coastguard Worker   BaseType_t rc = pdPASS;
120*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_USE_BUFFERED_LOGGING
121*84e33947SAndroid Build Coastguard Worker   if (!chre::LogBufferManagerSingleton::isInitialized()) {
122*84e33947SAndroid Build Coastguard Worker     chre::LogBufferManagerSingleton::init(gPrimaryLogBufferData,
123*84e33947SAndroid Build Coastguard Worker                                           gSecondaryLogBufferData,
124*84e33947SAndroid Build Coastguard Worker                                           sizeof(gPrimaryLogBufferData));
125*84e33947SAndroid Build Coastguard Worker 
126*84e33947SAndroid Build Coastguard Worker     rc = xTaskCreate(chreFlushLogsToHostThreadEntry, getChreFlushTaskName(),
127*84e33947SAndroid Build Coastguard Worker                      kChreTaskStackDepthWords, nullptr /* args */,
128*84e33947SAndroid Build Coastguard Worker                      kChreTaskPriority, &gChreFlushTaskHandle);
129*84e33947SAndroid Build Coastguard Worker   }
130*84e33947SAndroid Build Coastguard Worker #endif
131*84e33947SAndroid Build Coastguard Worker   return rc;
132*84e33947SAndroid Build Coastguard Worker }
133*84e33947SAndroid Build Coastguard Worker 
deinit()134*84e33947SAndroid Build Coastguard Worker void deinit() {
135*84e33947SAndroid Build Coastguard Worker   // On a deinit call, we just stop the CHRE event loop. This causes the 'run'
136*84e33947SAndroid Build Coastguard Worker   // method in the task function exit, and move on to handle task cleanup
137*84e33947SAndroid Build Coastguard Worker   if (gChreTaskHandle != nullptr) {
138*84e33947SAndroid Build Coastguard Worker     chre::EventLoopManagerSingleton::get()->getEventLoop().stop();
139*84e33947SAndroid Build Coastguard Worker   }
140*84e33947SAndroid Build Coastguard Worker 
141*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_ENABLE_CHPP
142*84e33947SAndroid Build Coastguard Worker   chpp::deinit();
143*84e33947SAndroid Build Coastguard Worker #endif
144*84e33947SAndroid Build Coastguard Worker }
145*84e33947SAndroid Build Coastguard Worker 
getChreTaskName()146*84e33947SAndroid Build Coastguard Worker const char *getChreTaskName() {
147*84e33947SAndroid Build Coastguard Worker   static constexpr char kChreTaskName[] = "CHRE";
148*84e33947SAndroid Build Coastguard Worker   return kChreTaskName;
149*84e33947SAndroid Build Coastguard Worker }
150*84e33947SAndroid Build Coastguard Worker 
151*84e33947SAndroid Build Coastguard Worker #ifdef CHRE_USE_BUFFERED_LOGGING
getChreFlushTaskName()152*84e33947SAndroid Build Coastguard Worker const char *getChreFlushTaskName() {
153*84e33947SAndroid Build Coastguard Worker   static constexpr char kChreFlushTaskName[] = "CHRELogs";
154*84e33947SAndroid Build Coastguard Worker   return kChreFlushTaskName;
155*84e33947SAndroid Build Coastguard Worker }
156*84e33947SAndroid Build Coastguard Worker #endif
157*84e33947SAndroid Build Coastguard Worker 
158*84e33947SAndroid Build Coastguard Worker }  // namespace freertos
159*84e33947SAndroid Build Coastguard Worker 
getChreTaskPriority()160*84e33947SAndroid Build Coastguard Worker BaseType_t getChreTaskPriority() {
161*84e33947SAndroid Build Coastguard Worker   return freertos::kChreTaskPriority;
162*84e33947SAndroid Build Coastguard Worker }
163*84e33947SAndroid Build Coastguard Worker 
164*84e33947SAndroid Build Coastguard Worker }  // namespace chre
165