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