Skip to content

Commit

Permalink
[Infineon] Add a test trigger for CYW30739 to fill up event logging b…
Browse files Browse the repository at this point in the history
…uffers.

* Implement the TestEventTriggerDelegate class to provide a vendor
  trigger kFillUpEventLoggingBuffer as 0xffffffff00000000 (-4294967296)
  to fill up event logging buffers with HardwareFaultChange and
  SoftwareFault events.
* Implement the OnSoftwareFaultEventHandler method to build and log a
  SoftwareFault event.
  • Loading branch information
hsusid committed May 9, 2024
1 parent e079364 commit 26bc3c8
Show file tree
Hide file tree
Showing 7 changed files with 220 additions and 0 deletions.
2 changes: 2 additions & 0 deletions examples/platform/infineon/cyw30739/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ static_library("platform") {
sources = [
"LEDWidget.h",
"OTAConfig.h",
"SoftwareDiagnostics.h",
"TestEventTriggerHandler.h",
"main.cpp",
]

Expand Down
62 changes: 62 additions & 0 deletions examples/platform/infineon/cyw30739/SoftwareDiagnostics.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
/*
*
* Copyright (c) 2024 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 "SoftwareDiagnostics.h"

#include <app/clusters/software-diagnostics-server/software-diagnostics-server.h>
#include <app/util/config.h>
#include <platform/CHIPDeviceLayer.h>

namespace chip {
namespace DeviceLayer {
namespace Infineon {
namespace CYW30739 {

using namespace chip::app::Clusters;

void OnSoftwareFaultEventHandler(const char * faultRecordString)
{
#ifdef MATTER_DM_PLUGIN_SOFTWARE_DIAGNOSTICS_SERVER
SoftwareDiagnostics::Events::SoftwareFault::Type softwareFault;

/* Unable to access thread ID in the application layer. */
softwareFault.id = 0;

if (DeviceLayer::PlatformMgrImpl().IsCurrentTask())
{
softwareFault.name.SetValue(CharSpan::fromCharString("Matter"));
}
else if (DeviceLayer::ThreadStackMgrImpl().IsCurrentTask())
{
softwareFault.name.SetValue(CharSpan::fromCharString("Thread"));
}
else
{
softwareFault.name.SetValue(CharSpan::fromCharString("App"));
}

softwareFault.faultRecording.SetValue(ByteSpan(Uint8::from_const_char(faultRecordString), strlen(faultRecordString)));

SoftwareDiagnosticsServer::Instance().OnSoftwareFaultDetect(softwareFault);
#endif // MATTER_DM_PLUGIN_SOFTWARE_DIAGNOSTICS_SERVER
}

} // namespace CYW30739
} // namespace Infineon
} // namespace DeviceLayer
} // namespace chip
29 changes: 29 additions & 0 deletions examples/platform/infineon/cyw30739/SoftwareDiagnostics.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
/*
*
* Copyright (c) 2024 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.
*/

namespace chip {
namespace DeviceLayer {
namespace Infineon {
namespace CYW30739 {

void OnSoftwareFaultEventHandler(const char * faultRecordString);

} // namespace CYW30739
} // namespace Infineon
} // namespace DeviceLayer
} // namespace chip
80 changes: 80 additions & 0 deletions examples/platform/infineon/cyw30739/TestEventTriggerHandler.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
/*
*
* Copyright (c) 2024 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 "TestEventTriggerHandler.h"

#include "SoftwareDiagnostics.h"

#include <app/clusters/general-diagnostics-server/general-diagnostics-server.h>
#include <platform/CHIPDeviceLayer.h>

namespace chip {
namespace DeviceLayer {
namespace Infineon {
namespace CYW30739 {

using namespace chip::app::Clusters;

CHIP_ERROR TestEventTriggerHandler::HandleEventTrigger(uint64_t eventTrigger)
{
switch (eventTrigger)
{
case kFillUpEventLoggingBuffer:
return HandleFillUpEventLoggingBufferEventTriger();
default:
return CHIP_ERROR_INVALID_ARGUMENT;
}
}

CHIP_ERROR TestEventTriggerHandler::HandleFillUpEventLoggingBufferEventTriger()
{
/* Create a fake hardware fault list. */
GeneralFaults<kMaxHardwareFaults> hardwareFaults;
for (uint8_t hardwareFault = to_underlying(GeneralDiagnostics::HardwareFaultEnum::kUnspecified);
hardwareFault < kMaxHardwareFaults; hardwareFault++)
{
hardwareFaults.add(hardwareFault);
}

/* Fill up the critical logging buffer by 10 hardware faults. */
constexpr uint8_t kHardwareFaultCountForCriticalBuffer = 10;
for (uint8_t i = 0; i < kHardwareFaultCountForCriticalBuffer; i++)
{
GeneralDiagnosticsServer::Instance().OnHardwareFaultsDetect(hardwareFaults, hardwareFaults);
}

/* Create a fake fault message. */
constexpr uint64_t kEncodingOverhead = 0x40;
constexpr uint64_t kMaxEventLoggingInfoSize = CHIP_DEVICE_CONFIG_EVENT_LOGGING_INFO_BUFFER_SIZE - kEncodingOverhead;
static char recordString[kMaxEventLoggingInfoSize + 1];
memset(recordString, 0x55, kMaxEventLoggingInfoSize);
recordString[kMaxEventLoggingInfoSize] = '\0';

/* Fill up the info logging buffer by a software fault. */
OnSoftwareFaultEventHandler(recordString);

/* Fill up the debug logging buffer by a software fault. */
OnSoftwareFaultEventHandler(recordString);

return CHIP_NO_ERROR;
}

} // namespace CYW30739
} // namespace Infineon
} // namespace DeviceLayer
} // namespace chip
42 changes: 42 additions & 0 deletions examples/platform/infineon/cyw30739/TestEventTriggerHandler.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
/*
*
* Copyright (c) 2024 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.
*/

#pragma once

#include <app/TestEventTriggerDelegate.h>

namespace chip {
namespace DeviceLayer {
namespace Infineon {
namespace CYW30739 {

class TestEventTriggerHandler : public chip::TestEventTriggerHandler
{
public:
static constexpr uint64_t kFillUpEventLoggingBuffer = 0xffff'ffff'0000'0000;

CHIP_ERROR HandleEventTrigger(uint64_t eventTrigger) override;

private:
CHIP_ERROR HandleFillUpEventLoggingBufferEventTriger();
};

} // namespace CYW30739
} // namespace Infineon
} // namespace DeviceLayer
} // namespace chip
2 changes: 2 additions & 0 deletions examples/platform/infineon/cyw30739/cyw30739_example.gni
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ template("cyw30739_example") {
sources = [
"${cyw30739_example_dir}/LEDWidget.cpp",
"${cyw30739_example_dir}/OTAConfig.cpp",
"${cyw30739_example_dir}/SoftwareDiagnostics.cpp",
"${cyw30739_example_dir}/TestEventTriggerHandler.cpp",
"${cyw30739_example_dir}/matter_config.cpp",
]

Expand Down
3 changes: 3 additions & 0 deletions examples/platform/infineon/cyw30739/matter_config.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@

#include "matter_config.h"
#include "AppTask.h"
#include "TestEventTriggerHandler.h"
#ifdef BOARD_ENABLE_DISPLAY
#include "GUI.h"
#endif
Expand Down Expand Up @@ -191,8 +192,10 @@ void CYW30739MatterConfig::InitApp(void)
/* Start CHIP datamodel server */
static chip::SimpleTestEventTriggerDelegate sTestEventTriggerDelegate{};
static chip::OTATestEventTriggerHandler sOtaTestEventTriggerHandler{};
static Infineon::CYW30739::TestEventTriggerHandler sCYW30739TestEventTriggerHandler{};
VerifyOrDie(sTestEventTriggerDelegate.Init(chip::ByteSpan(sTestEventTriggerEnableKey)) == CHIP_NO_ERROR);
VerifyOrDie(sTestEventTriggerDelegate.AddHandler(&sOtaTestEventTriggerHandler) == CHIP_NO_ERROR);
VerifyOrDie(sTestEventTriggerDelegate.AddHandler(&sCYW30739TestEventTriggerHandler) == CHIP_NO_ERROR);
// Create initParams with SDK example defaults here
static chip::CommonCaseDeviceServerInitParams initParams;
(void) initParams.InitializeStaticResourcesBeforeServerInit();
Expand Down

0 comments on commit 26bc3c8

Please sign in to comment.