Skip to content

Commit

Permalink
EFR32: DeviceAttestationCredentialsProvider implemented.
Browse files Browse the repository at this point in the history
  • Loading branch information
rcasallas-silabs committed Jun 28, 2022
1 parent 0861153 commit 4daca17
Show file tree
Hide file tree
Showing 13 changed files with 218 additions and 7 deletions.
8 changes: 8 additions & 0 deletions examples/chef/efr32/src/AppTask.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,11 @@
#include <assert.h>

#include <credentials/DeviceAttestationCredsProvider.h>
#ifdef DEVICE_ATTESTATION_CREDENTIALS
#include <platform/EFR32/DeviceAttestationCredsImpl.h>
#else
#include <credentials/examples/DeviceAttestationCredsExample.h>
#endif

#include <setup_payload/QRCodeSetupPayloadGenerator.h>
#include <setup_payload/SetupPayload.h>
Expand Down Expand Up @@ -207,7 +211,11 @@ CHIP_ERROR AppTask::Init()

chip::DeviceLayer::PlatformMgr().LockChipStack();
// Initialize device attestation config
#ifdef DEVICE_ATTESTATION_CREDENTIALS
SetDeviceAttestationCredentialsProvider(EFR32::GetDACProvider());
#else
SetDeviceAttestationCredentialsProvider(Examples::GetExampleDACProvider());
#endif
chip::DeviceLayer::PlatformMgr().UnlockChipStack();

// Create FreeRTOS sw timer for Function Selection.
Expand Down
8 changes: 8 additions & 0 deletions examples/light-switch-app/efr32/src/AppTask.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,11 @@
#include <assert.h>

#include <credentials/DeviceAttestationCredsProvider.h>
#ifdef DEVICE_ATTESTATION_CREDENTIALS
#include <platform/EFR32/DeviceAttestationCredsImpl.h>
#else
#include <credentials/examples/DeviceAttestationCredsExample.h>
#endif

#include <setup_payload/QRCodeSetupPayloadGenerator.h>
#include <setup_payload/SetupPayload.h>
Expand Down Expand Up @@ -198,7 +202,11 @@ CHIP_ERROR AppTask::Init()

chip::DeviceLayer::PlatformMgr().LockChipStack();
// Initialize device attestation config
#ifdef DEVICE_ATTESTATION_CREDENTIALS
SetDeviceAttestationCredentialsProvider(EFR32::GetDACProvider());
#else
SetDeviceAttestationCredentialsProvider(Examples::GetExampleDACProvider());
#endif
chip::DeviceLayer::PlatformMgr().UnlockChipStack();

// Create FreeRTOS sw timer for Function Selection.
Expand Down
8 changes: 8 additions & 0 deletions examples/lighting-app/efr32/src/AppTask.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,11 @@
#include <assert.h>

#include <credentials/DeviceAttestationCredsProvider.h>
#ifdef DEVICE_ATTESTATION_CREDENTIALS
#include <platform/EFR32/DeviceAttestationCredsImpl.h>
#else
#include <credentials/examples/DeviceAttestationCredsExample.h>
#endif

#include <setup_payload/QRCodeSetupPayloadGenerator.h>
#include <setup_payload/SetupPayload.h>
Expand Down Expand Up @@ -203,7 +207,11 @@ CHIP_ERROR AppTask::Init()

chip::DeviceLayer::PlatformMgr().LockChipStack();
// Initialize device attestation config
#ifdef DEVICE_ATTESTATION_CREDENTIALS
SetDeviceAttestationCredentialsProvider(EFR32::GetDACProvider());
#else
SetDeviceAttestationCredentialsProvider(Examples::GetExampleDACProvider());
#endif
chip::DeviceLayer::PlatformMgr().UnlockChipStack();

// Create FreeRTOS sw timer for Function Selection.
Expand Down
8 changes: 8 additions & 0 deletions examples/lock-app/efr32/src/AppTask.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,11 @@
#include <assert.h>

#include <credentials/DeviceAttestationCredsProvider.h>
#ifdef DEVICE_ATTESTATION_CREDENTIALS
#include <platform/EFR32/DeviceAttestationCredsImpl.h>
#else
#include <credentials/examples/DeviceAttestationCredsExample.h>
#endif

#include <setup_payload/QRCodeSetupPayloadGenerator.h>
#include <setup_payload/SetupPayload.h>
Expand Down Expand Up @@ -212,7 +216,11 @@ CHIP_ERROR AppTask::Init()

chip::DeviceLayer::PlatformMgr().LockChipStack();
// Initialize device attestation config
#ifdef DEVICE_ATTESTATION_CREDENTIALS
SetDeviceAttestationCredentialsProvider(EFR32::GetDACProvider());
#else
SetDeviceAttestationCredentialsProvider(Examples::GetExampleDACProvider());
#endif
chip::DeviceLayer::PlatformMgr().UnlockChipStack();

// Create FreeRTOS sw timer for Function Selection.
Expand Down
17 changes: 17 additions & 0 deletions examples/platform/efr32/efr32_certs.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
#ifndef MATTER_MFG_TOKENS_EFR32
#define MATTER_MFG_TOKENS_EFR32

#include "psa/crypto.h"

#define EFR32_CERTS_DAC_ID PSA_KEY_ID_USER_MIN + 1

#define CREATOR_MFG_MATTER_CD (USERDATA_TOKENS | 0x200) // 4 bytes
#define CREATOR_MFG_MATTER_PAI (USERDATA_TOKENS | 0x420) // 4 bytes
#define CREATOR_MFG_MATTER_DAC (USERDATA_TOKENS | 0x5F0) // 4 bytes

#define MFG_MATTER_CD_SIZE 541
#define MFG_MATTER_PAI_SIZE 463
#define MFG_MATTER_DAC_SIZE 492
#define MFG_MATTER_DAC_KEY_ID PSA_KEY_ID_USER_MIN + 1

#endif // MATTER_MFG_TOKENS_EFR32
8 changes: 8 additions & 0 deletions examples/window-app/common/src/WindowApp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,11 @@
#include <app/server/Server.h>
#include <app/util/af.h>
#include <credentials/DeviceAttestationCredsProvider.h>
#ifdef DEVICE_ATTESTATION_CREDENTIALS
#include <platform/EFR32/DeviceAttestationCredsImpl.h>
#else
#include <credentials/examples/DeviceAttestationCredsExample.h>
#endif
#include <lib/support/CodeUtils.h>
#include <platform/CHIPDeviceLayer.h>

Expand Down Expand Up @@ -113,7 +117,11 @@ WindowApp::Cover * WindowApp::GetCover(chip::EndpointId endpoint)
CHIP_ERROR WindowApp::Init()
{
// Initialize device attestation config
#ifdef DEVICE_ATTESTATION_CREDENTIALS
SetDeviceAttestationCredentialsProvider(EFR32::GetDACProvider());
#else
SetDeviceAttestationCredentialsProvider(Examples::GetExampleDACProvider());
#endif

ConfigurationMgr().LogDeviceConfig();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,6 @@
#include <credentials/DeviceAttestationCredsProvider.h>
#include <credentials/FabricTable.h>
#include <credentials/GroupDataProvider.h>
#include <credentials/examples/DeviceAttestationCredsExample.h>
#include <lib/core/CHIPSafeCasts.h>
#include <lib/core/PeerId.h>
#include <lib/support/CodeUtils.h>
Expand Down
17 changes: 11 additions & 6 deletions src/credentials/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -47,16 +47,21 @@ static_library("credentials") {
"attestation_verifier/DeviceAttestationDelegate.h",
"attestation_verifier/DeviceAttestationVerifier.cpp",
"attestation_verifier/DeviceAttestationVerifier.h",
"examples/DeviceAttestationCredsExample.cpp",
"examples/DeviceAttestationCredsExample.h",
"examples/ExampleDACs.cpp",
"examples/ExampleDACs.h",
"examples/ExamplePAI.cpp",
"examples/ExamplePAI.h",
"examples/LastKnownGoodTimeCertificateValidityPolicyExample.h",
"examples/StrictCertificateValidityPolicyExample.h",
]

if (!chip_device_attestation_credentials) {
sources += [
"examples/DeviceAttestationCredsExample.cpp",
"examples/DeviceAttestationCredsExample.h",
"examples/ExampleDACs.cpp",
"examples/ExampleDACs.h",
"examples/ExamplePAI.cpp",
"examples/ExamplePAI.h",
]
}

# TODO: These tests files should be removed after the DeviceAttestationCredsExample implementation
# is changed to generate it's own credentials instead of using Test credentials.
# For mbed and nrfconnect test builds, which are bilding monolithic test library these files are not needed.
Expand Down
6 changes: 6 additions & 0 deletions src/platform/EFR32/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ if (chip_enable_openthread) {

static_library("EFR32") {
sources = [
"${chip_root}/src/credentials/DeviceAttestationCredsProvider.h",
"../FreeRTOS/SystemTimeSupport.cpp",
"../SingletonConfigurationManager.cpp",
"BLEManagerImpl.cpp",
Expand Down Expand Up @@ -56,6 +57,11 @@ static_library("EFR32") {
"gatt_db.h",
]

if (chip_device_attestation_credentials) {
defines = [ "DEVICE_ATTESTATION_CREDENTIALS=1" ]
sources += [ "DeviceAttestationCredsImpl.cpp" ]
}

if (chip_enable_ota_requestor) {
sources += [
"OTAImageProcessorImpl.cpp",
Expand Down
92 changes: 92 additions & 0 deletions src/platform/EFR32/DeviceAttestationCredsImpl.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
/*
*
* Copyright (c) 2021 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.
*/
#include "DeviceAttestationCredsImpl.h"
#include <crypto/CHIPCryptoPAL.h>
#include <lib/core/CHIPError.h>
#include <lib/support/Span.h>

#include "efr32_certs.h"
#include "psa/crypto.h"
#include "sl_token_api.h"
#include "sl_token_manager.h"
#include <lib/support/CodeUtils.h>

namespace chip {
namespace Credentials {
namespace EFR32 {

namespace {

class DeviceAttestationCredsImpl : public DeviceAttestationCredentialsProvider
{
public:
CHIP_ERROR GetCertificationDeclaration(MutableByteSpan & out_buffer) override
{
uint8_t cd_buf[MFG_MATTER_CD_SIZE];
int err = sl_token_get_data(CREATOR_MFG_MATTER_CD, 0, cd_buf, sizeof(cd_buf));
VerifyOrReturnError(!err, CHIP_ERROR_INTERNAL);
return CopySpanToMutableSpan(ByteSpan(cd_buf), out_buffer);
}

CHIP_ERROR GetFirmwareInformation(MutableByteSpan & out_firmware_info_buffer) override
{
// TODO: We need a real example FirmwareInformation to be populated.
out_firmware_info_buffer.reduce_size(0);
return CHIP_NO_ERROR;
}

CHIP_ERROR GetDeviceAttestationCert(MutableByteSpan & out_buffer) override
{
uint8_t cert_buf[MFG_MATTER_PAI_SIZE];
int err = sl_token_get_data(CREATOR_MFG_MATTER_DAC, 0, cert_buf, sizeof(cert_buf));
VerifyOrReturnError(!err, CHIP_ERROR_INTERNAL);
return CopySpanToMutableSpan(ByteSpan(cert_buf), out_buffer);
}

CHIP_ERROR GetProductAttestationIntermediateCert(MutableByteSpan & out_pai_buffer) override
{
uint8_t cert_buf[MFG_MATTER_DAC_SIZE];
int err = sl_token_get_data(CREATOR_MFG_MATTER_PAI, 0, cert_buf, sizeof(cert_buf));
VerifyOrReturnError(!err, CHIP_ERROR_INTERNAL);
return CopySpanToMutableSpan(ByteSpan(cert_buf), out_pai_buffer);
}

CHIP_ERROR SignWithDeviceAttestationKey(const ByteSpan & digest_to_sign, MutableByteSpan & out_buffer) override
{
psa_key_id_t key_id = MFG_MATTER_DAC_KEY_ID;
uint8_t signature[512];
size_t signature_length = 0;
psa_status_t err = psa_sign_message(key_id, PSA_ALG_ECDSA(PSA_ALG_SHA_256), digest_to_sign.data(), digest_to_sign.size(),
signature, sizeof(signature), &signature_length);
ChipLogDetail(MessageLayer, "~ SignWithDeviceAttestationKey, err:%ld, size:%zu\n", err, signature_length);
VerifyOrReturnError(!err, CHIP_ERROR_INTERNAL);

return CopySpanToMutableSpan(ByteSpan{ signature, signature_length }, out_buffer);
}
};

} // namespace

DeviceAttestationCredentialsProvider * GetDACProvider()
{
static DeviceAttestationCredsImpl dac_provider;
return &dac_provider;
}

} // namespace EFR32
} // namespace Credentials
} // namespace chip
36 changes: 36 additions & 0 deletions src/platform/EFR32/DeviceAttestationCredsImpl.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/*
*
* Copyright (c) 2022 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.
*/
#pragma once

#include <credentials/DeviceAttestationCredsProvider.h>

namespace chip {
namespace Credentials {
namespace EFR32 {

/**
* @brief Get implementation of a sample DAC provider to validate device
* attestation procedure.
*
* @returns a singleton DeviceAttestationCredentialsProvider that relies on no
* storage abstractions.
*/
DeviceAttestationCredentialsProvider * GetDACProvider();

} // namespace EFR32
} // namespace Credentials
} // namespace chip
3 changes: 3 additions & 0 deletions src/platform/device.gni
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,9 @@ declare_args() {

# Substitute fake platform when building with chip_device_platform=auto.
chip_fake_platform = false

# Use actual device attestation credentials
chip_device_attestation_credentials = false
}

if (chip_device_platform == "auto") {
Expand Down
13 changes: 13 additions & 0 deletions third_party/silabs/efr32_sdk.gni
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,13 @@ template("efr32_sdk") {
"${efr32_sdk_root}/platform/service/sleeptimer/config",
"${efr32_sdk_root}/platform/service/system/inc",
"${efr32_sdk_root}/platform/service/udelay/inc",
"${efr32_sdk_root}/platform/service/legacy_hal/inc",
"${efr32_sdk_root}/platform/service/token_manager/config",
"${efr32_sdk_root}/platform/service/token_manager/inc",
"${efr32_sdk_root}/platform/service/token_manager/test",
"${efr32_sdk_root}/platform/service/token_manager/test/include",
"${efr32_sdk_root}/platform/service/token_manager/test/stack/config",
"${efr32_sdk_root}/platform/service/token_manager/test/stack/include",
"${efr32_sdk_root}/platform/middleware/glib",
"${efr32_sdk_root}/platform/middleware/glib/glib",
"${efr32_sdk_root}/platform/middleware/glib/dmd",
Expand Down Expand Up @@ -153,6 +160,8 @@ template("efr32_sdk") {
"MBEDTLS_THREADING_ALT=1",
"SL_THREADING_ALT=1",
"SL_COMPONENT_CATALOG_PRESENT",
"PLATFORM_HEADER=\"platform-header.h\"",
"USE_NVM3=1",

#"__STACK_SIZE=0",
]
Expand Down Expand Up @@ -346,6 +355,7 @@ template("efr32_sdk") {
"${efr32_sdk_root}/platform/radio/rail_lib/plugin/rail_util_pti/sl_rail_util_pti.c",
"${efr32_sdk_root}/platform/service/device_init/src/sl_device_init_nvic.c",
"${efr32_sdk_root}/platform/service/hfxo_manager/src/sl_hfxo_manager.c",
"${efr32_sdk_root}/platform/service/legacy_hal/src/token_legacy.c",
"${efr32_sdk_root}/platform/service/mpu/src/sl_mpu.c",
"${efr32_sdk_root}/platform/service/power_manager/src/sl_power_manager.c",
"${efr32_sdk_root}/platform/service/power_manager/src/sl_power_manager_debug.c",
Expand All @@ -357,6 +367,9 @@ template("efr32_sdk") {
"${efr32_sdk_root}/platform/service/system/src/sl_system_init.c",
"${efr32_sdk_root}/platform/service/system/src/sl_system_kernel.c",
"${efr32_sdk_root}/platform/service/system/src/sl_system_process_action.c",
"${efr32_sdk_root}/platform/service/token_manager/src/sl_token_def.c",
"${efr32_sdk_root}/platform/service/token_manager/src/sl_token_manager.c",
"${efr32_sdk_root}/platform/service/token_manager/src/sl_token_manufacturing.c",
"${efr32_sdk_root}/platform/service/udelay/src/sl_udelay.c",
"${efr32_sdk_root}/platform/service/udelay/src/sl_udelay_armv6m_gcc.S",
"${efr32_sdk_root}/protocol/bluetooth/src/sl_bt_mbedtls_context.c",
Expand Down

0 comments on commit 4daca17

Please sign in to comment.