blob: de9495eeab8d230ad98fe183e37516dfcb87ff29 [file]
/*
*
* Copyright (c) 2020 Project CHIP Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file
* This file implements the CHIP Device Interface that is used by
* applications to interact with the CHIP stack
*
*/
#include <stdlib.h>
#include "CHIPDeviceManager.h"
#include <app/clusters/network-commissioning/network-commissioning.h>
#include <app/util/af-types.h>
#include <core/ErrorStr.h>
#include <dac_provider/CommonDACProvider.h>
#include <platform/realtek/freertos/FactoryDataProvider.h>
#include <support/CHIPMem.h>
#include <support/CodeUtils.h>
#if CHIP_ENABLE_OPENTHREAD
#include <platform/OpenThread/GenericNetworkCommissioningThreadDriver.h>
#endif // CHIP_ENABLE_OPENTHREAD
using namespace ::chip;
namespace chip {
namespace DeviceManager {
using namespace ::chip::DeviceLayer;
chip::DeviceLayer::FactoryDataProvider mFactoryDataProvider;
#if CHIP_ENABLE_OPENTHREAD
app::Clusters::NetworkCommissioning::InstanceAndDriver<NetworkCommissioning::GenericThreadDriver>
sThreadNetworkDriver(0 /*endpointId*/);
#endif // CHIP_ENABLE_OPENTHREAD
void CHIPDeviceManager::CommonDeviceEventHandler(const ChipDeviceEvent * event, intptr_t arg)
{
CHIPDeviceManagerCallbacks * cb = reinterpret_cast<CHIPDeviceManagerCallbacks *>(arg);
if (cb != nullptr)
{
cb->DeviceEventCallback(event, reinterpret_cast<intptr_t>(cb));
}
}
CHIP_ERROR CHIPDeviceManager::Init(CHIPDeviceManagerCallbacks * cb)
{
CHIP_ERROR err;
mCB = cb;
mIsInitDone = false;
ChipLogProgress(DeviceLayer, "Start to init MemoryInit");
err = Platform::MemoryInit();
SuccessOrExit(err);
ChipLogProgress(DeviceLayer, "Start to init InitChipStack");
err = PlatformMgr().InitChipStack();
SuccessOrExit(err);
ChipLogProgress(DeviceLayer, "Factorydata init");
err = mFactoryDataProvider.Init();
SuccessOrExit(err);
SetCommissionableDataProvider(&mFactoryDataProvider);
SetDeviceAttestationCredentialsProvider(GetDACProvider());
SetDeviceInstanceInfoProvider(&mFactoryDataProvider);
#if CONFIG_NETWORK_LAYER_BLE
err = ConnectivityMgr().SetBLEAdvertisingEnabled(true);
SuccessOrExit(err);
#endif
err = PlatformMgr().AddEventHandler(CHIPDeviceManager::CommonDeviceEventHandler, reinterpret_cast<intptr_t>(cb));
SuccessOrExit(err);
// Start a task to run the CHIP Device event loop.
err = PlatformMgr().StartEventLoopTask();
SuccessOrExit(err);
#if CHIP_ENABLE_OPENTHREAD
ChipLogProgress(DeviceLayer, "Initializing OpenThread stack");
err = ThreadStackMgr().InitThreadStack();
SuccessOrExit(err);
ChipLogProgress(DeviceLayer, "Set Thread Device Type");
#if CHIP_DEVICE_CONFIG_THREAD_FTD
err = ConnectivityMgr().SetThreadDeviceType(ConnectivityManager::kThreadDeviceType_Router);
#else // CHIP_DEVICE_CONFIG_THREAD_FTD
#if CHIP_CONFIG_ENABLE_ICD_SERVER
#if CHIP_DEVICE_CONFIG_THREAD_SSED
err = ConnectivityMgr().SetThreadDeviceType(ConnectivityManager::kThreadDeviceType_SynchronizedSleepyEndDevice);
#else
err = ConnectivityMgr().SetThreadDeviceType(ConnectivityManager::kThreadDeviceType_SleepyEndDevice);
#endif
#else // CHIP_CONFIG_ENABLE_ICD_SERVER
err = ConnectivityMgr().SetThreadDeviceType(ConnectivityManager::kThreadDeviceType_MinimalEndDevice);
#endif // CHIP_CONFIG_ENABLE_ICD_SERVER
#endif // CHIP_DEVICE_CONFIG_THREAD_FTD
SuccessOrExit(err);
(void) sThreadNetworkDriver.Init();
ChipLogProgress(DeviceLayer, "Start OpenThread task");
err = ThreadStackMgrImpl().StartThreadTask();
SuccessOrExit(err);
ChipLogProgress(DeviceLayer, "Start OpenThread task done!!");
#endif // CHIP_ENABLE_OPENTHREAD
mIsInitDone = true;
exit:
return err;
}
void CHIPDeviceManager::Shutdown()
{
PlatformMgr().Shutdown();
}
} // namespace DeviceManager
} // namespace chip
void MatterPostAttributeChangeCallback(const app::ConcreteAttributePath & attributePath, uint8_t type, uint16_t size,
uint8_t * value)
{
switch (attributePath.mClusterId)
{
case app::Clusters::Identify::Id:
ChipLogProgress(Zcl, "Identify cluster ID: " ChipLogFormatMEI " Type: %u Value: %u, length %u",
ChipLogValueMEI(attributePath.mAttributeId), type, *value, size);
break;
case app::Clusters::WindowCovering::Id:
ChipLogProgress(Zcl, "Window covering cluster ID: " ChipLogFormatMEI " Type: %u Value: %u, length: %u",
ChipLogValueMEI(attributePath.mAttributeId), type, *value, size);
break;
default:
break;
}
}