volatile uint32_t * sdramData = (volatile uint32_t *)0x30000100;
#define WIDTH 800
volatile uint32_t * im[WIDTH/4] = (volatile uint32_t **)sdramData;
第三行是给我一个错误的行。我正在尝试创建一个从 sdramData 位置开始的 int 指针数组。它说无效的初始化程序错误。谢谢你的帮助。
初始化符号需要用大括号括起来,大括号中的值必须是常量:
volatile uint32_t * im[WIDTH/4] = { sdramData };
sdramData
如果数组的第一个元素是一个常量(它不在术语的含义范围内),这将初始化数组的第一个元素,并将其他元素保持为零。
如果你真的想要 200 个连续的 4 字节位置(对此我有疑问 - 见下文),你将不得不产生 200 个值来初始化列表(因为标准 C 仍然没有重复计数选项对于数组初始值设定项,遗憾的是——作为扩展,GCC 确实如此)。
#define SDRAMBASE 0x30000100
#define INIT_x(x) (SDRAMBASE + (x) * sizeof(uint32_t))
#define INIT_5(x) INIT_x(x+0), INIT_x(x+1), INIT_x(x+2), INIT_x(x+3), INIT_x(x+4)
#define INIT_10(x) INIT_5(x+0), INIT_5(x+5)
#define INIT_50(x) INIT_10(x+0), INIT_10(x+10), INIT_10(x+20), INIT_10(x+30), INIT_10(x+40)
volatile uint32_t *im[WIDTH/4] =
{
INIT_50( 0),
INIT_50( 50),
INIT_50(100),
INIT_50(150),
};
不漂亮,但节省了很多打字。如果需要,您可以在扩展中插入(volatile uint32_t *)
演员表INIT_x
——您可能会这样做。
另一方面,您可能可以编写一个表达式,只使用 SDRAMBASE 来完成没有数组的工作im
:
#define im_ARRAY(i) (*(volatile uint32_t *)(SDRAMBASE + (i) * sizeof(uint32_t)))
现在你可以写(圆括号而不是方括号):
uint32_t x = im_ARRAY(43);
代替:
uint32_t x = im[43];
事实上,你甚至可以使用:
#define im_ARRAY ((volatile uint32_t *)SDRAMBASE)
然后你可以写(像往常一样的方括号):
uint32_t x = im_ARRAY[43];
这看起来更符合预期的效果。仍然不完全好,但相对干净。
您所追求的可能是:
volatile uint32_t (*im)[4] = (volatile uint32_t (*)[4])sdramData;
如果sdramData
至少指向WIDTH
uint32_t 值,那么这将进行im[0..WIDTH/4 - 1][0..3]
有效访问。