[Issue 19563] New: extern(C++) Incorrect ABI passing small struct

d-bugmail at puremagic.com d-bugmail at puremagic.com
Wed Jan 9 08:22:47 UTC 2019


https://issues.dlang.org/show_bug.cgi?id=19563

          Issue ID: 19563
           Summary: extern(C++) Incorrect ABI passing small struct
           Product: D
           Version: D2
          Hardware: x86_64
                OS: Linux
            Status: NEW
          Severity: blocker
          Priority: P1
         Component: dmd
          Assignee: nobody at puremagic.com
          Reporter: turkeyman at gmail.com

test.cpp
--------

struct Test
{
    Test() : ptr(nullptr) {}
    Test(const Test& x)
    {
        ptr = x.ptr + 10;
    }
    char* ptr;
};

int test(Test p);

int main()
{
    Test x;
    test(x);
    return 0;
}

test.d
------

extern(C++):

struct Test
{
    this(this)
    {
        ptr += 10;
    }
    char* ptr;
}

int test(Test p)
{
    assert(p.ptr == null);
    return 10;
}

--------------------------------------------

When I build and run this, passing `x` to test() by value crashes. The function
receives garbage.

If you remove the copy constructors (pass this same struct as a POD), it works
fine!

This was tested in Linux 64bit, against GCC-7.
If it makes any difference, I supplied `-std=c++11 -D_GLIBCXX_USE_CXX11_ABI=0`
to the C compiler.

--


More information about the Digitalmars-d-bugs mailing list