yshui / picom

A lightweight compositor for X11 with animation support
https://picom.app/
Other
4.19k stars 589 forks source link

Awesome becomes all wonky with compton #157

Closed SoniEx2 closed 5 years ago

SoniEx2 commented 5 years ago

// The template below is for reporting bugs. For feature requests and others, feel free to delete irrelevant entries.

Platform

// Example: Ubuntu Desktop 17.04 amd64 Arch Linux

GPU, drivers, and screen setup

// Example: NVidia GTX 670, nvidia-drivers 381.09, two monitors configured side-by-side with xrandr // Please include the version of the video drivers (xf86-video-*) and mesa. // Please also paste the output of glxinfo -B here.

AMD Radeon HD 6970, mesa 19.0.2-1, xf86-video-ati 1:19.0.1-1, single monitor

$ glxinfo -B
name of display: :0
display: :0  screen: 0
direct rendering: Yes
Extended renderer info (GLX_MESA_query_renderer):
    Vendor: X.Org (0x1002)
    Device: AMD CAYMAN (DRM 2.50.0 / 5.0.7-1-ck-ivybridge, LLVM 8.0.0) (0x6718)
    Version: 19.0.2
    Accelerated: yes
    Video memory: 2048MB
    Unified memory: no
    Preferred profile: core (0x1)
    Max core profile version: 4.3
    Max compat profile version: 3.1
    Max GLES1 profile version: 1.1
    Max GLES[23] profile version: 3.1
Memory info (GL_ATI_meminfo):
    VBO free memory - total: 2047 MB, largest block: 2047 MB
    VBO free aux. memory - total: 1021 MB, largest block: 1021 MB
    Texture free memory - total: 2047 MB, largest block: 2047 MB
    Texture free aux. memory - total: 1021 MB, largest block: 1021 MB
    Renderbuffer free memory - total: 2047 MB, largest block: 2047 MB
    Renderbuffer free aux. memory - total: 1021 MB, largest block: 1021 MB
Memory info (GL_NVX_gpu_memory_info):
    Dedicated video memory: 2048 MB
    Total available memory: 3069 MB
    Currently available dedicated video memory: 2047 MB
OpenGL vendor string: X.Org
OpenGL renderer string: AMD CAYMAN (DRM 2.50.0 / 5.0.7-1-ck-ivybridge, LLVM 8.0.0)
OpenGL core profile version string: 4.3 (Core Profile) Mesa 19.0.2
OpenGL core profile shading language version string: 4.30
OpenGL core profile context flags: (none)
OpenGL core profile profile mask: core profile

OpenGL version string: 3.1 Mesa 19.0.2
OpenGL shading language version string: 1.40
OpenGL context flags: (none)

OpenGL ES profile version string: OpenGL ES 3.1 Mesa 19.0.2
OpenGL ES profile shading language version string: OpenGL ES GLSL ES 3.10

Environment

// Tell us something about the desktop environment you are using, for example: i3-gaps, Gnome Shell, etc. Awesome WM 4.3

Compton version

// Put the output of compton --version here. // If you are running compton v4 or later, please also include the output of compton --diagnostics // Example: v1

$ compton --diagnostics
**Version:** v6.2

### Extensions:

* Shape: Yes
* XRandR: Yes
* Present: Present

### Misc:

* Use Overlay: Yes
* Config file used: /home/soniex2/.config/compton.conf

Compton configuration:

// Paste your configuration here
$ cat .config/compton.conf 
# Thank you code_nomad: http://9m.no/ꪯ鵞
# and Arch Wiki contributors: https://wiki.archlinux.org/index.php/Compton

#################################
#
# Backend
#
#################################

# Backend to use: "xrender" or "glx".
# GLX backend is typically much faster but depends on a sane driver.
backend = "glx";

#################################
#
# GLX backend
#
#################################

glx-no-stencil = true;

# GLX backend: Copy unmodified regions from front buffer instead of redrawing them all.
# My tests with nvidia-drivers show a 10% decrease in performance when the whole screen is modified,
# but a 20% increase when only 1/4 is.
# My tests on nouveau show terrible slowdown.
glx-copy-from-front = false;

# GLX backend: Use MESA_copy_sub_buffer to do partial screen update.
# My tests on nouveau shows a 200% performance boost when only 1/4 of the screen is updated.
# May break VSync and is not available on some drivers.
# Overrides --glx-copy-from-front.
# glx-use-copysubbuffermesa = true;

# GLX backend: Avoid rebinding pixmap on window damage.
# Probably could improve performance on rapid window content changes, but is known to break things on some drivers (LLVMpipe).
# Recommended if it works.
# glx-no-rebind-pixmap = true;

# GLX backend: GLX buffer swap method we assume.
# Could be undefined (0), copy (1), exchange (2), 3-6, or buffer-age (-1).
# undefined is the slowest and the safest, and the default value.
# copy is fastest, but may fail on some drivers,
# 2-6 are gradually slower but safer (6 is still faster than 0).
# Usually, double buffer means 2, triple buffer means 3.
# buffer-age means auto-detect using GLX_EXT_buffer_age, supported by some drivers.
# Useless with --glx-use-copysubbuffermesa.
# Partially breaks --resize-damage.
# Defaults to undefined.
#glx-swap-method = "undefined";

#################################
#
# Shadows
#
#################################

# Enabled client-side shadows on windows.
shadow = false;
# The blur radius for shadows. (default 12)
shadow-radius = 0;
# The left offset for shadows. (default -15)
shadow-offset-x = -0;
# The top offset for shadows. (default -15)
shadow-offset-y = -0;
# The translucency for shadows. (default .75)
shadow-opacity = 0.0;

# Set if you want different colour shadows
# shadow-red = 0.0;
# shadow-green = 0.0;
# shadow-blue = 0.0;

# The shadow exclude options are helpful if you have shadows enabled. Due to the way compton draws its shadows, certain applications will have visual glitches
# (most applications are fine, only apps that do weird things with xshapes or argb are affected).
# This list includes all the affected apps I found in my testing. The "! name~=''" part excludes shadows on any "Unknown" windows, this prevents a visual glitch with the XFWM alt tab switcher.
shadow-exclude = [
    "! name~=''",
    "name = 'Notification'",
    "name = 'Plank'",
    "name = 'Docky'",
    "name = 'Kupfer'",
    "name = 'xfce4-notifyd'",
    "name *= 'VLC'",
    "name *= 'compton'",
    "name *= 'Chromium'",
    "name *= 'Chrome'",
    "class_g = 'Firefox' && argb",
    "class_g = 'Conky'",
    "class_g = 'Kupfer'",
    "class_g = 'Synapse'",
    "class_g ?= 'Notify-osd'",
    "class_g ?= 'Cairo-dock'",
    "class_g ?= 'Xfce4-notifyd'",
    "class_g ?= 'Xfce4-power-manager'",
    "_GTK_FRAME_EXTENTS@:c",
    "_NET_WM_STATE@:32a *= '_NET_WM_STATE_HIDDEN'"
];
# Avoid drawing shadow on all shaped windows (see also: --detect-rounded-corners)
shadow-ignore-shaped = false;

#################################
#
# Opacity
#
#################################

inactive-opacity = 1;
active-opacity = 1;
frame-opacity = 1;
inactive-opacity-override = false;

# Dim inactive windows. (0.0 - 1.0)
# inactive-dim = 0.2;
# Do not let dimness adjust based on window opacity.
# inactive-dim-fixed = true;
# Blur background of transparent windows. Bad performance with X Render backend. GLX backend is preferred.
# blur-background = true;
# Blur background of opaque windows with transparent frames as well.
# blur-background-frame = true;
# Do not let blur radius adjust based on window opacity.
blur-background-fixed = false;
blur-background-exclude = [
    "window_type = 'dock'",
    "window_type = 'desktop'"
];

#################################
#
# Fading
#
#################################

# Fade windows during opacity changes.
fading = false;
# The time between steps in a fade in milliseconds. (default 10).
fade-delta = 0;
# Opacity change between steps while fading in. (default 0.028).
fade-in-step = 1.00;
# Opacity change between steps while fading out. (default 0.03).
fade-out-step = 1.00;
# Fade windows in/out when opening/closing
no-fading-openclose = true;

# Specify a list of conditions of windows that should not be faded.
fade-exclude = [ ];

#################################
#
# Other
#
#################################

# Try to detect WM windows and mark them as active.
mark-wmwin-focused = true;
# Mark all non-WM but override-redirect windows active (e.g. menus).
mark-ovredir-focused = true;
# Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused instead of using FocusIn/Out events.
# Usually more reliable but depends on a EWMH-compliant WM.
use-ewmh-active-win = true;
# Detect rounded corners and treat them as rectangular when --shadow-ignore-shaped is on.
detect-rounded-corners = true;

# Detect _NET_WM_OPACITY on client windows, useful for window managers not passing _NET_WM_OPACITY of client windows to frame windows.
# This prevents opacity being ignored for some apps.
# For example without this enabled my xfce4-notifyd is 100% opacity no matter what.
detect-client-opacity = true;

# Specify refresh rate of the screen.
# If not specified or 0, compton will try detecting this with X RandR extension.
refresh-rate = 0;

# Vertical synchronization: match the refresh rate of the monitor
vsync = true;

# Enable DBE painting mode, intended to use with VSync to (hopefully) eliminate tearing.
# Reported to have no effect, though.
dbe = false;

# Limit compton to repaint at most once every 1 / refresh_rate second to boost performance.
# This should not be used with --vsync drm/opengl/opengl-oml as they essentially does --sw-opti's job already,
# unless you wish to specify a lower refresh rate than the actual value.
#sw-opti = true;

# Unredirect all windows if a full-screen opaque window is detected, to maximize performance for full-screen windows, like games.
# Known to cause flickering when redirecting/unredirecting windows.
unredir-if-possible = false;

# Specify a list of conditions of windows that should always be considered focused.
focus-exclude = [ ];

# Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time.
detect-transient = true;
# Use WM_CLIENT_LEADER to group windows, and consider windows in the same group focused at the same time.
# WM_TRANSIENT_FOR has higher priority if --detect-transient is enabled, too.
detect-client-leader = true;

#################################
#
# Window type settings
#
#################################

wintypes:
{
    tooltip =
    {
        # fade: Fade the particular type of windows.
        fade = true;
        # shadow: Give those windows shadow
        shadow = false;
        # opacity: Default opacity for the type of windows.
        opacity = 0.85;
        # focus: Whether to always consider windows of this type focused.
        focus = true;
    };
};

######################
#
# XSync
# See: https://github.com/yshui/compton/commit/b18d46bcbdc35a3b5620d817dd46fbc76485c20d
#
######################

# Use X Sync fence to sync clients' draw calls. Needed on nvidia-drivers with GLX backend for some users.
xrender-sync-fence = true;

Steps of reproduction

// If you can reliably reproduce this bug, please describe the quickest way to do so // This information will greatly help us diagnosing and fixing the issue.

  1. Start awesome 4.3
  2. Start compton
  3. Start something that triggers desktop notifications (but this doesn't happen just with notifications, and doesn't happen every time - sometimes menus get wonky too but it's easiest to trigger with notifications). Tested with quasselclient and awesome-client "error()".
  4. Stop compton, repeat 3.

Expected behavior

Notifications would appear normally.

Current Behavior

Notifications appear corrupted. They appear with 8x8(? didn't actually measure) lines, offset in a pattern. Additionally, these lines also have areas of random stuff on them (uninitialized memory maybe?).

Stack trace

// If compton crashes, please make sure your compton is built with debug info, and provide a stack trace of compton when it crashed. // Note, when compton crashes in a debugger, your screen might look frozen. But gdb will still handle your input if it is focused. // Usually you can use 'bt' and press enter to get the stack trace, then 'q', enter, 'y', enter to quit gdb.

// Or, you can enable core dump, and upload the core file and the compton executable here.

Other details

// If your problem is visual, you are encouraged to record a short video when the problem occurs and link to it here.

SoniEx2 commented 5 years ago

Update: I've also had this issue with the quit dialog from guake, still using awesome WM. Definitely leaning towards compton issue.

yshui commented 5 years ago

Do you have a screenshot?

SoniEx2 commented 5 years ago

if I can figure out how to get github to accept it

SoniEx2 commented 5 years ago

eh, I give up. anyway: <magnet:?xt=urn:btih:551650b47b662f2b49608949c040c91c0c2b7408&dn=1555245493.png&tr=udp%3A%2F%2Ftracker.opentrackr.org%3A1337%2Fannounce>

SoniEx2 commented 5 years ago

imgur won't let me upload either, and additionally imgur is known for adding compression artifacts.

in any case, I am seeding, and I was able to leech onto my phone. if you can't leech, check your ISP, the tracker status, or your DHT settings. it's a fresh torrent so expect it to take a few minutes.

Clyybber commented 5 years ago

Huh, weird. It works now, I have uploaded it here for convenience: https://i.imgur.com/8YZHz8r.png Btw, imgur's compression only kicks in for very large pngs. For smaller ones such as this one it doesn't change the file.

yshui commented 5 years ago

Could be a driver bug. I will ask around.

SoniEx2 commented 5 years ago

Could be a Cairo issue... I believe I've only had the issue with GTK apps and the WM, which as far as I can tell uses Cairo...

Will do more testing with Qt later today.

yshui commented 5 years ago

@SoniEx2 Does this problem happen if you uninstall xf86-video-ati and use Xorg's builtin modesetting driver instead?

SoniEx2 commented 5 years ago

Removing xf86-video-ati has made the issue disappear, or so it seems...

yshui commented 5 years ago

@SoniEx2 So, if you are certain you were indeed using xf86-video-ati version 19.0.1 before (there was a similar problem in 19.0.0 that was fixed in 19.0.1), you can open a bug report here:

https://bugs.freedesktop.org/enter_bug.cgi?product=xorg&component=Driver/Radeon

You should try to include as much information you could, also remember to mention removing xf86-video-ati fixes this problem.

I am going to close this bug since it's likely not a compton bug.