RetroPie forum home
    • Recent
    • Tags
    • Popular
    • Home
    • Docs
    • Register
    • Login
    Please do not post a support request without first reading and following the advice in https://retropie.org.uk/forum/topic/3/read-this-first

    Fixing Screen Tearing issues on RPI4

    Scheduled Pinned Locked Moved Help and Support
    configurationgraphicspi4 8gbscreentearing
    43 Posts 13 Posters 20.9k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • brandflake11B
      brandflake11
      last edited by brandflake11

      An interesting tidbit of information I have looked into was that the pi, while running games, had high cpu usage with systemd-journald (58%, more than retroarch!). It seems that there might be errors in the logs. I had a look at /var/log/syslog and had some error messages being placed there, also in dmesg:

      https://pastebin.com/afJ6gLhu

      This is happening many, many times per second. Could this be related? Is there something wrong with the wireless card?

      EDIT: It is also only happening during gameplay in retroarch, not in emulationstation or sm64pc. Coincidentally, the tearing doesn't happen during sm64pc at all, even with fast movement. Maybe the kernel errors is spiking cpu with systemd-journald and is causing the video to be affected?

      EDIT2: So, I discovered what was causing this systemd-journald error, it was a shader called snes_scnaline.glsp that I was using. I turned off the shader and even switched to pi-crt and systemd-journald stopped hogging so much cpu. The snes_* shaders seem to be causing this error, spiking journald. Still haven't figured out if this is causing the shaders. I will edit again if this is the case.

      EDIT3: Just found out that the shaders are not causing the tearing, I can get them without shaders even on. That cpu spike with the snes_* shaders is definitely bug though!

      1 Reply Last reply Reply Quote 0
      • DarksaviorD
        Darksavior @brandflake11
        last edited by Darksavior

        @brandflake11 Screen tearing has been happening on the pi4 since day 1 on all emulators for me. My pi is fully updated, so I'm not using outdated kernels/drivers. My wifi and bt are disabled.
        The new experimental kms driver supposedly fixes it but I haven't done enough testing. No idea if it would even work on a portable screen.

        1 Reply Last reply Reply Quote 0
        • brandflake11B
          brandflake11
          last edited by brandflake11

          @Darksavior Thanks for the response! Maybe I'll try the experimental driver and see if it works. Quick question if you know it, is the video driver just a debian package that I can go in and downgrade back to stable with something like synaptic? That way I could switch back to stable if needed.

          1 Reply Last reply Reply Quote 0
          • R
            rilight
            last edited by

            @brandflake11 You may find the thread I started relevant: https://retropie.org.uk/forum/topic/27299/low-framerate-on-main-emulationstation-menu-pi-4/

            I've also been encountering tearing issues as well as framerate drops, and a few users with more technical knowledge than me are trying to figure out the cause + any potential fixes.

            1 Reply Last reply Reply Quote 0
            • brandflake11B
              brandflake11
              last edited by

              @rilight Thanks, I took a look at it and may try some of the manual editing of config files. I really hope we get a tearless graphics experience on the pi4 soon, like the pi3 has!

              I did install the experimental firmware, and can say that it tears much less, and much less intense. It still happens, but not as frequently or as badly, so that's a plus! I also haven't found too many bugs either, so that's good! It definitely helps with Crash Bandicoot and Kirby's Nightmare in Dreamland, which was another game that would tear here and there.

              @rilight Did you find anything in particular from that thread helpful to get a tearless experience?

              R 1 Reply Last reply Reply Quote 0
              • X
                xanstin
                last edited by

                I tried the v3d min freq with no success just now. I also have tearing on games in NES and others. No shader on, just bezel overlay.

                1 Reply Last reply Reply Quote 0
                • R
                  rilight @brandflake11
                  last edited by

                  @brandflake11 said in Fixing Screen Tearing issues on RPI4:

                  @rilight Did you find anything in particular from that thread helpful to get a tearless experience?

                  Unfortunately I've been pretty busy recently, so I haven't had a chance to really mess around with the more recent suggestions. I did find that enabling the force_turbo option seemed to help, as well as forcing the resolution to 720p. I talked about the results of those tests in the thread, but other than that I haven't done anything else myself.

                  1 Reply Last reply Reply Quote 0
                  • B
                    bluestang
                    last edited by bluestang

                    v3d_freq_min only addresses the low/30 fps framerate issue that happens within EmulationStation.

                    The screen tearing issue from this thread is a separate issue is appears.

                    With the kernel setting set to ondemand, the expected behavior of the gpu clock is to ramp up the frequency to the default and then downclock to 300 Mhz when not used to conserve resources.

                    Also RetroArch v.1.8.9 and above made a lot of changes to the graphics side of their drivers. Once RetroPie devs update the setup script to implement those changes it may be worth waiting to see if the screen tearing has been fixed in those versions.

                    DarksaviorD 1 Reply Last reply Reply Quote 1
                    • brandflake11B
                      brandflake11
                      last edited by brandflake11

                      Maybe I'll look into installing the newest version of retroarch from source to see if it helps. Thanks for the suggestion @bluestang!

                      1 Reply Last reply Reply Quote 0
                      • DarksaviorD
                        Darksavior @bluestang
                        last edited by

                        @bluestang I'm using the retropie draft build script for 1.9.0 and there is no change with the screen tearing.

                        1 Reply Last reply Reply Quote 0
                        • brandflake11B
                          brandflake11
                          last edited by

                          Well darn, there has to be something we can do. I guess we should just keep waiting for better firmware? For the meantime, maybe I can go back to my pi3, or just suck it up and enjoy the pi4 with tearing.

                          Has anyone tried turning on the compositor? Does that affect retroarch if you are not running a desktop environment?

                          1 Reply Last reply Reply Quote 0
                          • brandflake11B
                            brandflake11
                            last edited by brandflake11

                            For anyone looking for a solution to this, I have found this thread.

                            Enabling the kms driver (although a work in progress) has fixed all tearing I was having. The tearing is replaced with some stuttering in some games, but I am more than okay with this.

                            To enable, I went to /boot/config.txt and edited this part:

                            [pi4]
                            # Enable DRM VC4 V3D driver on top of the dispmanx display stack
                            #dtoverlay=vc4-fkms-v3d
                            dtoverlay=vc4-kms-v3d-pi4,noaudio
                            max_framebuffers=2
                            
                            [all]
                            #dtoverlay=vc4-fkms-v3d
                            
                            

                            Basically, comment out dtoverlay=vc4-fkms-v3d with a #, and then put in the the dtoverlay=vc4-kms-v3d-pi4,noaudio line. For my setup, I was getting a black screen until I added the ,noaudio part to it.
                            Also, under [all] comment out the other dtoverlay underneath it if it is not commented out.

                            I hope this helps others!

                            Z H H L 4 Replies Last reply Reply Quote 1
                            • Z
                              zerojay @brandflake11
                              last edited by

                              @brandflake11 Thank you, this absolutely fixed the really weird screen tearing issues I was having even with NES games. Thank you so very much.

                              brandflake11B 1 Reply Last reply Reply Quote 1
                              • brandflake11B
                                brandflake11 @zerojay
                                last edited by

                                @zerojay You're welcome, I'm glad it helped you. I hope having a clear topic like this addressing this issue helps others as well.

                                1 Reply Last reply Reply Quote 1
                                • H
                                  hgill @brandflake11
                                  last edited by

                                  @brandflake11
                                  I applied your changes to the /boot/config.txt and it helped a lot.
                                  But some tearing was still visible when many sprites and layers were active in some situations. (Aliens 3 / SNES)

                                  What helped for me was reducing the overclocking from 2250 to 1950.
                                  Now I cannot reproduce the tearing any more.

                                  1 Reply Last reply Reply Quote 0
                                  • brandflake11B
                                    brandflake11
                                    last edited by

                                    That is very interesting @hgill that overclocking would affect that. I don't use overclocking on my pi and so I don't get any screen tearing. But, that's good to hear to keep note of for others!

                                    1 Reply Last reply Reply Quote 0
                                    • H
                                      huey @brandflake11
                                      last edited by

                                      @brandflake11 said in Fixing Screen Tearing issues on RPI4:

                                      vc4-kms-v3d-pi4

                                      This solution works great in my case in terms of fixing the screen tearing issues - thanks a lot.

                                      However, I noticed that after applying such settings, the hardware accelerated OMXPlayer no longer plays video inside EmulationStation (but the sound plays just fine), which is a deal breaker for me.

                                      brandflake11B 1 Reply Last reply Reply Quote 0
                                      • brandflake11B
                                        brandflake11 @huey
                                        last edited by

                                        @huey Yeah, there are definitely compromises with the experimental driver. I found kodi and the pixel desktop don't work super well with the kms driver either. If you don't want to play n64 and Dreamcast, honestly the pi3 may have a better experience at the moment. Maybe we'll get a complete kms driver eventually that fixes everything!

                                        H 1 Reply Last reply Reply Quote 0
                                        • H
                                          huey @brandflake11
                                          last edited by

                                          @brandflake11 said in Fixing Screen Tearing issues on RPI4:

                                          @huey Yeah, there are definitely compromises with the experimental driver. I found kodi and the pixel desktop don't work super well with the kms driver either. If you don't want to play n64 and Dreamcast, honestly the pi3 may have a better experience at the moment. Maybe we'll get a complete kms driver eventually that fixes everything!

                                          Thanks for confirming. I also read something along the same lines in the following RPi post and it seems to be an ongoing effort.

                                          https://www.raspberrypi.org/forums/viewtopic.php?f=29&t=269769

                                          "Note: kms won’t ever support applications that use firmware apis for display like dispmanx, or mmal/openmax video_render, including omxplayer, raspivid and non-gbm kodi. Similarly tvservice is not useful in this environment."

                                          1 Reply Last reply Reply Quote 0
                                          • L
                                            lolkthxbai @brandflake11
                                            last edited by lolkthxbai

                                            @brandflake11 Unfortunately, enabling the KMS driver in my config file gives me no video on startup. I’m also updated as of today on the latest version of RetroPie and still getting tearing in NES, SNES, every emulator I’ve tried. Did anyone else experience this? Is it really as simple as commenting out

                                            [pi4]
                                            #dtoverlay=vc4-fkms-v3d
                                            

                                            and then adding the experimental one?

                                            dtoverlay=vc4-kms-v3d-pi4,noaudio
                                            

                                            I’ve also seen some other posts where there’s a space after the “=“ sign and others that don’t use pi4 at the end at all.
                                            Is there some documentation about this somewhere?

                                            brandflake11B B 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Contributions to the project are always appreciated, so if you would like to support us with a donation you can do so here.

                                            Hosting provided by Mythic-Beasts. See the Hosting Information page for more information.