std :: map在gcc4.4.6 x86_64中生成分段错误

时间:2012-11-26 00:00:49

标签: gcc segmentation-fault stdmap

错误是

Program terminated with signal 11, Segmentation fault.
#0  _M_lower_bound (this=0x7fff4982ad00, __k=<value optimized out>) at /usr/lib/gcc/x86_64-redhat-linux/4.4.6/../../../../include/c++/4.4.6/bits/stl_tree.h:986
986             if (!_M_impl._M_key_compare(_S_key(__x), __k))
Missing separate debuginfos, use: debuginfo-install glibc-2.12-1.80.el6_3.6.x86_64 libgcc-4.4.6-4.el6.x86_64 libstdc++-4.4.6-4.el6.x86_64
(gdb) bt
#0  _M_lower_bound (this=0x7fff4982ad00, __k=<value optimized out>) at /usr/lib/gcc/x86_64-redhat-linux/4.4.6/../../../../include/c++/4.4.6/bits/stl_tree.h:986
#1  lower_bound (this=0x7fff4982ad00, __k=<value optimized out>) at /usr/lib/gcc/x86_64-redhat-linux/4.4.6/../../../../include/c++/4.4.6/bits/stl_tree.h:745
#2  lower_bound (this=0x7fff4982ad00, __k=<value optimized out>) at /usr/lib/gcc/x86_64-redhat-linux/4.4.6/../../../../include/c++/4.4.6/bits/stl_map.h:701
#3  std::map<int, int, std::less<int>, std::allocator<std::pair<int const, int> > >::operator[] (this=0x7fff4982ad00, __k=<value optimized out>)
    at /usr/lib/gcc/x86_64-redhat-linux/4.4.6/../../../../include/c++/4.4.6/bits/stl_map.h:447
#4  0x0000000000405148 in do_trace_loop () at main.cc:375
#5  0x0000000000407011 in main (argc=<value optimized out>, argv=<value optimized out>) at main.cc:727
(gdb)

但源代码非常正常

    pid_t retpid;
  map<int, int,less<int> > incall;
  map<int, int,less<int> > last;
  int status = 0;

  struct pstate_t ps;

  int nsyscalls = 0, nfiltered = 0, child_cored = 0, child_exit = 0;
  gettimeofday(&initTime,0);
  for(;;) {
#ifdef TIMED
    timeval init;
    gettimeofday(&init,0);    
#endif
    retpid = wait4(-1, &status, __WALL, &ru);
#ifdef TIMED
    getelapsed(init, 1000000, "wait");
#endif

    if(retpid == -1) {
      FATAL("wait");

    } else if(retpid == 0) {
      FATAL("wait was not passed WNOHANG but returned 0");

    } else {
#ifndef DEBUG
    {
    stringstream s;
    s << "PID: " << retpid <<"-----------" ;      
    logger->log(s.str());
    }
#endif
      if(WIFEXITED(status)) {
          if(retpid == child) {
                stringstream s;
                s << "child exited with status " << WEXITSTATUS(status);
                logger->log(s.str());
                break;
          } else {
                stringstream s;
                s << "child thread " << retpid  << " exited with status " << WEXITSTATUS(status);
                debug(s.str());
                continue;
          }
      }

      //this was below
      if(WIFSIGNALED(status)) {
        for(int i = 0; i < initModulePlugins.size(); i++) {
              Initializer* c = initModulePlugins[i];
              c->signaled(WTERMSIG(status), signame(WTERMSIG(status)));
        }

        if(child == retpid) {

            break;
        }
        continue;
      }

      if(WIFSTOPPED(status)) {
        int sig = WSTOPSIG(status);

        /* stopped due to entering or leaving a system call? */
        if(sig == SIGTRAP) {

          /* note that my structure has extra fields and this doesn't fill them */
          if(ptrace(PTRACE_GETREGS, retpid, 0, &ps)) {
            //FATAL("ptrace(PTRACE_GETREGS, ...)");

            stringstream s;
            s << "PTRACE_GETREGS  " << retpid << " failed";
            logger->log(s.str());

            continue;
          }

          if(incall[(int)retpid] && ps.scno != last[(int)retpid]) {
            /* this can potentially happen if we get confused by a signal or if we see nested system calls...
               it also happens after a successful exec */
            stringstream s;
            s << "not in syscall " << scname(last[retpid]) << " as expected";
            logger->log(s.str());
            incall[retpid] = 0;
          }

          /* becomes true if entering, false if leaving */
          incall[retpid] = !incall[retpid];

          if(incall[retpid]) {
            nsyscalls++;
          }

0 个答案:

没有答案