Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Assertion failed 'Contains(ancestor) && Contains(descendant)' during 'SSA: liveness' #110957

Closed
kunalspathak opened this issue Dec 26, 2024 · 8 comments · Fixed by #111128
Closed
Labels
arch-arm64 area-CodeGen-coreclr CLR JIT compiler in src/coreclr/src/jit and related components such as SuperPMI in-pr There is an active PR which will close this issue when it is merged os-mac-os-x macOS aka OSX

Comments

@kunalspathak
Copy link
Member

This is on osx/arm64, but I have seen failures in other platforms like linux/arm and windows/x64

// Found by Antigen
// Reduced from 30.59 KB to 2.86 KB.


using System;
using System.Collections.Generic;
using System.Runtime.CompilerServices;
using System.Runtime.Intrinsics;
using System.Runtime.Intrinsics.Arm;
using System.Runtime.Intrinsics.X86;
using System.Numerics;
public class TestClass
{
    public struct S1
    {
        public struct S1_D1_F1
        {
            public struct S1_D2_F1
            {
                public bool bool_0;
            }
        }
    }
    public struct S2
    {
        public struct S2_D1_F1
        {
            public struct S2_D2_F2
            {
                public uint uint_5;
            }
        }
    }
    public struct S3
    {
        public S2.S2_D1_F1.S2_D2_F2 s2_s2_d1_f1_s2_d2_f2_12;
    }
    public struct S4
    {
        public double double_15;
    }
    public struct S5
    {
    }
    static int s_int_26 = 2;
    static uint s_uint_32 = 2;
    static Vector64<byte> s_v64_byte_35 = Vector64.CreateScalar((byte)1);
    static Vector64<float> s_v64_float_43 = Vector64<float>.AllBitsSet;
    static Vector64<double> s_v64_double_44 = Vector64.CreateScalar((double)-5);
    static Vector128<int> s_v128_int_49 = Vector128.Create(2);
    static S1 s_s1_70 = new S1();
    static S2.S2_D1_F1 s_s2_s2_d1_f1_72 = new S2.S2_D1_F1();
    static S3 s_s3_74 = new S3();
    S1.S1_D1_F1.S1_D2_F1 s1_s1_d1_f1_s1_d2_f1_125 = new S1.S1_D1_F1.S1_D2_F1();
    S2.S2_D1_F1.S2_D2_F2 s2_s2_d1_f1_s2_d2_f2_128 = new S2.S2_D1_F1.S2_D2_F2();
    S2 s2_130 = new S2();
    S4 s4_132 = new S4();
    S5 s5_133 = new S5();
    private static List<string> toPrint = new List<string>();
    public uint Method1(S5 p_s5_134, out S1 p_s1_135, S1 p_s1_136, out S2 p_s2_137, S2.S2_D1_F1 p_s2_s2_d1_f1_138, Vector128<int> p_v128_int_139, S2 p_s2_140, S1.S1_D1_F1.S1_D2_F1 p_s1_s1_d1_f1_s1_d2_f1_141, out double p_double_142)
    {
        unchecked
        {
            byte byte_144 = 2;
            p_double_142 = Vector64.Sum(s_v64_double_44 *= Vector64.WidenLower(s_v64_float_43));
            try
            {
                Vector64.AsUInt32(s_v64_byte_35 | s_v64_byte_35);
            }
            catch (System.MethodAccessException)
{}            finally
            {
                do
                {
                }
                while (s1_s1_d1_f1_s1_d2_f1_125.bool_0 = byte_144 > (byte_144 >>= s_int_26 >>= 79));
            }
            return s_s3_74.s2_s2_d1_f1_s2_d2_f2_12.uint_5 = s_uint_32;
        }
    }
    public void Method0()
    {
        unchecked
        {
            s2_s2_d1_f1_s2_d2_f2_128.uint_5 = Method1(s5_133, out s_s1_70, s_s1_70, out s2_130, s_s2_s2_d1_f1_72, s_v128_int_49 *= 15-4, s2_130, s1_s1_d1_f1_s1_d2_f1_125, out s4_132.double_15);
            return;
        }
    }
    public static void Main(string[] args)
    {
      Antigen();
    }
    public static int Antigen()
    {
        new TestClass().Method0();
        return string.Join(Environment.NewLine, toPrint).GetHashCode();
    }
}
/*
Environment:

set DOTNET_JitObjectStackAllocation=1
set DOTNET_TieredCompilation=0
set DOTNET_MaxVectorTBitWidth=128
set DOTNET_PreferredVectorBitWidth=0
set DOTNET_JitStress=2
set DOTNET_JitThrowOnAssertionFailure=1
set DOTNET_LegacyExceptionHandling=1

Debug: -1958815518

Release: 0
JIT assert failed:
Assertion failed 'Contains(ancestor) && Contains(descendant)' in 'TestClass:Method1(TestClass+S5,byref,TestClass+S1,byref,TestClass+S2+S2_D1_F1,System.Runtime.Intrinsics.Vector128`1[int],TestClass+S2,TestClass+S1+S1_D1_F1+S1_D2_F1,byref):uint:this' during 'SSA: liveness' (IL size 128; hash 0xbf8e1181; FullOpts)

    File: /Users/runner/work/1/s/src/coreclr/jit/flowgraph.cpp Line: 4288


*/
@dotnet-issue-labeler dotnet-issue-labeler bot added the area-CodeGen-coreclr CLR JIT compiler in src/coreclr/src/jit and related components such as SuperPMI label Dec 26, 2024
@dotnet-policy-service dotnet-policy-service bot added the untriaged New issue has not been triaged by the area owner label Dec 26, 2024
Copy link
Contributor

Tagging subscribers to this area: @JulieLeeMSFT, @jakobbotsch
See info in area-owners.md if you want to be subscribed.

@jakobbotsch
Copy link
Member

I cannot reproduce this on win-x64. What platform is this supposed to repro on?

@kunalspathak
Copy link
Member Author

I cannot reproduce this on win-x64. What platform is this supposed to repro on?

This is from osx/arm64 or any other arm64 platform

This is on osx/arm64,

@jakobbotsch
Copy link
Member

Ah thanks, not sure how I missed that.
Still can't repro with alt jit. Can you link or share one of the win-x64 examples?

@kunalspathak
Copy link
Member Author

This one is on linux/arm64 that reproed on Saturday's run

// Found by Antigen
// Reduced from 53.36 KB to 3.11 KB.


using System;
using System.Collections.Generic;
using System.Runtime.CompilerServices;
using System.Runtime.Intrinsics;
using System.Runtime.Intrinsics.Arm;
using System.Runtime.Intrinsics.X86;
using System.Numerics;
public class TestClass
{
    public struct S1
    {
    }
    public struct S2
    {
        public struct S2_D1_F1
        {
        }
    }
    static uint s_uint_16 = 5;
    static Vector64<ulong> s_v64_ulong_26 = Vector64.Create((ulong)0);
    static Vector<byte> s_v_byte_39 = Vector.Create((byte)5);
    static S1 s_s1_52 = new S1();
    static S2.S2_D1_F1 s_s2_s2_d1_f1_53 = new S2.S2_D1_F1();
    Vector64<ulong> v64_ulong_77 = Vector64<ulong>.AllBitsSet;
    Vector128<sbyte> v128_sbyte_81 = Vector128<sbyte>.Zero;
    Vector<byte> v_byte_90 = Vector.Create((byte)5);
    S2 s2_105 = new S2();
    private static List<string> toPrint = new List<string>();
    public uint Method4(out Vector<byte> p_v_byte_186, S2.S2_D1_F1 p_s2_s2_d1_f1_187, S1 p_s1_188, out S1 p_s1_189, Vector64<ulong> p_v64_ulong_190, S2 p_s2_191, out S2 p_s2_192, long p_long_193)
    {
        unchecked
        {
            int int_200 = 5;
            uint uint_206 = 1;
            p_v_byte_186 = s_v_byte_39 *= 15|4;
            try
            {
                p_v_byte_186 += p_v_byte_186;
            }
            catch (System.AggregateException)
            {
            }
            finally
            {
                switch (int_200 % 15|4)
                {
                    case 0:
                    {
                        break;
                    }
                    case 73:
                    {
                        break;
                    }
                    case 2:
                    {
                        if (15<=4)
                        {
                        }
                        else
                        {
                            if (Vector128.GreaterThanAll(v128_sbyte_81, v128_sbyte_81 *= 15-4))
                            {
                            }
                            else
                            {
                                do
                                {
                                }
                                while (true);
                            }
                        }
                        break;
                    }
                    default:
                    {
                        break;
                    }
                }
            }
            return uint_206 ^= 15&4;
        }
    }
    public void Method0()
    {
        unchecked
        {
            long long_220 = 2;
            S2 s2_230 = new S2();
            s_uint_16 = Method4(out v_byte_90, s_s2_s2_d1_f1_53, s_s1_52, out s_s1_52, Vector64.IsPositiveInfinity(v64_ulong_77 += Vector64.ClampNative(s_v64_ulong_26, s_v64_ulong_26, s_v64_ulong_26) - s_v64_ulong_26 & v64_ulong_77), s2_230, out s2_105, long_220 *= 15^4);
            return;
        }
    }
    public static void Main(string[] args)
    {
      Antigen();
    }
    public static int Antigen()
    {
        new TestClass().Method0();
        return string.Join(Environment.NewLine, toPrint).GetHashCode();
    }
}
/*
Environment:

set DOTNET_JitFakeProcedureSplitting=1
set DOTNET_TieredCompilation=0
set DOTNET_MaxVectorTBitWidth=128
set DOTNET_PreferredVectorBitWidth=0
set DOTNET_JitStress=0
set DOTNET_JitStressRegs=1
set DOTNET_JitThrowOnAssertionFailure=1
set DOTNET_LegacyExceptionHandling=1

Debug: -184101551

Release: 0
JIT assert failed:
Assertion failed 'Contains(ancestor) && Contains(descendant)' in 'TestClass:Method4(byref,TestClass+S2+S2_D1_F1,TestClass+S1,byref,System.Runtime.Intrinsics.Vector64`1[ulong],TestClass+S2,byref,long):uint:this' during 'SSA: liveness' (IL size 121; hash 0x90884810; FullOpts)

    File: /__w/1/s/src/coreclr/jit/flowgraph.cpp Line: 4288


*/

@kunalspathak
Copy link
Member Author

kunalspathak commented Dec 31, 2024

And here is windows/x64, repros on 6045e29 with DOTNET_TieredCompilation=0

// Found by Antigen
// Reduced from 18.96 KB to 1.82 KB.

public class TestClass
{
    public struct S1
    {
        public struct S1_D1_F1
        {
        }
    }
    static bool s_bool_2 = true;
    static long s_long_9 = 5;
    int int_27 = 3;
    uint uint_33 = 39;
    S1.S1_D1_F1 s1_s1_d1_f1_36 = new S1.S1_D1_F1();
    static int s_loopInvariant = 8;
    public bool LeafMethod0()
    {
        unchecked
        {
            return s_bool_2;
        }
    }
    public S1.S1_D1_F1 LeafMethod15()
    {
        unchecked
        {
            return s1_s1_d1_f1_36;
        }
    }
    public long Method1(uint p_uint_40, out long p_long_41)
    {
        unchecked
        {
            p_long_41 = int_27 %= 15 | 4;
            try
            {
                LeafMethod15();
            }
            catch (System.MethodAccessException)
            {
            }
            finally
            {
                int __loopvar0 = s_loopInvariant, __loopSecondaryVar0_0 = s_loopInvariant;
                do
                {
                    __loopSecondaryVar0_0++;
                    if (__loopSecondaryVar0_0 > 15 + 4)
                        break;
                }
                while (LeafMethod0());
            }
            return 5;
        }
    }
    public void Method0()
    {
        unchecked
        {
            s_long_9 = Method1(uint_33, out s_long_9);
            return;
        }
    }
    public static void Main(string[] args) => Antigen();

    public static void Antigen()
    {
        new TestClass().Method0();
    }
}

@jakobbotsch
Copy link
Member

Oddly I'm still unable to reproduce this. Can you share an SPMI collection if you are able to repro it?

@kunalspathak
Copy link
Member Author

kunalspathak commented Jan 6, 2025

windows.x64.Checked.mch.txt
windows.x64.Checked.mch.mct.txt

Remove the .txt extension from the end. Collected on 6045e29

jakobbotsch added a commit to jakobbotsch/runtime that referenced this issue Jan 6, 2025
@dotnet-policy-service dotnet-policy-service bot added the in-pr There is an active PR which will close this issue when it is merged label Jan 6, 2025
@dotnet-policy-service dotnet-policy-service bot removed untriaged New issue has not been triaged by the area owner labels Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
arch-arm64 area-CodeGen-coreclr CLR JIT compiler in src/coreclr/src/jit and related components such as SuperPMI in-pr There is an active PR which will close this issue when it is merged os-mac-os-x macOS aka OSX
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants