The extension "init_priority" doesn't work correctly on some platforms. Global
static objects are not deinitialized in a proper order, as the following
testcase shows. It is probably because of a linker bug.


----------------------------8<------------------------------

#include <stdio.h>

struct A {

    A() {

        printf("A()\n");
    }

    ~A() {

        printf("~A()\n");
    }
};


struct B {

    B() {

        printf("B()\n");
    }

    ~B() {

        printf("~B()\n");
    }
};


struct C {

    C() {

        printf("C()\n");
    }

    ~C() {

        printf("~C()\n");
    }
};

struct D {

    D() {

        printf("D()\n");
    }

    ~D() {

        printf("~D()\n");
    }
};

static A a;
static B b;
static C c __attribute__((init_priority(101)));
static D d;

int main(int argc, char *argv[])
{

 return 0;
}

----------------------------8<------------------------------

It produces:

C() <= this is OK because of init_priority
A()
B()
D()
~C() <= deinitialization order error
~D()
~B()
~A()

But it should be:

C()
A()
B()
D()
~D()
~B()
~A()
~C() <= should be deinitialized here


-- 
           Summary: Invalid global deinitialization order
           Product: gcc
           Version: 4.0.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P2
         Component: other
        AssignedTo: unassigned at gcc dot gnu dot org
        ReportedBy: wyderski at ii dot uni dot wroc dot pl
  GCC host triplet: IA-32, GCC 4.0.0 (DJGPP package), Windows XP


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=24472

Reply via email to