Skip to content

Commit 3150237

Browse files
bzbarsky-applepull[bot]
authored andcommitted
Enable -Wconversion for nrfconnect platform bits. (#25383)
1 parent 9271979 commit 3150237

8 files changed

+36
-13
lines changed

src/platform/OpenThread/GenericThreadStackManagerImpl_OpenThread.cpp

+3-2
Original file line numberDiff line numberDiff line change
@@ -482,7 +482,8 @@ void GenericThreadStackManagerImpl_OpenThread<ImplClass>::_OnNetworkScanFinished
482482
scanResponse.lqi = aResult->mLqi;
483483
scanResponse.extendedAddress = Encoding::BigEndian::Get64(aResult->mExtAddress.m8);
484484
scanResponse.extendedPanId = Encoding::BigEndian::Get64(aResult->mExtendedPanId.m8);
485-
scanResponse.networkNameLen = strnlen(aResult->mNetworkName.m8, OT_NETWORK_NAME_MAX_SIZE);
485+
static_assert(OT_NETWORK_NAME_MAX_SIZE <= UINT8_MAX, "Network name length won't fit");
486+
scanResponse.networkNameLen = static_cast<uint8_t>(strnlen(aResult->mNetworkName.m8, OT_NETWORK_NAME_MAX_SIZE));
486487
memcpy(scanResponse.networkName, aResult->mNetworkName.m8, scanResponse.networkNameLen);
487488

488489
mScanResponseIter.Add(&scanResponse);
@@ -1168,7 +1169,7 @@ CHIP_ERROR GenericThreadStackManagerImpl_OpenThread<ImplClass>::_WriteThreadNetw
11681169
}
11691170
else
11701171
{
1171-
lastRssi.SetNonNull(((neighInfo.mLastRssi > 0) ? 0 : neighInfo.mLastRssi));
1172+
lastRssi.SetNonNull(min(static_cast<int8_t>(0), neighInfo.mLastRssi));
11721173
}
11731174

11741175
neighborTable.averageRssi = averageRssi;

src/platform/Zephyr/BUILD.gn

+2
Original file line numberDiff line numberDiff line change
@@ -76,4 +76,6 @@ static_library("Zephyr") {
7676
if (chip_malloc_sys_heap) {
7777
sources += [ "SysHeapMalloc.cpp" ]
7878
}
79+
80+
cflags = [ "-Wconversion" ]
7981
}

src/platform/Zephyr/DiagnosticDataProviderImpl.cpp

+1-1
Original file line numberDiff line numberDiff line change
@@ -226,7 +226,7 @@ CHIP_ERROR DiagnosticDataProviderImpl::GetTotalOperationalHours(uint32_t & total
226226

227227
ReturnErrorOnFailure(ConfigurationMgr().GetTotalOperationalHours(reinterpret_cast<uint32_t &>(totalHours)));
228228

229-
totalOperationalHours = totalHours + deltaTime < UINT32_MAX ? totalHours + deltaTime : UINT32_MAX;
229+
totalOperationalHours = static_cast<uint32_t>(totalHours + deltaTime < UINT32_MAX ? totalHours + deltaTime : UINT32_MAX);
230230

231231
return CHIP_NO_ERROR;
232232
}

src/platform/Zephyr/PlatformManagerImpl.cpp

+13-3
Original file line numberDiff line numberDiff line change
@@ -27,6 +27,7 @@
2727

2828
#include <platform/internal/CHIPDeviceLayerInternal.h>
2929

30+
#include <lib/support/SafeInt.h>
3031
#include <lib/support/logging/CHIPLogging.h>
3132
#include <platform/PlatformManager.h>
3233
#include <platform/Zephyr/DiagnosticDataProviderImpl.h>
@@ -48,11 +49,20 @@ static k_timer sOperationalHoursSavingTimer;
4849
static int app_entropy_source(void * data, unsigned char * output, size_t len, size_t * olen)
4950
{
5051
const struct device * entropy = DEVICE_DT_GET(DT_CHOSEN(zephyr_entropy));
51-
int ret = entropy_get_entropy(entropy, output, len);
52+
uint16_t clampedLen;
53+
if (CanCastTo<uint16_t>(len))
54+
{
55+
clampedLen = static_cast<uint16_t>(len);
56+
}
57+
else
58+
{
59+
clampedLen = UINT16_MAX;
60+
}
61+
int ret = entropy_get_entropy(entropy, output, clampedLen);
5262

5363
if (ret == 0)
5464
{
55-
*olen = len;
65+
*olen = clampedLen;
5666
}
5767
else
5868
{
@@ -85,7 +95,7 @@ void PlatformManagerImpl::UpdateOperationalHours(intptr_t arg)
8595
if (ConfigurationMgr().GetTotalOperationalHours(reinterpret_cast<uint32_t &>(totalOperationalHours)) == CHIP_NO_ERROR)
8696
{
8797
ConfigurationMgr().StoreTotalOperationalHours(
88-
totalOperationalHours + deltaTime < UINT32_MAX ? totalOperationalHours + deltaTime : UINT32_MAX);
98+
static_cast<uint32_t>(totalOperationalHours + deltaTime < UINT32_MAX ? totalOperationalHours + deltaTime : UINT32_MAX));
8999
sInstance.mSavedOperationalHoursSinceBoot = upTimeH;
90100
}
91101
else

src/platform/nrfconnect/BUILD.gn

+2
Original file line numberDiff line numberDiff line change
@@ -114,4 +114,6 @@ static_library("nrfconnect") {
114114
if (chip_malloc_sys_heap) {
115115
sources += [ "../Zephyr/SysHeapMalloc.cpp" ]
116116
}
117+
118+
cflags = [ "-Wconversion" ]
117119
}

src/platform/nrfconnect/OTAImageProcessorImpl.cpp

+10-2
Original file line numberDiff line numberDiff line change
@@ -164,8 +164,16 @@ CHIP_ERROR OTAImageProcessorImpl::ProcessBlock(ByteSpan & aBlock)
164164
if (error == CHIP_NO_ERROR)
165165
{
166166
// DFU target library buffers data internally, so do not clone the block data.
167-
error = System::MapErrorZephyr(dfu_multi_image_write(mParams.downloadedBytes, aBlock.data(), aBlock.size()));
168-
mParams.downloadedBytes += aBlock.size();
167+
if (mParams.downloadedBytes > std::numeric_limits<size_t>::max())
168+
{
169+
error = CHIP_ERROR_BUFFER_TOO_SMALL;
170+
}
171+
else
172+
{
173+
error = System::MapErrorZephyr(
174+
dfu_multi_image_write(static_cast<size_t>(mParams.downloadedBytes), aBlock.data(), aBlock.size()));
175+
mParams.downloadedBytes += aBlock.size();
176+
}
169177
}
170178

171179
// Report the result back to the downloader asynchronously.

src/platform/nrfconnect/wifi/NrfWiFiDriver.cpp

+1-1
Original file line numberDiff line numberDiff line change
@@ -48,7 +48,7 @@ bool NrfWiFiDriver::WiFiNetworkIterator::Next(Network & item)
4848
}
4949

5050
memcpy(item.networkID, mDriver->mStagingNetwork.ssid, mDriver->mStagingNetwork.ssidLen);
51-
item.networkIDLen = mDriver->mStagingNetwork.ssidLen;
51+
item.networkIDLen = static_cast<uint8_t>(mDriver->mStagingNetwork.ssidLen);
5252
item.connected = false;
5353

5454
mExhausted = true;

src/platform/nrfconnect/wifi/WiFiManager.cpp

+4-4
Original file line numberDiff line numberDiff line change
@@ -252,8 +252,8 @@ CHIP_ERROR WiFiManager::GetWiFiInfo(WiFiInfo & info) const
252252
info.mBssId = ByteSpan(mac_string_buf, sizeof(mac_string_buf));
253253
info.mSecurityType = static_cast<uint8_t>(status.security);
254254
info.mWiFiVersion = static_cast<uint8_t>(status.link_mode);
255-
info.mRssi = status.rssi;
256-
info.mChannel = status.channel;
255+
info.mRssi = static_cast<int8_t>(status.rssi);
256+
info.mChannel = static_cast<uint16_t>(status.channel);
257257
info.mSsidLen = status.ssid_len;
258258
memcpy(info.mSsid, status.ssid, status.ssid_len);
259259

@@ -291,12 +291,12 @@ void WiFiManager::ScanResultHandler(uint8_t * data)
291291
if (scanResult->rssi > Instance().mWiFiParams.mRssi)
292292
{
293293
Instance().ClearStationProvisioningData();
294-
Instance().mWiFiParams.mParams.ssid_length = Instance().mWantedNetwork.ssidLen;
294+
Instance().mWiFiParams.mParams.ssid_length = static_cast<uint8_t>(Instance().mWantedNetwork.ssidLen);
295295
Instance().mWiFiParams.mParams.ssid = Instance().mWantedNetwork.ssid;
296296
// Fallback to the WIFI_SECURITY_TYPE_PSK if the security is unknown
297297
Instance().mWiFiParams.mParams.security =
298298
scanResult->security <= WIFI_SECURITY_TYPE_MAX ? scanResult->security : WIFI_SECURITY_TYPE_PSK;
299-
Instance().mWiFiParams.mParams.psk_length = Instance().mWantedNetwork.passLen;
299+
Instance().mWiFiParams.mParams.psk_length = static_cast<uint8_t>(Instance().mWantedNetwork.passLen);
300300

301301
// If the security is none, WiFi driver expects the psk to be nullptr
302302
if (Instance().mWiFiParams.mParams.security == WIFI_SECURITY_TYPE_NONE)

0 commit comments

Comments
 (0)