从 'uint8_t* {aka unsigned char*}' 到 'const char*' 的无效转换 [-fpermissive]
invalid conversion from 'uint8_t* {aka unsigned char*}' to 'const char*' [-fpermissive]
我正在使用 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");
}
void OSD0_TEXT ( const char *TEXT)
{
.....
TxBurst(0x400, strlen(TEXT), TEXT);
.....
}
main{
OSD0_TEXT("STAY FOLISH");
}
严格来说,uint8_t
和 char
可能并不总是兼容,因为 char
具有实现定义的签名,并且在某些编译器上可能是签名类型。
实际上,当 char
用于存储 ASCII 字符时,转换 to/from uint8_t
to/from char
将始终有效,因为没有符号带有负索引的表格。
旁注:
您应该始终努力确保 const 的正确性,尤其是在创建指向字符串文字的指针时。
字符串文字的大小可以在编译时计算,以节省一点时间。
main() return在我见过的任何裸机 ARM 系统上都是无效的。它不是 return int,因为那没有任何意义(return 对谁?)。
因此,您的代码的正确修复是:
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);
}
我正在使用 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");
}
void OSD0_TEXT ( const char *TEXT)
{
.....
TxBurst(0x400, strlen(TEXT), TEXT);
.....
}
main{
OSD0_TEXT("STAY FOLISH");
}
严格来说,uint8_t
和 char
可能并不总是兼容,因为 char
具有实现定义的签名,并且在某些编译器上可能是签名类型。
实际上,当 char
用于存储 ASCII 字符时,转换 to/from uint8_t
to/from char
将始终有效,因为没有符号带有负索引的表格。
旁注:
您应该始终努力确保 const 的正确性,尤其是在创建指向字符串文字的指针时。
字符串文字的大小可以在编译时计算,以节省一点时间。
main() return在我见过的任何裸机 ARM 系统上都是无效的。它不是 return int,因为那没有任何意义(return 对谁?)。
因此,您的代码的正确修复是:
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);
}