Edit

kc3-lang/angle/src/libANGLE/Overlay_autogen.cpp

Branch :

  • Show log

    Commit

  • Author : Shahbaz Youssefi
    Date : 2019-06-30 03:26:18
    Hash : 050b124d
    Message : Reland "Vulkan: Debug overlay" This is a reland of e54d0f90d1a165404236fd7abd1b05ddd041a686 This was reverted due to a build failure as a result of a missing virtual destructor in the widget base class. Original change's description: > Vulkan: Debug overlay > > A debug overlay system for the Vulkan backend designed with efficiency > and runtime configurability in mind. Overlay widgets are of two > fundamental types: > > - Text widgets: A single line of text with small, medium or large font. > - Graph widgets: A bar graph of data. > > Built on these, various overlay widget types are defined that gather > statistics. Five such types are defined with one widget per type as > example: > > - Count: A widget that counts something. VulkanValidationMessageCount > is an overlay widget of this type that shows the number of validation > messages received from the validation layers. > - Text: A generic text. VulkanLastValidationMessage is an overlay > widget of this type that shows the last validation message. > - PerSecond: A value that gets reset every second automatically. FPS is > an overlay widget of this type that simply gets incremented on every > swap(). > - RunningGraph: A graph of last N values. VulkanCommandGraphSize is an > overlay of this type. On every vkQueueSubmit, the number of nodes in > the command graph is accumulated. On every present(), the value is > taken as the number of nodes for the whole duration of the frame. > - RunningHistogram: A histogram of last N values. Input values are in > the [0, 1] range and they are ranked to N buckets for histogram > calculation. VulkanSecondaryCommandBufferPoolWaste is an overlay > widget of this type. On vkQueueSubmit, the memory waste from command > buffer pool allocations is recorded in the histogram. > > Overlay font is placed in libANGLE/overlay/ which gen_overlay_fonts.py > processes to create an array of bits, which is processed at runtime to > create the actual font image (an image with 3 layers). > > The overlay widget layout is defined in overlay_widgets.json which > gen_overlay_widgets.py processes to generate an array of widgetss, each > of its respective type, and sets their properties, such as color and > bounding box. The json file allows widgets to align against other > widgets as well as against the framebuffer edges. > > Two compute shaders are implemented to efficiently render the UI: > > - OverlayCull: This shader creates a bitset of Text and Graph widgets > whose bounding boxes intersect a corresponding subgroup processed by > OverlayDraw. This is done only when the enabled overlay widgets are > changed (a feature that is not yet implemented) or the surface is > resized. > - OverlayDraw: Using the bitsets generated by OverlayCull, values that > are uniform for each workgroup (set to be equal to hardware subgroup > size), this shader loops over enabled widgets that can possibly > intersect the pixel being processed and renders and blends in texts > and graphs. This is done once per frame on present(). > > Currently, to enable overlay widgets an environment variable is used. > For example: > > $ export ANGLE_OVERLAY=FPS:VulkanSecondaryCommandBufferPoolWaste > $ ./hello_triangle --use-angle=vulkan > > Possible future work: > > - On Android, add settings in developer options and enable widgets based > on those. > - Spawn a small server in ANGLE and write an application that sends > enable/disable commands remotely. > - Implement overlay for other backends. > > Bug: angleproject:3757 > Change-Id: If9c6974d1935c18f460ec569e79b41188bd7afcc > Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/1729440 > Commit-Queue: Shahbaz Youssefi <syoussefi@chromium.org> > Reviewed-by: Jamie Madill <jmadill@chromium.org> Bug: angleproject:3757 Change-Id: I47915d88b37b6f882c686c2de13fca309a10b572 Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/1780897 Reviewed-by: Jamie Madill <jmadill@chromium.org> Commit-Queue: Shahbaz Youssefi <syoussefi@chromium.org>

  • src/libANGLE/Overlay_autogen.cpp
  • // GENERATED FILE - DO NOT EDIT.
    // Generated by gen_overlay_widgets.py using data from overlay_widgets.json.
    //
    // Copyright 2019 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    // Overlay_autogen.cpp:
    //   Autogenerated overlay widget declarations.
    
    #include "libANGLE/Overlay.h"
    #include "libANGLE/OverlayWidgets.h"
    #include "libANGLE/Overlay_font_autogen.h"
    #include "libANGLE/renderer/driver_utils.h"
    
    namespace gl
    {
    using namespace overlay;
    
    namespace
    {
    int GetFontSize(int fontSize, bool largeFont)
    {
        if (largeFont && fontSize > 0)
        {
            return fontSize - 1;
        }
        return fontSize;
    }
    }  // anonymous namespace
    
    void Overlay::initOverlayWidgets()
    {
        const bool kLargeFont = rx::IsAndroid();
    
        {
            PerSecond *widget = new PerSecond;
            {
                const int32_t fontSize = GetFontSize(kFontLayerMedium, kLargeFont);
                const int32_t offsetX  = 10;
                const int32_t offsetY  = 10;
                const int32_t width    = 12 * kFontGlyphWidths[fontSize];
                const int32_t height   = kFontGlyphHeights[fontSize];
    
                widget->type      = WidgetType::PerSecond;
                widget->fontSize  = fontSize;
                widget->coords[0] = offsetX;
                widget->coords[1] = offsetY;
                widget->coords[2] = offsetX + width;
                widget->coords[3] = offsetY + height;
                widget->color[0]  = 0.498039215686;
                widget->color[1]  = 0.749019607843;
                widget->color[2]  = 1.0;
                widget->color[3]  = 1.0;
            }
            mState.mOverlayWidgets[WidgetId::FPS].reset(widget);
        }
    
        {
            Text *widget = new Text;
            {
                const int32_t fontSize = GetFontSize(kFontLayerSmall, kLargeFont);
                const int32_t offsetX  = 10;
                const int32_t offsetY  = -10;
                const int32_t width    = 150 * kFontGlyphWidths[fontSize];
                const int32_t height   = kFontGlyphHeights[fontSize];
    
                widget->type      = WidgetType::Text;
                widget->fontSize  = fontSize;
                widget->coords[0] = offsetX;
                widget->coords[1] = offsetY - height;
                widget->coords[2] = offsetX + width;
                widget->coords[3] = offsetY;
                widget->color[0]  = 1.0;
                widget->color[1]  = 0.0;
                widget->color[2]  = 0.0;
                widget->color[3]  = 1.0;
            }
            mState.mOverlayWidgets[WidgetId::VulkanLastValidationMessage].reset(widget);
        }
    
        {
            Count *widget = new Count;
            {
                const int32_t fontSize = GetFontSize(kFontLayerSmall, kLargeFont);
                const int32_t offsetX  = 10;
                const int32_t offsetY =
                    mState.mOverlayWidgets[WidgetId::VulkanLastValidationMessage]->coords[1];
                const int32_t width  = 25 * kFontGlyphWidths[fontSize];
                const int32_t height = kFontGlyphHeights[fontSize];
    
                widget->type      = WidgetType::Count;
                widget->fontSize  = fontSize;
                widget->coords[0] = offsetX;
                widget->coords[1] = offsetY - height;
                widget->coords[2] = offsetX + width;
                widget->coords[3] = offsetY;
                widget->color[0]  = 1.0;
                widget->color[1]  = 0.0;
                widget->color[2]  = 0.0;
                widget->color[3]  = 1.0;
            }
            mState.mOverlayWidgets[WidgetId::VulkanValidationMessageCount].reset(widget);
        }
    
        {
            RunningGraph *widget = new RunningGraph(60);
            {
                const int32_t fontSize = GetFontSize(0, kLargeFont);
                const int32_t offsetX  = 10;
                const int32_t offsetY  = 100;
                const int32_t width    = 5 * static_cast<uint32_t>(widget->runningValues.size());
                const int32_t height   = 100;
    
                widget->type      = WidgetType::RunningGraph;
                widget->fontSize  = fontSize;
                widget->coords[0] = offsetX;
                widget->coords[1] = offsetY;
                widget->coords[2] = offsetX + width;
                widget->coords[3] = offsetY + height;
                widget->color[0]  = 0.294117647059;
                widget->color[1]  = 0.78431372549;
                widget->color[2]  = 0.0;
                widget->color[3]  = 0.78431372549;
            }
            mState.mOverlayWidgets[WidgetId::VulkanCommandGraphSize].reset(widget);
            {
                const int32_t fontSize = GetFontSize(kFontLayerSmall, kLargeFont);
                const int32_t offsetX =
                    mState.mOverlayWidgets[WidgetId::VulkanCommandGraphSize]->coords[0];
                const int32_t offsetY =
                    mState.mOverlayWidgets[WidgetId::VulkanCommandGraphSize]->coords[1];
                const int32_t width  = 40 * kFontGlyphWidths[fontSize];
                const int32_t height = kFontGlyphHeights[fontSize];
    
                widget->description.type      = WidgetType::Text;
                widget->description.fontSize  = fontSize;
                widget->description.coords[0] = offsetX;
                widget->description.coords[1] = std::max(offsetY - height, 1);
                widget->description.coords[2] = offsetX + width;
                widget->description.coords[3] = offsetY;
                widget->description.color[0]  = 0.294117647059;
                widget->description.color[1]  = 0.78431372549;
                widget->description.color[2]  = 0.0;
                widget->description.color[3]  = 1.0;
            }
        }
    
        {
            RunningHistogram *widget = new RunningHistogram(50);
            {
                const int32_t fontSize = GetFontSize(0, kLargeFont);
                const int32_t offsetX  = -50;
                const int32_t offsetY  = 100;
                const int32_t width    = 6 * static_cast<uint32_t>(widget->runningValues.size());
                const int32_t height   = 100;
    
                widget->type      = WidgetType::RunningHistogram;
                widget->fontSize  = fontSize;
                widget->coords[0] = offsetX - width;
                widget->coords[1] = offsetY;
                widget->coords[2] = offsetX;
                widget->coords[3] = offsetY + height;
                widget->color[0]  = 1.0;
                widget->color[1]  = 0.78431372549;
                widget->color[2]  = 0.294117647059;
                widget->color[3]  = 0.78431372549;
            }
            mState.mOverlayWidgets[WidgetId::VulkanSecondaryCommandBufferPoolWaste].reset(widget);
            {
                const int32_t fontSize = GetFontSize(kFontLayerSmall, kLargeFont);
                const int32_t offsetX =
                    mState.mOverlayWidgets[WidgetId::VulkanSecondaryCommandBufferPoolWaste]->coords[0];
                const int32_t offsetY =
                    mState.mOverlayWidgets[WidgetId::VulkanSecondaryCommandBufferPoolWaste]->coords[1];
                const int32_t width  = 40 * kFontGlyphWidths[fontSize];
                const int32_t height = kFontGlyphHeights[fontSize];
    
                widget->description.type      = WidgetType::Text;
                widget->description.fontSize  = fontSize;
                widget->description.coords[0] = offsetX;
                widget->description.coords[1] = std::max(offsetY - height, 1);
                widget->description.coords[2] = std::min(offsetX + width, -1);
                widget->description.coords[3] = offsetY;
                widget->description.color[0]  = 1.0;
                widget->description.color[1]  = 0.78431372549;
                widget->description.color[2]  = 0.294117647059;
                widget->description.color[3]  = 1.0;
            }
        }
    }
    
    }  // namespace gl