我正在调试一个非常奇怪的问题,目前不知所措,所以我想看看是否有人有任何想法/想法。
我的代码库中的一个字符驱动程序中有一个定义(这是 uCLinux 发行版中的众多驱动程序之一):
#define MAX_BUFSIZE 500
当我像这样构建时,我会看到输出包大小:
-rw-rw-r-- 1 mike users 1720620 Jan 16 11:00 gcl-kernel.pkg
当我将定义更改为 1000 并重建时:
#define MAX_BUFSIZE 1000
-rw-rw-r-- 1 mike users 2359596 Jan 16 11:17 gcl-kernel.pkg
整体内核镜像大幅增加。 #define
是唯一更改。 AFAIK,这应该在运行时改变可执行文件的 RAM 大小,它不应该对可执行文件的大小做任何事情。
所以我的问题:
谁能想到修改结构会改变最终图像大小的任何原因吗?
其他分析/信息(如果您关心):
我跟踪了头文件中定义的一个结构的使用情况:
typedef struct {
int head;
int tail;
int status;
int active;
void * dev[MAX_BUFSIZE];
char free[MAX_BUFSIZE];
canmsg_t data[MAX_BUFSIZE];
int count;
} msg_fifo_t;
每当我更改任何这些数组的大小时,可执行文件的大小都会发生变化。每当这种类型的新对象出现或在代码中被删除时,可执行文件大小都会发生变化,例如:
extern msg_fifo_t Tx_Bufx[];
extern msg_fifo_t Rx_Buf[];
具有不同的输出可执行文件大小:
extern msg_fifo_t Tx_Bufx[];
//extern msg_fifo_t Rx_Buf[];
我已经尝试过,但我似乎无法在我的 x86 系统上创建此问题的较小版本来调试问题,它一定与环境有关。 (针对 uCLinux 2.4 内核构建的 Coldfire 工具链)。
最佳答案
关于c - 为什么更改结构大小会更改可执行文件的大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14366582/