9

当我声明一个接受的函数const char*并传递一个字符串文字时,我得到一个

警告:[2066] 分配中的类型限定符不匹配

因为字符串文字是rom const char*. 反过来也是一样。

虽然 PIC 是哈佛架构,但内存被映射到一个连续的地址空间,所以理论上应该可以以相同的方式同时支持 ram 和 rom 指针。可能我必须使用 rom 指针,因为它们是 24 位的,而 ram 指针是 16 位的。

但是,仅将 aconst char*转换为 aconst rom char*是行不通的。

4

2 回答 2

4

不幸的是,这是 Microchip C18 编译器的固有限制。C18 中的指针可以指向 ROM 或 RAM,但不能同时指向两者。

这就是为什么您会在例如Microchip 应用程序库中发现 ROM 和 RAM 操作的重复函数:

BYTE* TCPPutString(TCP_SOCKET hTCP, BYTE* Data);
ROM BYTE* TCPPutROMString(TCP_SOCKET hTCP, ROM BYTE* Data);

Hi-Tech PICC-18 编译器具有在运行时确定的适当地址空间,这允许更灵活的指针使用。这是我放弃 C18 转而使用 PICC-18 的原因之一。

请参阅此问题的答案以及 John Temples对 Hi-Tech PICC-18 和 MPLAB C18的比较以获得更多信息。

于 2011-05-17T11:59:48.867 回答
2

添加到 mizo 的答案(我无法发表评论,因为我主要回答 Arduino.SE 和 EE.SE)

XC8 编译器还具有在运行时确定适当地址空间的功能。

所以是的,Hi-Tech PICC-18 做到了这一点,但并不是唯一这样做的编译器。

尽管我可以理解目前是否不可能切换编译器。


因此,您可能希望在string.h

/** @name memcpypgm2ram
 * The {\bf memcpypgm2ram} function performs a {\bf memcpy} where
 * {\bf s1} points to data memory and {\bf s2} points to program
 * memory.
 * @param s1 pointer to destination in data memory
 * @param s2 pointer to source in program memory
 * @param n number of characters to copy
 */
void *memcpypgm2ram (auto void *s1, auto const MEM_MODEL rom void *s2, auto sizeram_t n);

/** @name memcpyram2pgm
 * The {\bf memcpyram2pgm} function performs a {\bf memcpy} where {\bf s1} 
 * points to program memory and {\bf s2} point to data memory.
 * @param s1 pointer to destination in program memory
 * @param s2 pointer to source in data memory
 * @param n number of characters to copy
 */
MEM_MODEL rom void *memcpyram2pgm (auto MEM_MODEL rom void *s1, auto const void *s2, auto sizeram_t n);

你可以让你的功能像:

void YourStringFunction(ramstring);

void YourStringFunctionAccpetingRom(romstring){
YourStringFunction(memcpypgm2ram(romstring));
}

^这不是实际代码,更多的是伪代码。另外,我不确定它是否有效。

于 2015-04-03T08:52:32.243 回答