Skip to content

Commit

Permalink
fix #20621 Comparing addresses of rvalue reference parameters not cor…
Browse files Browse the repository at this point in the history
…rect
  • Loading branch information
WalterBright committed Dec 31, 2024
1 parent da1b69a commit 0288ee4
Show file tree
Hide file tree
Showing 5 changed files with 37 additions and 3 deletions.
15 changes: 14 additions & 1 deletion compiler/src/dmd/backend/inliner.d
Original file line number Diff line number Diff line change
Expand Up @@ -516,7 +516,20 @@ private elem* initializeParamsWithArgs(elem* eargs, SYMIDX sistart, SYMIDX siend
{
if (log) printf("detected slice with %s\n", s.Sident.ptr);
auto s2 = nextSymbol(si);
if (!s2) { symbol_print(*s); elem_print(e); assert(0); }
if (!s2)
{
for (size_t m = args.length; m; --m)
{
elem* ex = args[m - 1];
printf("arg[%d]\n", cast(int) m);
elem_print(ex);
}

printf("function: %s\n", funcsym_p.Sident.ptr);
printf("szs: %d sze: %d\n", cast(int)szs, cast(int)sze);
printf("detected slice with %s\n", s.Sident.ptr);
symbol_print(*s); elem_print(e); assert(0);
}
assert(szs == type_size(s2.Stype));
const ty = s.Stype.Tty;

Expand Down
13 changes: 12 additions & 1 deletion compiler/src/dmd/constfold.d
Original file line number Diff line number Diff line change
Expand Up @@ -806,6 +806,7 @@ UnionExp Equal(EXP op, const ref Loc loc, Type type, Expression e1, Expression e

UnionExp Identity(EXP op, const ref Loc loc, Type type, Expression e1, Expression e2)
{
//printf("Identity %s %s\n", e1.toChars(), e2.toChars());
UnionExp ue = void;
int cmp;
if (e1.op == EXP.null_)
Expand All @@ -820,7 +821,17 @@ UnionExp Identity(EXP op, const ref Loc loc, Type type, Expression e1, Expressio
{
SymOffExp es1 = e1.isSymOffExp();
SymOffExp es2 = e2.isSymOffExp();
cmp = (es1.var == es2.var && es1.offset == es2.offset);
cmp = es1.offset == es2.offset;
if (cmp)
{
cmp = es1.var == es2.var;
if (!cmp && (es1.var.isParameter() || es2.var.isParameter()))
{
// because of ref's, they may still be the same, we cannot tell
cantExp(ue);
return ue;
}
}
}
else
{
Expand Down
8 changes: 8 additions & 0 deletions compiler/src/dmd/e2ir.d
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,10 @@ bool ISX64REF(Declaration var)
|| (var.storage_class & STC.lazy_)
|| (var.type.isTypeStruct() && var.type.isTypeStruct().sym.hasCopyConstruction());
}
else if (target.os & Target.OS.Windows)
{
return !(var.storage_class & STC.lazy_) && var.type.isTypeStruct() && var.type.isTypeStruct().sym.hasMoveCtor;
}
else if (target.os & Target.OS.Posix)
{
return !(var.storage_class & STC.lazy_) && var.type.isTypeStruct() && !var.type.isTypeStruct().sym.isPOD();
Expand All @@ -131,6 +135,10 @@ bool ISX64REF(ref IRState irs, Expression exp)
return exp.type.size(Loc.initial) > registerSize
|| (exp.type.isTypeStruct() && exp.type.isTypeStruct().sym.hasCopyConstruction());
}
else if (irs.target.os & Target.OS.Windows)
{
return exp.type.isTypeStruct() && exp.type.isTypeStruct().sym.hasMoveCtor;
}
else if (irs.target.os & Target.OS.Posix)
{
return exp.type.isTypeStruct() && !exp.type.isTypeStruct().sym.isPOD();
Expand Down
2 changes: 1 addition & 1 deletion compiler/src/dmd/root/longdouble.d
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ nothrow @nogc pure:
ushort exp_sign = 0x7fff; // sign is highest bit

this(ulong m, ushort es) { mantissa = m; exp_sign = es; }
this(longdouble_soft ld) { mantissa = ld.mantissa; exp_sign = ld.exp_sign; }
this(ref longdouble_soft ld) { mantissa = ld.mantissa; exp_sign = ld.exp_sign; }
this(int i) { ld_set(&this, i); }
this(uint i) { ld_set(&this, i); }
this(long i) { ld_setll(&this, i); }
Expand Down
2 changes: 2 additions & 0 deletions compiler/test/runnable/rvalue1.d
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,8 @@ struct S4
{
void* p;

this(ref S4) { }

this(S4 s)
{
assert(&s is &x); // confirm the rvalue reference
Expand Down

0 comments on commit 0288ee4

Please sign in to comment.