Fix for x86_64 build fail
[platform/upstream/connectedhomeip.git] / src / platform / Zephyr / ThreadStackManagerImpl.cpp
1 /*
2  *
3  *    Copyright (c) 2020 Project CHIP Authors
4  *
5  *    Licensed under the Apache License, Version 2.0 (the "License");
6  *    you may not use this file except in compliance with the License.
7  *    You may obtain a copy of the License at
8  *
9  *        http://www.apache.org/licenses/LICENSE-2.0
10  *
11  *    Unless required by applicable law or agreed to in writing, software
12  *    distributed under the License is distributed on an "AS IS" BASIS,
13  *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  *    See the License for the specific language governing permissions and
15  *    limitations under the License.
16  */
17
18 /**
19  *    @file
20  *          Provides an implementation of the ThreadStackManager object for
21  *          Zephyr platforms.
22  *
23  */
24 /* this file behaves like a config.h, comes first */
25 #include <platform/internal/CHIPDeviceLayerInternal.h>
26
27 #include <platform/OpenThread/GenericThreadStackManagerImpl_OpenThread.cpp>
28 #include <platform/Zephyr/ThreadStackManagerImpl.h>
29
30 #include <platform/OpenThread/OpenThreadUtils.h>
31 #include <platform/ThreadStackManager.h>
32
33 namespace chip {
34 namespace DeviceLayer {
35
36 using namespace ::chip::DeviceLayer::Internal;
37
38 ThreadStackManagerImpl ThreadStackManagerImpl::sInstance;
39
40 CHIP_ERROR ThreadStackManagerImpl::_InitThreadStack()
41 {
42     return GenericThreadStackManagerImpl_OpenThread<ThreadStackManagerImpl>::DoInit(openthread_get_default_instance());
43 }
44
45 CHIP_ERROR ThreadStackManagerImpl::_StartThreadTask()
46 {
47     // Intentionally empty.
48     return CHIP_NO_ERROR;
49 }
50
51 void ThreadStackManagerImpl::_LockThreadStack()
52 {
53     openthread_api_mutex_lock(openthread_get_default_context());
54 }
55
56 bool ThreadStackManagerImpl::_TryLockThreadStack()
57 {
58     // There's no openthread_api_mutex_try_lock() in Zephyr, so until it's contributed we must use the low-level API
59     return k_mutex_lock(&openthread_get_default_context()->api_lock, K_NO_WAIT) == 0;
60 }
61
62 void ThreadStackManagerImpl::_UnlockThreadStack()
63 {
64     openthread_api_mutex_unlock(openthread_get_default_context());
65 }
66
67 void ThreadStackManagerImpl::_ProcessThreadActivity()
68 {
69     // Intentionally empty.
70 }
71
72 void ThreadStackManagerImpl::_OnCHIPoBLEAdvertisingStart()
73 {
74     // Intentionally empty.
75 }
76
77 void ThreadStackManagerImpl::_OnCHIPoBLEAdvertisingStop()
78 {
79     // Intentionally empty.
80 }
81
82 } // namespace DeviceLayer
83 } // namespace chip