1*61c4878aSAndroid Build Coastguard Worker // Copyright 2021 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker //
3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker // the License at
6*61c4878aSAndroid Build Coastguard Worker //
7*61c4878aSAndroid Build Coastguard Worker // https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker //
9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker // the License.
14*61c4878aSAndroid Build Coastguard Worker
15*61c4878aSAndroid Build Coastguard Worker #include "FreeRTOS.h"
16*61c4878aSAndroid Build Coastguard Worker #include "pw_system/config.h"
17*61c4878aSAndroid Build Coastguard Worker #include "pw_thread/detached_thread.h"
18*61c4878aSAndroid Build Coastguard Worker #include "pw_thread/thread.h"
19*61c4878aSAndroid Build Coastguard Worker #include "pw_thread_freertos/context.h"
20*61c4878aSAndroid Build Coastguard Worker #include "pw_thread_freertos/options.h"
21*61c4878aSAndroid Build Coastguard Worker
22*61c4878aSAndroid Build Coastguard Worker namespace pw::system {
23*61c4878aSAndroid Build Coastguard Worker
24*61c4878aSAndroid Build Coastguard Worker // Low to high priorities.
25*61c4878aSAndroid Build Coastguard Worker enum class ThreadPriority : UBaseType_t {
26*61c4878aSAndroid Build Coastguard Worker kWorkQueue = tskIDLE_PRIORITY + 1,
27*61c4878aSAndroid Build Coastguard Worker // TODO(amontanez): These should ideally be at different priority levels, but
28*61c4878aSAndroid Build Coastguard Worker // there's synchronization issues when they are.
29*61c4878aSAndroid Build Coastguard Worker kLog = kWorkQueue,
30*61c4878aSAndroid Build Coastguard Worker kRpc = kWorkQueue,
31*61c4878aSAndroid Build Coastguard Worker #if PW_SYSTEM_ENABLE_TRANSFER_SERVICE
32*61c4878aSAndroid Build Coastguard Worker kTransfer = kWorkQueue,
33*61c4878aSAndroid Build Coastguard Worker #endif // PW_SYSTEM_ENABLE_TRANSFER_SERVICE
34*61c4878aSAndroid Build Coastguard Worker kNumPriorities,
35*61c4878aSAndroid Build Coastguard Worker };
36*61c4878aSAndroid Build Coastguard Worker
37*61c4878aSAndroid Build Coastguard Worker static_assert(static_cast<UBaseType_t>(ThreadPriority::kNumPriorities) <=
38*61c4878aSAndroid Build Coastguard Worker configMAX_PRIORITIES);
39*61c4878aSAndroid Build Coastguard Worker
40*61c4878aSAndroid Build Coastguard Worker static constexpr size_t kLogThreadStackWords = 1024;
41*61c4878aSAndroid Build Coastguard Worker static thread::freertos::StaticContextWithStack<kLogThreadStackWords>
42*61c4878aSAndroid Build Coastguard Worker log_thread_context;
LogThreadOptions()43*61c4878aSAndroid Build Coastguard Worker const thread::Options& LogThreadOptions() {
44*61c4878aSAndroid Build Coastguard Worker static constexpr auto options =
45*61c4878aSAndroid Build Coastguard Worker pw::thread::freertos::Options()
46*61c4878aSAndroid Build Coastguard Worker .set_name("LogThread")
47*61c4878aSAndroid Build Coastguard Worker .set_static_context(log_thread_context)
48*61c4878aSAndroid Build Coastguard Worker .set_priority(static_cast<UBaseType_t>(ThreadPriority::kLog));
49*61c4878aSAndroid Build Coastguard Worker return options;
50*61c4878aSAndroid Build Coastguard Worker }
51*61c4878aSAndroid Build Coastguard Worker
52*61c4878aSAndroid Build Coastguard Worker // Stack size set to 16K in order to accommodate tests with large stacks.
53*61c4878aSAndroid Build Coastguard Worker // TODO: https://pwbug.dev/325509758 - Lower once tests stack sizes are reduced.
54*61c4878aSAndroid Build Coastguard Worker static constexpr size_t kRpcThreadStackWords = 8192;
55*61c4878aSAndroid Build Coastguard Worker static thread::freertos::StaticContextWithStack<kRpcThreadStackWords>
56*61c4878aSAndroid Build Coastguard Worker rpc_thread_context;
RpcThreadOptions()57*61c4878aSAndroid Build Coastguard Worker const thread::Options& RpcThreadOptions() {
58*61c4878aSAndroid Build Coastguard Worker static constexpr auto options =
59*61c4878aSAndroid Build Coastguard Worker pw::thread::freertos::Options()
60*61c4878aSAndroid Build Coastguard Worker .set_name("RpcThread")
61*61c4878aSAndroid Build Coastguard Worker .set_static_context(rpc_thread_context)
62*61c4878aSAndroid Build Coastguard Worker .set_priority(static_cast<UBaseType_t>(ThreadPriority::kRpc));
63*61c4878aSAndroid Build Coastguard Worker return options;
64*61c4878aSAndroid Build Coastguard Worker }
65*61c4878aSAndroid Build Coastguard Worker
66*61c4878aSAndroid Build Coastguard Worker #if PW_SYSTEM_ENABLE_TRANSFER_SERVICE
67*61c4878aSAndroid Build Coastguard Worker static constexpr size_t kTransferThreadStackWords = 512;
68*61c4878aSAndroid Build Coastguard Worker static thread::freertos::StaticContextWithStack<kTransferThreadStackWords>
69*61c4878aSAndroid Build Coastguard Worker transfer_thread_context;
TransferThreadOptions()70*61c4878aSAndroid Build Coastguard Worker const thread::Options& TransferThreadOptions() {
71*61c4878aSAndroid Build Coastguard Worker static constexpr auto options =
72*61c4878aSAndroid Build Coastguard Worker pw::thread::freertos::Options()
73*61c4878aSAndroid Build Coastguard Worker .set_name("TransferThread")
74*61c4878aSAndroid Build Coastguard Worker .set_static_context(transfer_thread_context)
75*61c4878aSAndroid Build Coastguard Worker .set_priority(static_cast<UBaseType_t>(ThreadPriority::kTransfer));
76*61c4878aSAndroid Build Coastguard Worker return options;
77*61c4878aSAndroid Build Coastguard Worker }
78*61c4878aSAndroid Build Coastguard Worker #endif // PW_SYSTEM_ENABLE_TRANSFER_SERVICE
79*61c4878aSAndroid Build Coastguard Worker
80*61c4878aSAndroid Build Coastguard Worker static constexpr size_t kWorkQueueThreadStackWords = 512;
81*61c4878aSAndroid Build Coastguard Worker static thread::freertos::StaticContextWithStack<kWorkQueueThreadStackWords>
82*61c4878aSAndroid Build Coastguard Worker work_queue_thread_context;
WorkQueueThreadOptions()83*61c4878aSAndroid Build Coastguard Worker const thread::Options& WorkQueueThreadOptions() {
84*61c4878aSAndroid Build Coastguard Worker static constexpr auto options =
85*61c4878aSAndroid Build Coastguard Worker pw::thread::freertos::Options()
86*61c4878aSAndroid Build Coastguard Worker .set_name("WorkQueueThread")
87*61c4878aSAndroid Build Coastguard Worker .set_static_context(work_queue_thread_context)
88*61c4878aSAndroid Build Coastguard Worker .set_priority(static_cast<UBaseType_t>(ThreadPriority::kWorkQueue));
89*61c4878aSAndroid Build Coastguard Worker return options;
90*61c4878aSAndroid Build Coastguard Worker }
91*61c4878aSAndroid Build Coastguard Worker
92*61c4878aSAndroid Build Coastguard Worker } // namespace pw::system
93