New issue
Advanced search Search tips
Note: Color blocks (like or ) mean that a user may not be available. Tooltip shows the reason.

Issue 914495 link

Starred by 1 user

Issue metadata

Status: Fixed
Owner:
Closed: Dec 18
Cc:
Components:
EstimatedDays: ----
NextAction: ----
OS: Mac
Pri: 2
Type: Bug

Blocking:
issue 900941



Sign in to add a comment

viz_unittests RendererPixelTest/2.* failed on mac

Project Member Reported by penghuang@chromium.org, Dec 12

Issue description

Reproduce steps:

1. apply cl https://crrev.com/c/1374516
2. ninja -C out/Release viz_unittests
3. ./out/Release/viz_unittests --gtest_filter=RendererPixelTest/2.*

The log:
Note: Google Test filter = RendererPixelTest/2.SimpleGreenRect
[==========] Running 1 test from 1 test case.
[----------] Global test environment set-up.
[----------] 1 test from RendererPixelTest/2, where TypeParam = <type>
[ RUN      ] RendererPixelTest/2.SimpleGreenRect
[74999:775:1212/151942.088980:18077524755906:ERROR:skia_output_surface_impl.cc(260)] Not implemented reached in virtual void viz::SkiaOutputSurfaceImpl::EnsureBackbuffer()
[74999:7939:1212/151942.107833:18077543599782:ERROR:GrGLGpu.cpp(2342)] GrGLGpu::flushRenderTarget glCheckFramebufferStatus 8cd7

[74999:775:1212/151942.144919:18077580687271:ERROR:pixel_comparator.cc(47)] Number of pixel with an error: 40000
[74999:775:1212/151942.144979:18077580743212:ERROR:pixel_comparator.cc(48)] Error Bounding Box : 0,0 200x200
[74999:775:1212/151942.157390:18077593157558:ERROR:pixel_test_utils.cc(74)] Pixels do not match!
[74999:775:1212/151942.157456:18077593220463:ERROR:pixel_test_utils.cc(75)] Actual: 
[74999:775:1212/151942.157484:18077593248427:ERROR:pixel_test_utils.cc(76)] Expected: 
../../components/viz/service/display/renderer_pixeltest.cc:933: Failure
Value of: this->RunPixelTest(&pass_list, base::FilePath(FILE_PATH_LITERAL("green.png")), cc::ExactPixelComparator(true))
  Actual: false
Expected: true
Stack trace:
0   libbase.dylib                       0x000000010bdd1ada base::debug::StackTrace::StackTrace() + 26
1   viz_unittests                       0x0000000107bed6aa StackTraceGetter::CurrentStackTrace(int, int) + 90
2   viz_unittests                       0x0000000107bfd237 testing::internal::UnitTestImpl::CurrentOsStackTraceExceptTop(int) + 71
3   viz_unittests                       0x0000000107bfcd11 testing::internal::AssertHelper::operator=(testing::Message const&) const + 145
4   viz_unittests                       0x00000001079b8bb8 viz::(anonymous namespace)::RendererPixelTest_SimpleGreenRect_Test<viz::SkiaRenderer>::TestBody() + 552

[74999:7939:1212/151942.223294:18077659059881:FATAL:gl_context.cc(337)] Check failed: error == GL_NO_ERROR || error == GL_CONTEXT_LOST_KHR. GL error was: 1286
0   libbase.dylib                       0x000000010c0e8863 base::debug::StackTrace::StackTrace(unsigned long) + 83
1   libbase.dylib                       0x000000010c0e891d base::debug::StackTrace::StackTrace(unsigned long) + 29
2   libbase.dylib                       0x000000010bdd1ada base::debug::StackTrace::StackTrace() + 26
3   libbase.dylib                       0x000000010be1945e logging::LogMessage::~LogMessage() + 142
4   libbase.dylib                       0x000000010be18255 logging::LogMessage::~LogMessage() + 21
5   libgl_wrapper.dylib                 0x000000011d1a44bf gl::GLContext::MakeVirtuallyCurrent(gl::GLContext*, gl::GLSurface*) + 1023
6   libgles2.dylib                      0x000000011b8c2e4a gpu::GLContextVirtual::MakeCurrent(gl::GLSurface*) + 138
7   libgl_in_process_context.dylib      0x000000011cac58d5 gpu::InProcessCommandBuffer::DestroyOnGpuThread() + 581
8   libgl_in_process_context.dylib      0x000000011cae14ed bool base::internal::FunctorTraits<bool (gpu::InProcessCommandBuffer::*)(), void>::Invoke<bool (gpu::InProcessCommandBuffer::*)(), gpu::InProcessCommandBuffer*>(bool (gpu::InProcessCommandBuffer::*)(), gpu::InProcessCommandBuffer*&&) + 125
9   libgl_in_process_context.dylib      0x000000011cae1431 bool base::internal::InvokeHelper<false, bool>::MakeItSo<bool (gpu::InProcessCommandBuffer::*)(), gpu::InProcessCommandBuffer*>(bool (gpu::InProcessCommandBuffer::*&&)(), gpu::InProcessCommandBuffer*&&) + 81
10  libgl_in_process_context.dylib      0x000000011cae1385 bool base::internal::Invoker<base::internal::BindState<bool (gpu::InProcessCommandBuffer::*)(), base::internal::UnretainedWrapper<gpu::InProcessCommandBuffer> >, bool ()>::RunImpl<bool (gpu::InProcessCommandBuffer::*)(), std::__1::tuple<base::internal::UnretainedWrapper<gpu::InProcessCommandBuffer> >, 0ul>(bool (gpu::InProcessCommandBuffer::*&&)(), std::__1::tuple<base::internal::UnretainedWrapper<gpu::InProcessCommandBuffer> >&&, std::__1::integer_sequence<unsigned long, 0ul>) + 85
11  libgl_in_process_context.dylib      0x000000011cae126e base::internal::Invoker<base::internal::BindState<bool (gpu::InProcessCommandBuffer::*)(), base::internal::UnretainedWrapper<gpu::InProcessCommandBuffer> >, bool ()>::RunOnce(base::internal::BindStateBase*) + 62
12  libgl_in_process_context.dylib      0x000000011cae1d8c base::OnceCallback<bool ()>::Run() && + 92
13  libgl_in_process_context.dylib      0x000000011cae1d14 base::OnceCallback<void ()> gpu::(anonymous namespace)::WrapTaskWithResult<bool>(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::'lambda'(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::operator()(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*) const + 36
14  libgl_in_process_context.dylib      0x000000011cae1ca5 void base::internal::FunctorTraits<base::OnceCallback<void ()> gpu::(anonymous namespace)::WrapTaskWithResult<bool>(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::'lambda'(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*), void>::Invoke<base::OnceCallback<void ()> gpu::(anonymous namespace)::WrapTaskWithResult<bool>(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::'lambda'(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*), base::OnceCallback<bool ()>, bool*, base::WaitableEvent*>(bool&&, base::OnceCallback<bool ()>&&, bool*&&, base::WaitableEvent*&&) + 117
15  libgl_in_process_context.dylib      0x000000011cae1b3c void base::internal::InvokeHelper<false, void>::MakeItSo<base::OnceCallback<void ()> gpu::(anonymous namespace)::WrapTaskWithResult<bool>(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::'lambda'(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*), base::OnceCallback<bool ()>, bool*, base::WaitableEvent*>(bool&&, base::OnceCallback<bool ()>&&, bool*&&, base::WaitableEvent*&&) + 92
16  libgl_in_process_context.dylib      0x000000011cae1ab4 void base::internal::Invoker<base::internal::BindState<base::OnceCallback<void ()> gpu::(anonymous namespace)::WrapTaskWithResult<bool>(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::'lambda'(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*), base::OnceCallback<bool ()>, bool*, base::WaitableEvent*>, void ()>::RunImpl<base::OnceCallback<void ()> gpu::(anonymous namespace)::WrapTaskWithResult<bool>(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::'lambda'(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*), std::__1::tuple<base::OnceCallback<bool ()>, bool*, base::WaitableEvent*>, 0ul, 1ul, 2ul>(bool&&, std::__1::tuple<base::OnceCallback<bool ()>, bool*, base::WaitableEvent*>&&, std::__1::integer_sequence<unsigned long, 0ul, 1ul, 2ul>) + 132
17  libgl_in_process_context.dylib      0x000000011cae194e base::internal::Invoker<base::internal::BindState<base::OnceCallback<void ()> gpu::(anonymous namespace)::WrapTaskWithResult<bool>(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*)::'lambda'(base::OnceCallback<bool ()>, bool*, base::WaitableEvent*), base::OnceCallback<bool ()>, bool*, base::WaitableEvent*>, void ()>::RunOnce(base::internal::BindStateBase*) + 62
18  libbase.dylib                       0x000000010bd9379c base::OnceCallback<void ()>::Run() && + 92
19  libbase.dylib                       0x000000010bdd30f9 base::debug::TaskAnnotator::RunTask(char const*, base::PendingTask*) + 729
20  libbase.dylib                       0x000000010be5da3c base::MessageLoopImpl::RunTask(base::PendingTask*) + 796
21  libbase.dylib                       0x000000010be5deb9 base::MessageLoopImpl::DeferOrRunPendingTask(base::PendingTask) + 89
22  libbase.dylib                       0x000000010be5e967 base::MessageLoopImpl::DoWork() + 455
23  libbase.dylib                       0x000000010be6804e base::MessagePumpDefault::Run(base::MessagePump::Delegate*) + 78
24  libbase.dylib                       0x000000010be5d2a0 base::MessageLoopImpl::Run(bool) + 512
25  libbase.dylib                       0x000000010bf0c7fd base::RunLoop::Run() + 525
26  libbase.dylib                       0x000000010c036929 base::Thread::Run(base::RunLoop*) + 393
27  libbase.dylib                       0x000000010c0370a3 base::Thread::ThreadMain() + 1107
28  libbase.dylib                       0x000000010c10ee60 base::(anonymous namespace)::ThreadFunc(void*) + 192
29  libsystem_pthread.dylib             0x00007fff5763b661 _pthread_body + 340
30  libsystem_pthread.dylib             0x00007fff5763b50d _pthread_body + 0
31  libsystem_pthread.dylib             0x00007fff5763abf9 thread_start + 13

[74998:21255:1212/151942.287781:18077723560538:ERROR:kill_posix.cc(84)] Unable to terminate process group 74999: No such process (3)
[1/1] RendererPixelTest/2.SimpleGreenRect (CRASHED)
1 test crashed:
    RendererPixelTest/2.SimpleGreenRect (../../components/viz/service/display/renderer_pixeltest.cc:916)
Tests took 0 seconds.

 
Description: Show this description
Description: Show this description
Description: Show this description
Components: Internals>Services>Viz
Owner: penghuang@chromium.org
Status: Assigned (was: Untriaged)
Reassigning to viz.
Description: Show this description
Blocking: 900941
Cc: robertphillips@chromium.org
Labels: -Pri-3 Pri-2
Owner: egdaniel@chromium.org
I though the problem is because gl context state is modified by chrome, and GrContext isn't reset before calling skia methods. So I tired adding extra GrContext reset call before calling skia methods, but it problem still happens. So I am guessing this is an issue in skia.

Hi Greg or Robert, could you please take a look? Thanks.
Cc: egdaniel@chromium.org
Owner: penghuang@chromium.org
So I don't think resetting the context will effect whether or not a gl framebuffer is incomplete or not.

Can you do some debugging and investigation into where the framebuffer is coming from. I'm guessing you are wrapping a framebuffer into an SkSurface?

If so, can you check the framebuffer status at the time you originaly give it Skia? I believe skia never adds attachments to wrapped framebuffers, so I assume if it is complete when you give us the framebuffer it should stay complete.

If I had to guess I would imagine this has something more to do with using virtual contexts and possibly trying to share framebuffers across them?
Thanks for the hints. I did some investigation, the results are:
1. incomplete framebuffer error is happen during GrContext::flush() at [1].
2. Before the flush, chrome issued draw ddl operation on SkiaOutputSurface::surface_
3. SkiaOutputSurface::surface_ is an offscreen GLSurface for viz_unittests. It is an EGLSurface on Mac created at [2].
4. Also I verified the error in GrGLGpu::flushRenderTargetNoColorWrite(), the target->renderFBOID() is 0. Do you know how a default framebuffer 0 can be incompleted?

[1] https://cs.chromium.org/chromium/src/components/viz/service/display_embedder/skia_output_surface_impl_on_gpu.cc?q=SkiaOutputSurfaceImplOnGpu&sq=package:chromium&g=0&l=218
[2] https://cs.chromium.org/chromium/src/ui/gl/gl_surface_egl.cc?type=cs&q=PbufferGLSurfaceEGL&g=0&l=1651

If I add an extra MakeCurrent(surface_.get()) with the real context(not the virtualized gl context), it fixes the problem. I guess the issue is related to virtualized gl context.
Project Member

Comment 10 by bugdroid1@chromium.org, Dec 18

The following revision refers to this bug:
  https://chromium.googlesource.com/chromium/src.git/+/53776079784e4e76a2673e54b4d2745ac7475415

commit 53776079784e4e76a2673e54b4d2745ac7475415
Author: Jonathan Backer <backer@chromium.org>
Date: Tue Dec 18 22:12:52 2018

Use a FakeOnScreenSurface for unit tests

RendererPixelTests exercise SkiaRenderer and do a readback from
the gl_surface_ in SkiaOutputSurfaceOnGpu. Using a FakeOnScreenSurface
guarantees that GLContextVirtual will always make the surface current.

Bug:  914495 
Change-Id: I1cccad720780307d9e14fe3f6e064ea6fb5327d7
Reviewed-on: https://chromium-review.googlesource.com/c/1382860
Reviewed-by: Peng Huang <penghuang@chromium.org>
Commit-Queue: Peng Huang <penghuang@chromium.org>
Cr-Commit-Position: refs/heads/master@{#617650}
[modify] https://crrev.com/53776079784e4e76a2673e54b4d2745ac7475415/components/viz/service/display_embedder/skia_output_surface_impl_on_gpu.cc
[modify] https://crrev.com/53776079784e4e76a2673e54b4d2745ac7475415/gpu/ipc/in_process_command_buffer.cc
[modify] https://crrev.com/53776079784e4e76a2673e54b4d2745ac7475415/gpu/ipc/service/gles2_command_buffer_stub.cc
[modify] https://crrev.com/53776079784e4e76a2673e54b4d2745ac7475415/gpu/ipc/service/gpu_channel_manager.cc

Status: Fixed (was: Assigned)

Sign in to add a comment