/* * * Copyright (c) 2020 Project CHIP Authors * All rights reserved. * * 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. */ #include #include #include using namespace ::chip; using namespace ::chip::Inet; using namespace ::chip::DeviceLayer; volatile int apperror_cnt; // ================================================================================ // App Error //================================================================================= void appError(int err) { ChipLogProgress(NotSpecified, "!!!!!!!!!!!! App Critical Error: %d !!!!!!!!!!!", err); portDISABLE_INTERRUPTS(); while (true) ; } void appError(CHIP_ERROR error) { appError(static_cast(error.AsInteger())); } extern "C" int START_ENTRY(void) { platform_port_init(); Internal::BLConfig::Init(); ChipLogProgress(NotSpecified, "=================================================="); ChipLogProgress(NotSpecified, "bouffalolab chip-lighting-example, built at " __DATE__ " " __TIME__); ChipLogProgress(NotSpecified, "=================================================="); ChipLogProgress(NotSpecified, "Init CHIP Memory"); chip::Platform::MemoryInit(NULL, 0); ChipLogProgress(NotSpecified, "Starting App Task"); StartAppTask(); ChipLogProgress(NotSpecified, "Starting OS Scheduler..."); vTaskStartScheduler(); // Should never get here. ChipLogError(NotSpecified, "Starting OS Scheduler failed"); appError(0); return 0; }