日期:2014-05-16  浏览次数:20914 次

About“*** stack smashing detected ***”error
问题是这样的:
在开发一个小程序时,在源程序源代码目录下经过./configure,make,make install成功后,运行一切正常。
然后做成rpm包,再安装(-ivh,--nodeps,--force)运行后出现错误如下:
。。。
*** stack smashing detected ***: my_program terminated
PID 2803: received a signal=6
。。。
对应程序如下:
KNOWLA_INFO_t knowla_data;
int config_info_query(char *mod_name, CFG_INFO_t *pmd)
{
char hostname[HOSTLENGTH];
int port=0;
int retVal = 0;

if ( NULL == mod_name)
{
PRINT("config_info_query: invalid parameters!\n");
retVal = -1;
goto out;
}
  CONF_STR_CONFIG host_conf_array[] = {
  {"host", hostname},
  {0, 0}
  };
  CONF_INT_CONFIG port_int_array[] = {
  {"port", &port},
  {0, 0}
  };

  set_conf_file(CONF_FILE);

  if (load_conf(NULL, mod_name, port_int_array, host_conf_array) != 0) {
  WLOG_ERR("load configure failed!");
  return MOD_CONF_ERR;
  }

strcpy(pmd->hostname,hostname);
pmd->port = port;  

PRINT("cfg_info_query: hostname is: %s,port is :%d\n",pmd->hostname,pmd->port);
PRINT("main:=====================test log0000000000\n");

out:
  return retVal;
}
int main()
{
 ...
 1. memset(&knowla_data,0x00,sizeof(KNOWLA_INFO_t));
2. knowla_data.port = 0;
3, PRINT("main:before caoo knowla_info_query,test log=================\n");
4. retVal = knowla_info_query("knowla_cfg", &knowla_data);
5. PRINT("The knowla_data is %s,%d\n",knowla_data.hostname,knowla_data.port);
6. PRINT("main:=====================test log=================\n");
}
其中,knowla_data为一结构体变量。
最后安装rpm后运行的时候连第5句都没有打印出来,说明在main函数中,当调用完第4句的时候就出错了。

是不是说的“栈破碎”就是调用这个函数的时候出错的?

请高手给看看,非常感谢!!


------解决方案--------------------
这个现象看起来像是栈溢出,也就是说给数组hostname写入的时候越界,破坏了栈上的关键内容(比如返回地址)
config_info_query这个函数里面没有直接修改hostname, 但是把它的地址给了host_conf_array, 所以很可能是load_conf这个函数里面修改host_conf_array的时候越界。
建议:
1. 定义数组hostname的时候把空间多扩大一点, 看看还有没有错误
2. 在调用load_conf之前之后加上PRINT,看看是不是这里的问题
3. 检查load_conf的代码,看看他给host_conf_array里面写了多少字节,会不会超过HOSTLENGTH

------解决方案--------------------
你的问题可能发生在这2个地方
C/C++ code

load_conf(NULL, mod_name, port_int_array, host_conf_array)

strcpy(pmd->hostname,hostname);