gpt4 book ai didi

pic - 使用 microchip c18 编译器在 pic18f 上创建大缓冲区

转载 作者:行者123 更新时间:2023-12-03 03:50:49 25 4
gpt4 key购买 nike

使用带有 pic18f 的 Microchip C18 编译器,我想在程序数据空间中创建一个 3000 字节的“大”缓冲区。

如果我把它放在 main() 中(在堆栈上):

char tab[127];

我有这个错误:

Error [1300] stack frame too large

如果我将其放在全局中,则会出现此错误:

Error - section '.udata_main.o' can not fit the section. Section '.udata_main.o' length=0x0000007f

如何创建一个大缓冲区?你有关于如何使用 c18 管理 pic18f 上的大缓冲区的教程吗?

最佳答案

这里有一个关于这个问题的教程:http://www.dwengo.org/tips-tricks/large-variables

基本上,您在特殊部分中声明变量,并在默认部分中声明指向它的指针:

  #pragma udata DATA // section DATA
int large_table[768];

#pragma udata // return to default section
int *table_ptr = &large_table[0];

接下来,您可以通过添加如下内容来更新链接描述文件以定义大部分:

DATABANK   NAME=data      START=0x200          END=0x7FF          PROTECTED
SECTION NAME=DATA RAM=data

请注意,通常没有任何未映射的内存可供您放置 DATA 部分,但 USB 缓冲区通常是我的首选(当然,除非您在同一个项目中需要 USB...)

关于pic - 使用 microchip c18 编译器在 pic18f 上创建大缓冲区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2983875/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com