This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

[参考译文] CRC-AM243X:MCU-PLUS-SDK 标志因错误的数据类型转换而生成无效

Guru**** 2454490 points


请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

https://e2e.ti.com/support/microcontrollers/arm-based-microcontrollers-group/arm-based-microcontrollers/f/arm-based-microcontrollers-forum/1498017/mcu-plus-sdk-am243x-invalid-crc-flag-raise-because-of-wrong-data-type-conversion

器件型号:AM243X - MCU-PLUS-SDK

工具/软件:

您好:

目前我们面临的一个问题是将 EthcatCat 从属设备"RevisionNo"  值设置为大于0xFF。  

此问题会影响 EEPROM 上的"Configured Station Alias"。 下电上电后、此值始终复位回默认值(例如默认值为0)。

经过彻底 调查后、我们找到了问题的根本原因。 它位于 source "ti-Sitara-support-packages/TI_SDK/ind_comms_sdk_am243x/source/industrial_comms/EtherCAT_slave/iss_fwhal/tiscbsp.c"中 、方法为"bsp_eeprom_emulation_init ()" 、网址为:556、其中

数据类型转换似乎不正确、这会导致发出"INVALID_CRC_FLAG"。

/*This check compares the data at offset 24*/
temp_reg = *(uint32_t *)((uint8_t *)(eeprom_cache + (0xC << 1)));
if(temp_reg != (uint8_t)(*((uint8_t *)(g_bsp_params.default_tiesc_eeprom + 24))))
{
    invalid_crc_flag = 1;
}

因此、默认 EEPROM 将加载到 EEPROM_CACHE。

更正数据类型可解决此问题。  

我的问题是、  最新的 SDK 中是否已经解决了此问题?  

谢谢你。

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。
    [引述 userid="577497" url="~/support/microcontrollers/arm-based-microcontrollers-group/arm-based-microcontrollers/f/arm-based-microcontrollers-forum/1498017/mcu-plus-sdk-am243x-invalid-crc-flag-raise-because-of-wrong-data-type-conversion

    经过彻底 调查后、我们找到了问题的根本原因。 它位于 source "ti-Sitara-support-packages/TI_SDK/ind_comms_sdk_am243x/source/industrial_comms/EtherCAT_slave/iss_fwhal/tiscbsp.c"中 、方法为"bsp_eeprom_emulation_init ()" 、网址为:556、其中

    数据类型转换似乎不正确、这会导致发出"INVALID_CRC_FLAG"。

    [/报价]

    感谢您指出这一点、我认为最新的9.2.0.24版本中没有解决此问题。 因此、您可以通过以下更改来解决此问题

    temp_reg =*( uint8_t *)((uint8_t *)(EEPROM_CACHE +(0xC << 1)));/*将类型从 uint32_t 转换 为 uint8_t */

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    您好、

    感谢您的答复。  

    /*将类型从 uint32_t 转换 为 uint8_t */

    temp_reg 的值大于255、我相信我们可以保持它在这里。 但是、以下变化对我们来说是有益的

            temp_reg = *(uint32_t *)((uint8_t *)(eeprom_cache + (0xC << 1)));
            if(temp_reg != *(uint32_t *)((uint8_t *)(g_bsp_params.default_tiesc_eeprom + 24)))
            {
                invalid_crc_flag = 1;
            }

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    谢谢 Shahin。 我们将在下一个版本的 SDK 中修复该问题。

    此致、
    Aaron