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

« back to all changes in this revision

Viewing changes to src/platforms/mesa/server/display_helpers.cpp

  • Committer: Bileto Bot
  • Date: 2016-08-15 16:28:40 UTC
  • mfrom: (1160.2357.136 0.24)
  • Revision ID: ci-train-bot@canonical.com-20160815162840-98t95gfrcymlrwpc
* New upstream release 0.24.0 (https://launchpad.net/mir/+milestone/0.24.0)
  - ABI summary:
    . mirclient ABI unchanged at 9
    . mirserver ABI bumped to 41
    . mircommon ABI unchanged at 6
    . mirplatform ABI bumped to 12
    . mirprotobuf ABI unchanged at 3
    . mirplatformgraphics ABI bumped to 10
    . mirclientplatform ABI unchanged at 5
    . mirinputplatform ABI unchanged at 5
  - Enhancements:
    . Added a new tool 'mirvanity' which can use a high speed video camera
      to measure client-to-screen latency.
    . Added (build-time) support for desktop full OpenGL servers (disabled
      by default in favor of GLESv2).
    . Introduced new buffer semantics (NBS) and enabled it by default.
    . Avoided using libmirserver in mir_demo_standalone_render_overlays,
      making bringup traces less cluttered.
    . Removed TilingWindowManager from example servers.
    . Added two new mir_*_performance_test tools that are run as part of
      'mir_performance_tests'.
    . Added pointer confinement to the client API.
    . Added new platform supporting software EGLStreams.
    . Added an input platform that the nested server can use.
    . Allow configuration of the application_not_responding_detector
    . Handle server-side keymapping using XKBMapper.
    . Remove the offscreen display.
    . Add callback option to notify shells that the server is about to stop.
    . Add logging for ANativeWindow events on Android.
  - Bugs fixed:
    . usage of std:call_once in mirclient causes TLS collisions with some
      android devices (LP: #1599867)
    . AltGr not working on external keyboards (LP: #1565236)
    . [regression] unity8 fails to start when built with 0.24 series (lp:mir)
      (LP: #1597717)
    . CI failure in MirSurfaceVisibilityEvent.exposed_received_when_surface_
      raised_over_occluding_surface [called twice - over-saturated and active]
      (LP: #1556045)
    . package-built mir_demo_server does not start on device (LP: #1577357)
    . During surface creation, first stream in spec becomes default stream.
      (LP: #1577967)
    . mouse is getting stuck on a phantom edge (LP: #1580774)
    . [testsfail] in MirSurfaceVisibilityEvent.exposed_received_when_surface_
      raised_over_occluding_surface [never called] (LP: #1581385)
    . [enhancement] Add support for full OpenGL compositing (LP: #1420581)
    . [testsfail] ServerSignal.terminate_handler_is_called_for_SIGINT|SIGTERM
      (LP: #1570353)
    . [testsfail] ClientLatency.triple_buffered_client_has_less_than_two_
      frames_latency (LP: #1576690)
    . [testsfail] NestedServer.when_monitor_plugged_in_client_is_notified_of_
      new_display_configuration (LP: #1576760)
    . mir server crashed in what(): drmModeMoveCursor failed (returned -13)
      (LP: #1579630)
    . mirtest-dev is hard to use as the objects used are compiled with LTO
      (LP: #1583536)
    . [testsfail] ClientLogging.reports_performance [Value of: lag]
      (LP: #1583970)
    . [ FAILED ] ClientLogging.reports_performance (Value of: nbuffers)
      (LP: #1584603)
    . [ FAILED ] ClientLogging.reports_performance (Value of: render)
      (LP: #1584605)
    . ClientCredsTestFixture.session_authorizer_receives_pid_of_connecting_
      clients failure (LP: #1587604)
    . Mir on X11 ignores mir::graphics::GLConfig depth & stencil buffer size
      (LP: #1589632)
    . Need to support pointer confinement (LP: #1590099)
    . [tests] given_nested_server_set_base_display_configuration_when_
      monitor_plugged_in_configuration_is_reset fails (LP: #1591354)
    . CI failure in DemoInProcessServerWithStubClientPlatform.surface_
      creation_does_not_leak_fds (LP: #1598802)
    . Screen is squashed/distorted when rotated in Mir-on-X11 (LP: #1577262)
    . --display-report=log shows some invalid uninitialized EGL attribute
      values (LP: #1582066)
    . mir_demo_client_eglplasma falls back to software rendering on i915
      (Intel Atoms), which explains why it's so slow (LP: #1583532)
    . [regression] x11 platform only draws to a small part of the x11 window
      (LP: #1598267)
    . mir ftbfs in yakkety builders (LP: #1600343)
    . Autolanding keeps failing: mock_egl.h:89:7: error: type 'struct
      MockEGL' violates one definition rule [-Werror=odr] (LP: #1603303)
    . [regression] The Super/Windows key doesn't work any more (LP: #1602966)
    . mir_acceptance_tests.bin: double free or corruption (fasttop)
      (LP: #1603114)
    . ftbfs in linking libmir-test-assist.a in xenial+overlay and
      yakkety+overlay (LP: #1601810)
    . [testsfail] failure in NestedInput.on_input_device_state_nested_*
      (LP: #1602646)  
    . mirtest-dev provides an incorrect .pc file (LP: #1603080)
    . mir_test_framework::server_platform_path(), 
      mir_test_framework::server_platform() don't support use in a downstream
      test built against mir-test-assist (LP: #1603091)
    . Servers based on Mir need a hook to execute code when the server is
      closing (LP: #1593655)
    . Android graphics platform doesn't get packaged for arm64 (LP: #157866)
    . memory leaks in unit tests on android (LP: #1253486)
    . Physical "screen" size reported by the X11 backend is same as pixel
      count, fixing dpi to 25.4 (LP: #1596051)
    . Mir build and test failures with gcc-6 and LTO (LP: #1610215)
    . [regression] Trust prompt not shown when starting camera (LP: #1612256)
* No-change rebuild for boost soname change.
    . unity8/libmirclient gives up and terminates prematurely with
      "std::exception::what: disconnected: no new buffers" via
      ExchangeSemantics::submit() (LP: #1506358)

Show diffs side-by-side

added added

removed removed

Lines of Context:
19
19
#include "display_helpers.h"
20
20
#include "drm_close_threadsafe.h"
21
21
 
 
22
#include "kms-utils/drm_mode_resources.h"
 
23
 
22
24
#include "mir/graphics/gl_config.h"
23
25
#include "mir/graphics/egl_error.h"
24
26
#include "mir/udev/wrapper.h"
183
185
 
184
186
int mgmh::DRMHelper::count_connections(int fd)
185
187
{
186
 
    DRMModeResources resources{fd};
 
188
    kms::DRMModeResources resources{fd};
187
189
 
188
190
    int n_connected = 0;
189
 
    resources.for_each_connector([&](DRMModeConnectorUPtr connector)
 
191
    resources.for_each_connector([&](kms::DRMModeConnectorUPtr connector)
190
192
    {
191
193
        if (connector->connection == DRM_MODE_CONNECTED)
192
194
            n_connected++;
321
323
 
322
324
void mgmh::EGLHelper::setup(GBMHelper const& gbm)
323
325
{
 
326
    eglBindAPI(MIR_SERVER_EGL_OPENGL_API);
 
327
 
324
328
    static const EGLint context_attr[] = {
 
329
#if MIR_SERVER_EGL_OPENGL_BIT == EGL_OPENGL_ES2_BIT
325
330
        EGL_CONTEXT_CLIENT_VERSION, 2,
 
331
#endif
326
332
        EGL_NONE
327
333
    };
328
334
 
335
341
 
336
342
void mgmh::EGLHelper::setup(GBMHelper const& gbm, EGLContext shared_context)
337
343
{
 
344
    eglBindAPI(MIR_SERVER_EGL_OPENGL_API);
 
345
 
338
346
    static const EGLint context_attr[] = {
 
347
#if MIR_SERVER_EGL_OPENGL_BIT == EGL_OPENGL_ES2_BIT
339
348
        EGL_CONTEXT_CLIENT_VERSION, 2,
 
349
#endif
340
350
        EGL_NONE
341
351
    };
342
352
 
350
360
void mgmh::EGLHelper::setup(GBMHelper const& gbm, gbm_surface* surface_gbm,
351
361
                            EGLContext shared_context)
352
362
{
 
363
    eglBindAPI(MIR_SERVER_EGL_OPENGL_API);
 
364
 
353
365
    static const EGLint context_attr[] = {
 
366
#if MIR_SERVER_EGL_OPENGL_BIT == EGL_OPENGL_ES2_BIT
354
367
        EGL_CONTEXT_CLIENT_VERSION, 2,
 
368
#endif
355
369
        EGL_NONE
356
370
    };
357
371
 
371
385
    if (egl_display != EGL_NO_DISPLAY) {
372
386
        if (egl_context != EGL_NO_CONTEXT)
373
387
        {
 
388
            eglBindAPI(MIR_SERVER_EGL_OPENGL_API);
374
389
            if (eglGetCurrentContext() == egl_context)
375
390
                eglMakeCurrent(egl_display, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT);
376
391
            eglDestroyContext(egl_display, egl_context);
391
406
bool mgmh::EGLHelper::make_current() const
392
407
{
393
408
    auto ret = eglMakeCurrent(egl_display, egl_surface, egl_surface, egl_context);
 
409
    eglBindAPI(MIR_SERVER_EGL_OPENGL_API);
394
410
    return (ret == EGL_TRUE);
395
411
}
396
412
 
410
426
        EGL_ALPHA_SIZE, 0,
411
427
        EGL_DEPTH_SIZE, depth_buffer_bits,
412
428
        EGL_STENCIL_SIZE, stencil_buffer_bits,
413
 
        EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
 
429
        EGL_RENDERABLE_TYPE, MIR_SERVER_EGL_OPENGL_BIT,
414
430
        EGL_NONE
415
431
    };
416
432
 
440
456
        should_terminate_egl = true;
441
457
    }
442
458
 
443
 
    eglBindAPI(EGL_OPENGL_ES_API);
444
 
 
445
459
    if (eglChooseConfig(egl_display, config_attr, &egl_config, 1, &num_egl_configs) == EGL_FALSE ||
446
460
        num_egl_configs != 1)
447
461
    {