1

我正在尝试为 8052 嵌入式平台上的应用程序代码计算 CRC32。

以下是计算 CRC 的指南:

void TestChecksum()
{
     unsigned short calc = 0;

     /* Run the checksum algorithm */
     calc = slow_crc16(0, (unsigned char *) ChecksumStart, (ChecksumEnd - ChecksumStart+1));

     /* Rotate out the answer */
     unsigned char zeros[2] = {0, 0};
     calc = slow_crc16(calc, zeros, 2);

     etc...
}

在哪里

unsigned short slow_crc16(unsinged short sum, unsigned char *p, unsigned int len)
{
     while (len--)
     {
         int i;
         unsigned char byte = *(p++);

         for (i = 0; i < 8; ++i)
         {
          etc...
         }
}

这个例子的问题是指针自动指向 XData 而我在 CODE 之后。我知道我想计算 CRC 的代码地址,比如 0x2000 到 0x2FFF。

是否可以将指针定义为:

uint8_t __code *Ptr;

并将地址 0x2000 作为 uint32 传递给 CRC 函数?

基本上我不知道如何让一个指针指向一个实际存储为变量的地址。

任何帮助将不胜感激,我不确定这是否可能。

4

1 回答 1

0

指针整数;它只是有一种特殊的类型来阻止它与其他指针(或数字)混淆。

在许多架构上,您可以将指针转换为数字并再次返回而不会丢失任何内容:

char *ptr = (char *)0x2000;
int address = (int)ptr;

[这不适用于指针的“整数”与普通int“整数”大小不同的架构。还有一些其他奇特的案例你几乎肯定也不关心。]

实际上,获取指针以执行“成为整数”以外的任何操作的唯一方法是取消引用它:

char c = *ptr;

或者,使用数组表示法完全相同的东西:

char c = ptr[0];

或者,仅当ptr是指向struct类型的指针时:

int v = ptr->value;

在所有这些情况下,它使用指针作为地址,并从内存中获取引用的数据。

最后,您可以使用“address-of”运算符(也称为“reference”运算符)获取指向变量的指针:

char c = 'Z';
char *ptr = &c;
于 2013-07-08T15:38:11.450 回答