~ci-train-bot/mir/mir-ubuntu-zesty-2683

« back to all changes in this revision

Viewing changes to src/server/graphics/offscreen/display_buffer.cpp

  • Committer: Bileto Bot
  • Date: 2017-04-13 15:26:17 UTC
  • mfrom: (1160.2883.164 0.27)
  • Revision ID: ci-train-bot@canonical.com-20170413152617-bs7slz07xbzxu2d3
* New upstream release 0.27.0 (https://launchpad.net/mir/+milestone/0.27.0)
  - ABI summary:
    . mirclient ABI unchanged at 9
    . mirserver ABI bumped to 44
    . mircommon ABI unchanged at 7
    . mirplatform ABI bumped to 61
    . mirprotobuf ABI unchanged at 3
    . mirplatformgraphics ABI bumped to 13
    . mirclientplatform ABI unchanged at 5
    . mirinputplatform ABI bumped to 7
    . mircore ABI unchanged at 1
  - Enhancements:
    . Mostly groundwork required to support major enhancements coming in
      future Mir versions.
    . Removed android-input and eliminated the entire "3rd_party/" subtree.
      Now the Mir source tree contains original code only.
    . Added mir_prompt_session_new_fds_for_prompt_providers_sync API.
    . mirout: Added load and save options for keeping display configs
      on disk.
    . mirout: Added "--" support for applying configuration changes under
      Unity8.
    . Fixed failure of DRM hardware cursor {hide(); show(image);}
    . Added server option: "--cursor software" (MIR_SERVER_CURSOR=software)
    . Added letterboxing/black bars support to the GL renderer in preparation
      for generic output cloning.
    . Added client API for getting the logical size of an output.
    . Migrated MirCookie to use SHA-256.
    . Ensure RealKMSOutputConfiguration stays in sync with actual hardware
      state.
    . Added support for drag-and-drop.
    . Lots of other client API enhancements.
    . Minor clean-ups, optimizations and dead code removal.
  - Bugs fixed:
    . [enhancement] Make able to get version information from client /
      server APIs (LP: #1195540)
    . Touch screen coordinates don't rotate with the screen (LP: #1349660)
    . Subpixel order not included in Mir display information (LP: #1393578)
    . [enhancement] Missing client API for relative surface movement (e.g.
      dragging client-decorated windows) (LP: #1420334) . Mir does not reset
      key states when paused or resumed (modifiers get stuck after VT
      switching) (LP: #1536279)
    . Inconsistent behaviour of Num Lock (LP: #1588237)
    . [ FAILED ] NestedInput.nested_event_filter_receives_keyboard_from_host
      (LP: #1613523)
    . Rotating an output left or right without restarting the
      compositor distorts the image (LP: #1643488)
    . support display scaling slider in unity8 (LP: #1645372)
    . [ FAILED ] NestedInputWithMouse.mouse_pointer_coordinates_in_nested_
      server_are_accumulated (LP: #1646375)
    . [ FAILED ] NestedInputWithMouse.mouse_pointer_position_is_in_sync_with_
      host_server (LP: #1646558)
    . abi_check doesn't check mircore (LP: #1649354)
    . Under Unity8, mir_demo_client_target is distorted and input in the
      wrong place on start-up (LP: #1655804)
    . [testsfail] PromptSessionClientAPI.client_pid_is_associated_with_
      session hangs and times out (LP: #1655929)
    . EDID does not change when hotplugging a monitor (LP: #1660017)
    . [regression] Mir 0.26.0 - spinner loading animation, minimize, maximize
      too fast (LP: #1661072)
    . [regression] Unity8 stutters constantly (like half frame rate) using
      Mir 0.26.0 (LP: #1661128)
    . [regression] mir_demo_server refuses to quit on Ctrl+Alt+Backspace or
      Ctrl+C in its terminal (deadlock in DefaultInputDeviceHub::add_device)
      (LP: #1661151)
    . [regression] mirout crashes when connecting to unity8 or any nested
      server: [libprotobuf FATAL
      /usr/include/google/protobuf/repeated_field.h:1408] CHECK failed:
      (index) < (current_size_): (LP: #1661163)
    . [ FAILED ] DefaultInputManagerTest.forwards_pause_continue_state_
      changes_to_platform (LP: #1661187)
    . [regression] Segfault on detect_fd_leaks during acceptance tests (in
      DisplayConfiguration/{DisplayFormatSetting,DisplaySubpixelSetting})
      (LP: #1661498)
    . [regression] Nested server segfaults or rapidly logs exceptions when a
      fullscreen client starts [in mir_presentation_chain_set_dropping_mode
      ... std::exception::what: Operation not permitted] (LP: #1661508)
    . [regression] Windowed clients of nested servers are all black
      (LP: #1661521)
    . mir_window_request_persistent_id_sync seg faults when called twice
      (LP: #1661704)
    . mir_acceptance_tests now takes 10 seconds longer (in r4002 compared to
      r4001) (LP: #1662044)
    . Mir graphics platform ABI broke in series 0.26 but sonames never
      changed (LP: #1662455)
    . libmirclient-dev missing build depndency on libmircore-dev
      (LP: #1662942)
    . [regression] mirscreencast hangs during screencast creation
      (LP: #1662997)
    . [regression] Software clients of nested servers with size >=480x480
      are all black in Mir 0.25.0 and later (or stretched and distorted under
      Unity8) (LP: #1663062)
    . mir_window_spec_set_cursor_name() doesn't trigger
      mir::scene::SurfaceObserver::cursor_image_set_to (LP: #1663197)
    . android complaint during mirscreencast of nested server (LP: #1664562)
    . qtubuntu sends wrong text as part of QKeyEvent (LP: #1664610)
    . Mir server crashed with SIGSEGV in
      mir::compositor::TemporaryBuffer::size() called from
      mir::gl::tessellate_renderable_into_rectangle() (LP: #1664760)
    . mirout reports logical size of a rotated display incorrectly
      (LP: #1665271)
    . Nested servers (Unity8) periodically stutter (half frame rate) with
      Mir 0.26.1 (LP: #1666372)
    . If the only surface in a session cannot take focus the server crashes
      (LP: #1667645)
    . [regression] OSK input shaping no longer works correctly (LP: #1669444)
    . GTK window functions `Always on Top, Move and Resize' don't work in
      Mir/Unity8 (LP: #1669524)
    . [regression] mir_proving_server mode hotkeys (Ctrl+Alt+=/-) cause the
      server to segfault (LP: #1669752)
    . Test takes minutes to complete: MediatingDisplayChangerTest.confirmed_
      configuration_doesnt_revert_after_timeout (LP: #1671033)
    . [ FAILED ] PosixRWMutex.prefer_writer_nonrecursive_prevents_writer_
      starvation (Timeout waiting to acquire write lock) (LP: #1671037)
    . [regression] Mixing screen rotation with mode changes makes the image
      squished (LP: #1672269)
    . unity-system-compositor crashed with SIGSEGV in
      libinput_device_config_accel_is_available() from
      libinput_device_config_accel_set_speed() from
      mir::input::evdev::LibInputDevice::apply_settings() (LP: #1672955)
    . Presentation chains should support various Vulkan presentation modes
      (LP: #1673533)
    . Need an extension for GBM buffers to replace
      mir_buffer_get_buffer_package() (LP: #1673534)
    . cross-compile-chroot.sh (to zesty) fails to build [cannot find -ludev]
      due to libudev.so being in a different directory to where libudev.pc
      searches for it (LP: #1674201)
    . Please transition to Boost 1.62 (LP: #1675138)
    . [regression] Mir is assigning the first output ID = 0 (==
      mir_display_output_id_invalid) (LP: #1675331)
    . Mir sending key repeat events continually to nested shell after VT
      switch (causes Unity8 lockup for a while) (LP: #1675357)
    . mirout commands don't work when followed by -- (LP: #1676320)
    . mir_demo_standalone_render_overlays fails to link (LP: #1677239)
    . [regression] doxygen processing for capnproto/protobuf broken
      (LP: #1679248)
    . mir_window_spec_set_cursor_render_surface does not work (LP: #1679836)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright © 2013 Canonical Ltd.
 
3
 *
 
4
 * This program is free software: you can redistribute it and/or modify it
 
5
 * under the terms of the GNU General Public License version 3,
 
6
 * as published by the Free Software Foundation.
 
7
 *
 
8
 * This program is distributed in the hope that it will be useful,
 
9
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
11
 * GNU General Public License for more details.
 
12
 *
 
13
 * You should have received a copy of the GNU General Public License
 
14
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
15
 *
 
16
 * Authored by: Alexandros Frantzis <alexandros.frantzis@canonical.com>
 
17
 */
 
18
 
 
19
#include "display_buffer.h"
 
20
#include "mir/graphics/gl_extensions_base.h"
 
21
#include "mir/raii.h"
 
22
 
 
23
#include <boost/throw_exception.hpp>
 
24
#include <stdexcept>
 
25
 
 
26
#include MIR_SERVER_GL_H
 
27
#include MIR_SERVER_GLEXT_H
 
28
 
 
29
namespace mg = mir::graphics;
 
30
namespace mgo = mg::offscreen;
 
31
namespace geom = mir::geometry;
 
32
 
 
33
namespace
 
34
{
 
35
 
 
36
class GLExtensions : public mg::GLExtensionsBase
 
37
{
 
38
public:
 
39
    GLExtensions() :
 
40
        mg::GLExtensionsBase{
 
41
            reinterpret_cast<char const*>(glGetString(GL_EXTENSIONS))}
 
42
    {
 
43
    }
 
44
};
 
45
 
 
46
}
 
47
 
 
48
mgo::detail::GLFramebufferObject::GLFramebufferObject(geom::Size const& size)
 
49
    : size{size}, color_renderbuffer{0}, depth_renderbuffer{0}, fbo{0}
 
50
{
 
51
    /* Save previous FBO state */
 
52
    glGetIntegerv(GL_FRAMEBUFFER_BINDING, &old_fbo);
 
53
    glGetIntegerv(GL_VIEWPORT, old_viewport);
 
54
 
 
55
    GLExtensions const extensions;
 
56
 
 
57
    GLenum gl_color_format{GL_RGBA4};
 
58
    GLenum const gl_depth_format{GL_DEPTH_COMPONENT16};
 
59
 
 
60
#ifdef GL_RGBA8_OES
 
61
    if (extensions.support("GL_ARM_rgba8") ||
 
62
        extensions.support("GL_OES_rgb8_rgba8"))
 
63
    {
 
64
        gl_color_format = GL_RGBA8_OES;
 
65
    }
 
66
#endif
 
67
 
 
68
    /* Create a renderbuffer for the color attachment */
 
69
    glGenRenderbuffers(1, &color_renderbuffer);
 
70
    glBindRenderbuffer(GL_RENDERBUFFER, color_renderbuffer);
 
71
    glRenderbufferStorage(GL_RENDERBUFFER, gl_color_format,
 
72
                          size.width.as_int(), size.height.as_int());
 
73
 
 
74
    /* Create a renderbuffer for the depth attachment */
 
75
    glGenRenderbuffers(1, &depth_renderbuffer);
 
76
    glBindRenderbuffer(GL_RENDERBUFFER, depth_renderbuffer);
 
77
    glRenderbufferStorage(GL_RENDERBUFFER, gl_depth_format,
 
78
                          size.width.as_int(), size.height.as_int());
 
79
 
 
80
    /* Create a FBO and set it up */
 
81
    glGenFramebuffers(1, &fbo);
 
82
 
 
83
    auto const fbo_raii = mir::raii::paired_calls(
 
84
        [this] { glBindFramebuffer(GL_FRAMEBUFFER, fbo); },
 
85
        [this] { glBindFramebuffer(GL_FRAMEBUFFER, old_fbo); });
 
86
 
 
87
    glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0,
 
88
                              GL_RENDERBUFFER, color_renderbuffer);
 
89
    glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT,
 
90
                              GL_RENDERBUFFER, depth_renderbuffer);
 
91
 
 
92
    if (glCheckFramebufferStatus(GL_FRAMEBUFFER) != GL_FRAMEBUFFER_COMPLETE)
 
93
        BOOST_THROW_EXCEPTION(std::runtime_error("Failed to set up FBO"));
 
94
}
 
95
 
 
96
mgo::detail::GLFramebufferObject::~GLFramebufferObject()
 
97
{
 
98
    if (fbo)
 
99
        glDeleteFramebuffers(1, &fbo);
 
100
    if (color_renderbuffer)
 
101
        glDeleteRenderbuffers(1, &color_renderbuffer);
 
102
    if (depth_renderbuffer)
 
103
        glDeleteRenderbuffers(1, &depth_renderbuffer);
 
104
}
 
105
 
 
106
void mgo::detail::GLFramebufferObject::bind() const
 
107
{
 
108
    glBindFramebuffer(GL_FRAMEBUFFER, fbo);
 
109
    glViewport(0, 0, size.width.as_int(), size.height.as_int());
 
110
}
 
111
 
 
112
void mgo::detail::GLFramebufferObject::unbind() const
 
113
{
 
114
    glBindFramebuffer(GL_FRAMEBUFFER, old_fbo);
 
115
    glViewport(old_viewport[0], old_viewport[1],
 
116
               old_viewport[2], old_viewport[3]);
 
117
}
 
118
 
 
119
mgo::DisplayBuffer::DisplayBuffer(SurfacelessEGLContext egl_context,
 
120
                                  geom::Rectangle const& area)
 
121
    : egl_context{std::move(egl_context)},
 
122
      fbo{area.size},
 
123
      area(area)
 
124
{
 
125
}
 
126
 
 
127
geom::Rectangle mgo::DisplayBuffer::view_area() const
 
128
{
 
129
    return area;
 
130
}
 
131
 
 
132
void mgo::DisplayBuffer::make_current()
 
133
{
 
134
    egl_context.make_current();
 
135
}
 
136
 
 
137
void mgo::DisplayBuffer::bind()
 
138
{
 
139
    fbo.bind();
 
140
}
 
141
 
 
142
void mgo::DisplayBuffer::release_current()
 
143
{
 
144
    fbo.unbind();
 
145
    egl_context.release_current();
 
146
}
 
147
 
 
148
void mgo::DisplayBuffer::swap_buffers()
 
149
{
 
150
    glFinish();
 
151
}
 
152
 
 
153
bool mgo::DisplayBuffer::overlay(RenderableList const&)
 
154
{
 
155
    return false;
 
156
}
 
157
 
 
158
glm::mat2 mgo::DisplayBuffer::transformation() const
 
159
{
 
160
    return glm::mat2{};
 
161
}
 
162
 
 
163
mg::NativeDisplayBuffer* mgo::DisplayBuffer::native_display_buffer()
 
164
{
 
165
    return this;
 
166
}