无效转换:从“uint8_t* {aka unsigned char*}”到“const char*”[-fpermissive]

6

我正在使用gcc编译器为STM32编写C代码,我尝试了一些建议。我通过i2c.h定义从i2c.c调用函数。也许我在那里犯了错误。感谢您的评论。

(i2c.h)

#define Chip_TxBurst(wREG, wCNT, pbDATA)   \
    I2C_TxBurst((0xC0) | (((wREG) >> 7) & 0x1E), (wREG), (wCNT), (pbDATA))

(i2c.c)

void I2C_TxBurst (
uint16_t  bSLA,          /* I2C slave address */
uint16_t  bREG,          /* I2C sub-address */
uint16_t  bCNT,          /* The number of data which will be transmitted */
uint8_t  *pbDATA        /* Point to the first DATA item */
)
{
    uint8_t bIdx;

    for (bIdx = 0; bIdx < bCNT; bIdx++)
    {
        I2C_TxData(pbDATA[bIdx]);
    } /* for */

    } /* I2C_TxBurst */

(osd.c)

void OSD0_TEXT( uint8_t     *TEXT,
                    uint8_t     FONT_SIZE_X,
                    ......
                    )
{
    Chip_TxBurst(0x400, FONT_SIZE_X, TEXT);
}

(主要的)

main{
OSD0_TEXT("STAY FOLISH",11);
}

(旧问题代码)

void OSD0_TEXT (    uint8_t     *TEXT)
{
.....
TxBurst(0x400, strlen(TEXT), TEXT);
.....
}
main{
OSD0_TEXT("STAY FOLISH");
}

2
你将 char[N] 传递给一个期望 uint8_t 的函数(OS0_TEXT),并将 uint8_t 传递给一个期望 const char* 的函数(strlen)。 - P.P
2个回答

7
严格来说,uint8_tchar可能并不兼容,因为char的有符号实现是未定义的,在一些编译器中可能是一个有符号类型。
在实践中,当char用于存储ASCII字符时,将uint8_t转换为/从char转换为总是有效的,因为没有带负索引的符号表。
附注:
  • 应始终追求const正确性,特别是在创建对字符串字面值的指针时。

  • 字符串字面量的大小可以在编译时计算,以节省一点时间。

  • 在我见过的任何裸机ARM系统上,main()返回void。它不返回int,因为那没有任何意义(返回给谁?)。

因此,修复您代码的正确方法是:
void OSD0_TEXT (const uint8_t* TEXT, size_t size)
{
  ...
  TxBurst(0x400, size, TEXT);
  ...
}

void main (void)
{
  static const char STR[] = "STAY FOOLISH"; // static to ensure it wont end up in RAM
  const size_t STR_LEN = sizeof(STR) - 1;

  OSD0_TEXT((const uint8_t*)STR, STR_LEN);
}

0
void OSD0_TEXT (    const char *TEXT)
{
.....
TxBurst(0x400, strlen(TEXT), TEXT);
.....
}
main{
OSD0_TEXT("STAY FOLISH");
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接