(Case 1241288) Creating Texture3D asset causes editor crash

This is my 3rd attempt to get this crash through QA, now posting in the forum, which hopefully boosts its chance to get reproduced this time.

Creating a Texture3D asset causes the editor to crash. Please see the attached video, which shows that this works in 2019.3, but causes a crash in 2020.1.

Reproduce

Actual
Unity editor crashes.

Expected
No crash. This used to work in Unity 2019.3.

1 Like

Still hoping for a reply. Is anybody able to reproduce this crash or is it only me?

It’s being looked into by QA. I’'ve asked for a status update.

1 Like

Seems like we’re not really getting further.

I came across a twitter post from @Aras recently, where he shows off new Texture3D preview functionality. So I started to wonder if the crash is related to it.

I found out that I’m actually able to create a Texture3D object, but as soon as I assign it to Selection.activeObject, which I believe would then use the new preview/inspector, the editor goes kaboom.

Is this helping you any further to fix this issue?

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEditor;

class CreateTexture3DTool
{
    static Texture3D s_Texture3D;

    [MenuItem("Test/Create Texture3D in memory")]
    static void DoMenuItem()
    {
        if (s_Texture3D != null)
            Texture3D.DestroyImmediate(s_Texture3D);
        s_Texture3D = null;

        Debug.Log("Before new Texture3D");
        s_Texture3D = new Texture3D(16, 16, 3, TextureFormat.ARGB32, true);
        Debug.Log("After new Texture3D");

        Debug.Log("Before Selection.activeObject = s_Texture3D");
        Selection.activeObject = s_Texture3D; // this is causing a crash
        Debug.Log("After Selection.activeObject = s_Texture3D");
    }
}

From what I can tell: no one here in QA can reproduce your issue. They tried on various GPUs and various driver versions, with “debug allocator” settings etc., but so far no cookie (i.e. no crash). However, no one here had your exact GPU model, AFAIK. So maybe it’s something that for some reason only crashes on your config, but we haven’t been able to find what. :(((

I can offer to test a custom Editor build if that would help. For example if you add additional logs/asserts or whatever you prefer around code that might cause the problem?

What makes me believe it’s Not really a problem with my setup is that it works just fine in unity 2019.3.

Have you tried in the latest beta? I tried to follow your setup in b9, I don’t get crash, not even warning.
However I have a “Custom NUnit” package in my project by default, because some of the packages you and me have depend on it. I’m not sure though if it was the same in b6 which you have showcased here.

BTW, I have a similar issue, which is only reproducible by me and it involves the beta and some packages. In some cases adding/updating the Collaborate package crashes my b8 and b9. Obviously I’m not sure if it has anything to do with your case, it’s just a shoot in the dark.

Yeah well we must have changed something to make it crash on your setup, but so far we can’t reproduce the crash on any of our setups… and the log files for some reason don’t have an actionable stack trace either. Do you have some other windows machine to test locally on (just to get additional input on whether it crashes there or not)?

Hey thanks for the reply!
I haven’t tried the most recent beta, but I’m able to reproduce the crash in Unity 2020.2, so I doubt latest beta fixed it. Good idea with the packages, but today I figured out I’m also able to reproduce the crash without my Texture3D Import Pipeline package and just these two lines of code:

Selection.activeObject = tex; // this is causing a crash```

[quote="Aras, post:8, topic: 787425, username:Aras"]
Do you have some other windows machine to test locally on (just to get additional input on whether it crashes there or not)?
[/quote]
Thanks for the reply too!

Unfortunately I don't. I'm working from home office and only have this one rather outdated machine. Since it seems to work everywhere but on my PC, I guess it would also work if I try it on a different PC.

- It works in 2019.3.
- It does not in 2020.1 and 2020.2.
- I've updated graphics drivers.
- I've DirectX 12.
- DxDiag does not find any problems.
- Perhaps the Feature Levels: 11_0,10_1,10_0,9_3,9_2,9_1 are not sufficient anymore?

The DxDiag report shows several "Not Supported" entries, maybe Unity requires something my hardware does not support now?

```csharp
------------------
System Information
------------------
      Time of this report: 5/19/2020, 20:16:48
             Machine name: removed
               Machine Id: removed
         Operating System: Windows 10 Home 64-bit (10.0, Build 18363) (18362.19h1_release.190318-1202)
                 Language: English (Regional Setting: English)
      System Manufacturer: System manufacturer
             System Model: P5K/EPU
                     BIOS: BIOS Date: 06/19/08 17:02:36 Ver: 08.00.12 (type: BIOS)
                Processor: Intel(R) Core(TM)2 Quad CPU    Q9400  @ 2.66GHz (4 CPUs), ~2.7GHz
                   Memory: 8192MB RAM
      Available OS Memory: 8192MB RAM
                Page File: 6708MB used, 5806MB available
              Windows Dir: C:\WINDOWS
          DirectX Version: DirectX 12
      DX Setup Parameters: Not found
         User DPI Setting: 96 DPI (100 percent)
       System DPI Setting: 96 DPI (100 percent)
          DWM DPI Scaling: Disabled
                 Miracast: Available, no HDCP
Microsoft Graphics Hybrid: Not Supported
DirectX Database Version: Unknown
           DxDiag Version: 10.00.18362.0387 64bit Unicode

------------
DxDiag Notes
------------
      Display Tab 1: No problems found.
        Sound Tab 1: No problems found.
        Sound Tab 2: No problems found.
          Input Tab: No problems found.

--------------------
DirectX Debug Levels
--------------------
Direct3D:    0/4 (retail)
DirectDraw:  0/4 (retail)
DirectInput: 0/5 (retail)
DirectMusic: 0/5 (retail)
DirectPlay:  0/9 (retail)
DirectSound: 0/5 (retail)
DirectShow:  0/6 (retail)

---------------
Display Devices
---------------
           Card name: NVIDIA GeForce GTX 650 Ti
        Manufacturer: NVIDIA
           Chip type: GeForce GTX 650 Ti
            DAC type: Integrated RAMDAC
         Device Type: Full Device (POST)
          Device Key: Enum\PCI\VEN_10DE&DEV_11C6&SUBSYS_426319DA&REV_A1
       Device Status: 0180200A [DN_DRIVER_LOADED|DN_STARTED|DN_DISABLEABLE|DN_NT_ENUMERATOR|DN_NT_DRIVER]
Device Problem Code: No Problem
Driver Problem Code: Unknown
      Display Memory: 6102 MB
    Dedicated Memory: 2007 MB
       Shared Memory: 4095 MB
        Current Mode: 1920 x 1080 (32 bit) (60Hz)
         HDR Support: Not Supported
    Display Topology: Internal
Display Color Space: DXGI_COLOR_SPACE_RGB_FULL_G22_NONE_P709
     Color Primaries: Red(0.630859,0.350586), Green(0.333984,0.620117), Blue(0.156250,0.050781), White Point(0.313477,0.328125)
   Display Luminance: Min Luminance = 0.500000, Max Luminance = 270.000000, MaxFullFrameLuminance = 270.000000
        Monitor Name: Generic PnP Monitor
       Monitor Model: S242HL
          Monitor Id: ACR0216
         Native Mode: 1920 x 1080(p) (60.000Hz)
         Output Type: DVI
Monitor Capabilities: HDR Not Supported
Display Pixel Format: DISPLAYCONFIG_PIXELFORMAT_32BPP
      Advanced Color: Not Supported
         Driver Name: C:\WINDOWS\System32\DriverStore\FileRepository\nv_dispi.inf_amd64_9952681a7bb1dfac\nvldumdx.dll,C:\WINDOWS\System32\DriverStore\FileRepository\nv_dispi.inf_amd64_9952681a7bb1dfac\nvldumdx.dll,C:\WINDOWS\System32\DriverStore\FileRepository\nv_dispi.inf_amd64_9952681a7bb1dfac\nvldumdx.dll,C:\WINDOWS\System32\DriverStore\FileRepository\nv_dispi.inf_amd64_9952681a7bb1dfac\nvldumdx.dll
Driver File Version: 26.21.0014.4587 (English)
      Driver Version: 26.21.14.4587
         DDI Version: 12
      Feature Levels: 11_0,10_1,10_0,9_3,9_2,9_1
        Driver Model: WDDM 2.6
Graphics Preemption: DMA
  Compute Preemption: DMA
            Miracast: Not Supported
      Detachable GPU: No
Hybrid Graphics GPU: Not Supported
      Power P-states: Not Supported
      Virtualization: Paravirtualization
          Block List: No Blocks
  Catalog Attributes: Universal:False Declarative:False
   Driver Attributes: Final Retail
    Driver Date/Size: 4/3/2020 2:00:00 AM, 964544 bytes
         WHQL Logo'd: Yes
     WHQL Date Stamp: Unknown
   Device Identifier: {D7B71E3E-5286-11CF-816B-6D621BC2D735}
           Vendor ID: 0x10DE
           Device ID: 0x11C6
           SubSys ID: 0x426319DA
         Revision ID: 0x00A1
  Driver Strong Name: oem9.inf:0f066de3500239da:Section004:26.21.14.4587:pci\ven_10de&dev_11c6
      Rank Of Driver: 00D12001
         Video Accel:
         DXVA2 Modes: DXVA2_ModeMPEG2_VLD  DXVA2_ModeVC1_D2010  DXVA2_ModeVC1_VLD  DXVA2_ModeH264_VLD_Stereo_Progressive_NoFGT  DXVA2_ModeH264_VLD_Stereo_NoFGT  DXVA2_ModeH264_VLD_NoFGT  DXVA2_ModeHEVC_VLD_Main  DXVA2_ModeMPEG4pt2_VLD_Simple  DXVA2_ModeMPEG4pt2_VLD_AdvSimple_NoGMC
   Deinterlace Caps: {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(YUY2,YUY2) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_PixelAdaptive
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(YUY2,YUY2) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(YUY2,YUY2) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(YUY2,YUY2) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_BOBVerticalStretch
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(UYVY,UYVY) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_PixelAdaptive
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(UYVY,UYVY) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(UYVY,UYVY) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(UYVY,UYVY) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_BOBVerticalStretch
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(YV12,0x32315659) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_PixelAdaptive
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(YV12,0x32315659) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(YV12,0x32315659) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(YV12,0x32315659) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_BOBVerticalStretch
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(NV12,0x3231564e) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_PixelAdaptive
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(NV12,0x3231564e) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(NV12,0x3231564e) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(NV12,0x3231564e) Frames(Prev/Fwd/Back)=(0,0,0) Caps=VideoProcess_YUV2RGB VideoProcess_StretchX VideoProcess_StretchY DeinterlaceTech_BOBVerticalStretch
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(IMC1,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(IMC1,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(IMC1,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(IMC1,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(IMC2,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(IMC2,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(IMC2,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(IMC2,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(IMC3,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(IMC3,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(IMC3,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(IMC3,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(IMC4,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(IMC4,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(IMC4,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(IMC4,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(S340,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(S340,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(S340,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(S340,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {6CB69578-7617-4637-91E5-1C02DB810285}: Format(In/Out)=(S342,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {F9F19DA5-3B09-4B2F-9D89-C64753E3EAAB}: Format(In/Out)=(S342,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {5A54A0C9-C7EC-4BD9-8EDE-F3C75DC4393B}: Format(In/Out)=(S342,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
                     {335AA36E-7884-43A4-9C91-7F87FAF3E37E}: Format(In/Out)=(S342,UNKNOWN) Frames(Prev/Fwd/Back)=(0,0,0) Caps=
        D3D9 Overlay: Supported
             DXVA-HD: Supported
        DDraw Status: Enabled
          D3D Status: Enabled
          AGP Status: Enabled
       MPO MaxPlanes: 1
            MPO Caps: Not Supported
         MPO Stretch: Not Supported
     MPO Media Hints: Not Supported
         MPO Formats: Not Supported
    PanelFitter Caps: Not Supported
PanelFitter Stretch: Not Supported

Have you looked at the crash.dmp file? I hoped it would help or at least gives some ideas where to put additional asserts/printfs.

That’s a good example where having Unity source code access would pay off, then I could just fix it myself or at least add a better error message and don’t desperately need to cry for help. :slight_smile:

Regardless of what we do in the future over Unity source, we should give it to you as thanks for all the great feedback! (and so you can give us the fixes instead of the bugs…) :smile:

5 Likes

@Peter77 I sent you a build with additional logging around Texture3D creation via your bug report.

3 Likes

Thanks so much for the help! I’ve updated Case 1241288 with the crash.dmp and editor.log files, I used this code to reproduce the crash.

Please note the crash does not seem to occur while creating the Texture3D:
var tex = new Texture3D(16, 16, 3, TextureFormat.ARGB32, true); // works fine

… but after assigning it to the selection:
Selection.activeObject = tex; // this is causing a crash

… and this also does not crash immediately at that line. The Debug.Log after that line still occurs. If I remove the selection assignment and only create the Texture3D object, it does not crash.

@Aras I’m pretty confident it’s related to the Inspector. If I close the Inspector window and execute this code:

var tex = new Texture3D(16, 16, 3, TextureFormat.ARGB32, true);
Selection.activeObject = tex;

… no crash.

If I then open an Inspector window, the crash occurs:

The crash occurs, because Selection.activeObject still points to the created Texture3D object and the Inspector tries to display it or something related to it.

Ha! Yeah I just answered with the same theory to your bug report. Pretty sure now indeed, that the actual cause of crash is something related to preview. Now just need to figure out what, why and fix it. Thanks for the patience so far! I’ll try to think of something. But that’s tomorrow :wink:

2 Likes

In the mean time I have tested this problem on an Intel UHD 620 and on a Geforce MX150 (Razor Blade laptop). Neither had crashed, unfortunately. (Attached my dxdiag if you want to compare)

5877619–625813–DxDiag.txt (14.1 KB)

1 Like

Alright! So far it seems that Texture3D is not directly related. The actual bug reason is that Graphics.DrawProceduralNow regressed and crashes on old Intel CPUs (pre-SSE4.2). The texture inspector in 2020.1 happens to use that and triggers the crash, but otherwise the bug is not related to textures, shaders or GPU at all. I’ll fix! Thaks @Peter77 for patience tracking it down.

4 Likes

I’m super grateful that you looked into it and I know from first hand experience that fixing bugs can be awful to impossible if you can’t reproduce it locally. So this wasn’t a problem at all for me. I actually think you found the issue really fast.

1 Like

Alright, the fix should ship in 2020.2.0a13, 2020.1.0b11 and 2019.3.16 soon.

4 Likes