Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fullscreen doesn't pillarbox games in fullscreen mode on KDE 6.2 #1608

Open
3 of 6 tasks
KayJay7 opened this issue Nov 1, 2024 · 18 comments
Open
3 of 6 tasks

Fullscreen doesn't pillarbox games in fullscreen mode on KDE 6.2 #1608

KayJay7 opened this issue Nov 1, 2024 · 18 comments

Comments

@KayJay7
Copy link

KayJay7 commented Nov 1, 2024

Is there an existing issue for this?

  • I have searched the existing issues

Are you using any gamescope patches or a forked version of gamescope?

  • The issue occurs on upstream gamescope without any modifications

Current Behavior

The main way I use gamescope is to force pillarboxing on games that need it but don't implement it (e.g. Terraria). I cannot pinpoint when it happened (but I can tell it worked in June) but now gamescope doesn't pillarbox anymore, it just shows the game windows in the upper left corner of the screen, like if it was just a borderless window that doesn't cover the whole screen.

Examples:

Screenshot_20241101_103731

Screenshot_20241101_103832

I do not think it's an issue with kde, because other fullscreen applications work correctly with pillarboxing. For example, here is Quantum Break in fullscreen pillarboxed:

Screenshot_20241101_104253

I have tried both the Wayland and SDL backend, but for some reason the SDL one fails to start. Also, I have tried various combination of commands: with different -S parameters, with -b etc. I'm reporting one of the simpler ones

For some reason, I'm not able to replicate the issue on vkcube or glxgears from terminal. I'm running gamescope -h 100 -w 100 -W 2560 -H 1080 -S integer -F pixel -f -- vkcube and it works as expected. It scales to 1000x1000 and adds black borders.

Steps To Reproduce

  1. Launch Terraria from Steam with gamescope -h 1080 -w 1920 -H 1080 -W 2560 -f -- %command% on latest KDE
    • The nested resolution needs to be smaller than the real resolution
  2. The game window will not be pillarboxed correctly

Hardware information

- Distro: Fedora 40
- CPU: AMD Ryzen R7 7700x
- GPU: AMD Radeon Vega 56
- Driver Version: Mesa 24.1.7

Software information

- Desktop environment: KDE 6.2.2
- Session type: Wayland
- Gamescope version: ?
	* The output of `gamescope --version` is missing the version number `gamescope version  (gcc 14.2.1)`
	* Dnf reports version 3.15.13
- Gamescope launch command(s): `gamescope -h 1080 -w 1920 -H 1080 -W 2560 -f -- %command%`

Which gamescope backends have the issue you are reporting?

  • Wayland (default for nested gamescope)
  • DRM (default for embedded gamescope, i.e. gamescope-session)
  • SDL
  • OpenVR

Logging, screenshots, or anything else

Same screenshot as before:

Screenshot_20241101_103731

Screenshot_20241101_103832

It even causes a weird effect with mangohud where it overflows from the window, while usually it's cropped at the window borders

Screenshot_20241101_103819

image

@KayJay7
Copy link
Author

KayJay7 commented Nov 1, 2024

I tried on a different system, with an Intel graphics UHD 620 (a Thinkpad t480s), and with Gnome 46, pillarboxing works as expected

@Eckoa
Copy link

Eckoa commented Nov 2, 2024

Forcing composition or using sdl will work around it

Likely the same as this issue
#1177

@Kontrabant
Copy link

Kontrabant commented Nov 3, 2024

This is probably related to this bug.

In short, the Wayland xdg_toplevel spec says that compositor is supposed to center and mask fullscreen surfaces that don't cover the entire output. KDE/KWin doesn't do this.

@KayJay7
Copy link
Author

KayJay7 commented Nov 3, 2024

This is probably related to this bug.

In short, the Wayland xdg_toplevel spec says that compositor is supposed to center and mask fullscreen surfaces that don't cover the entire output. KDE/KWin doesn't do this.

That bug seems to predate KDE 6, while my problem wasn't present a couple of months ago

@matte-schwartz
Copy link

@KayJay7 do you know have any idea if it was a plasma update or a Gamescope update that changed the behavior? Or is it unclear. I tried to reproduce this yesterday on Arch and was unable to, Plasma 6.2.2 and Gamescope 3.15.14

@KayJay7
Copy link
Author

KayJay7 commented Nov 3, 2024

@KayJay7 do you know have any idea if it was a plasma update or a Gamescope update that changed the behavior? Or is it unclear. I tried to reproduce this yesterday on Arch and was unable to, Plasma 6.2.2 and Gamescope 3.15.14

Unfortunately I do not, I haven't used gamescope in a few months, in the meantime plasma has been updated a couple times.

Later this evening I might be able to find a more precise timespan without using gamescope, and check if there's been any gamescope update in that span.

@KayJay7
Copy link
Author

KayJay7 commented Nov 3, 2024

@matte-schwartz So, I'm 100% sure it worked on July 11 and a few days laters (which is when I used it for rain world). Unfortunately, since then gamescope updated three times including one week ago. So I cannot say whether it was a gamescope or plasma update that caused the issue.

@matte-schwartz
Copy link

Fedora, right? I'll see if I can check it out sometime soon since I know the way they build gamescope on Fedora relies on a few patches and workarounds not present upstream

@KayJay7
Copy link
Author

KayJay7 commented Nov 3, 2024

Yes, Fedora 40. I will also try if I can downgrade gamescope without causing a mass downgrade and see what happens.

By the way, what are those downstream patches for?

@matte-schwartz
Copy link

matte-schwartz commented Nov 3, 2024

main one i remember is a patch to stop using the included submodules for gamescope and instead compile with their own system library versions, which may not be a 1:1 match for what gamescope itself ships and relies on

https://src.fedoraproject.org/rpms/gamescope/tree/f40

edit: and just to clarify, it might be something else entirely here but its certainly one factor i'd like to be able to eliminate

@KayJay7
Copy link
Author

KayJay7 commented Nov 5, 2024

So, the only other version I have available on dnf is 3.14.2, and after downgrading I can't start gamescope neither from steam nor from heroic (though launching it from terminal works). I don't think this is related, and it's probably something minor I did wrong, but I don't understand how to get a log or a console output, so I don't know where to start. Adding PROTON_LOG=1 does nothing because it probably exits before launching proton.

Maybe it has something to do with how steam and heroic are built?

p.s. and re-upgrading gamescope goes back to the previous behaviour

@Tatsh
Copy link

Tatsh commented Nov 15, 2024

Forcing composition or using sdl will work around it

Likely the same as this issue #1177

SDL does get around this but I am running Sims 2 and it randomly freezes requiring me to click to make the game continue. Normal mode does not do this.

Compositing results in a lot of garbage on screen so it's not usable.

@matte-schwartz
Copy link

matte-schwartz commented Dec 16, 2024

I checked Terraria again on gamescope 3.16.1 with plasma 6.2.4 and it seems like the game pillarboxes correctly for me now with your launch command: gamescope -h 1080 -w 1920 -H 1080 -W 2560 -f -- %command%

Screenshot_20241216_094243

might be worth re-checking when your distro picks up the latest release version

@Connatus
Copy link

Connatus commented Jan 7, 2025

Wanted to comment that I'm still seeing this issue with
gamescope version 3.16.1-4-gf873ec7+ (gcc 14.2.1)
KDE Plasma Version: 6.2.5

It only seems to happen when the game is rendering at the "native" gamescope resolution.
I'm running Helldivers 2 with the following command
gamescope -w 3840 -h 1440 -W 5120 -H 1440 -f -- %command%
In game when I have the resolution set to 1920x1080
Screenshot_20250107_020611-1
It pillerboxes properly
But if I set the resolution to 3840x1440
Screenshot_20250107_020059-1
I see this issue.

I was also able to replicate the issue using GLXgears
When running at 1920x1080
gamescope -w 3840 -h 1440 -W 5120 -H 1440 -f -- glxgears -geometry 1920x1080
Screenshot_20250107_021846

And then issue is replicated when rendering at 3840x1440
gamescope -w 3840 -h 1440 -W 5120 -H 1440 -f -- glxgears -geometry 3840x1440
Screenshot_20250107_021831

My setup is an ultra wide with resolution of 5120x1440

@matte-schwartz
Copy link

just to confirm, did you add any additional patches or change any debugging convars before you built gamescope? I have gamescope version 3.16.1-4-gf873ec78 (gcc 14.2.1) after building from latest git without a +

@Connatus
Copy link

Connatus commented Jan 7, 2025

It might have some patches?
I just installed from this copr repo https://copr.fedorainfracloud.org/coprs/vulongm/gamescope-git/

Haven't tried building the latest from head myself

@matte-schwartz
Copy link

Thanks for the link, the patch used is just #1671 which should be irrelevant to this issue. I'll try checking this out when I'm back home in a couple weeks.

@Tatsh
Copy link

Tatsh commented Jan 8, 2025

Replying to #1608 (comment)

I am also to reproduce this. My setup is 7680x2160. glxgears appears on the left side only. The right side of my display is also not obscured.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

7 participants