Bug 371889

Summary: High CPU and memory usage in plasmashell process
Product: [Plasma] plasmashell Reporter: Hubert Kario <hkario>
Component: generalAssignee: David Edmundson <kde>
Status: RESOLVED DUPLICATE    
Severity: major CC: ainur.shakirov.tt, bhush94, enrico.tagliavini, jeryjer67, kde_org, plasma-bugs, rdieter, rocketraman, rparree, s_chriscollins
Priority: NOR    
Version: 5.7.5   
Target Milestone: 1.0   
Platform: Fedora RPMs   
OS: Linux   
Latest Commit: Version Fixed In:
Sentry Crash Report:
Attachments: perf record of plasma shell (still working good)
perf record of plasma shell (slow performance)
perf record of plasma shell (systray animation when in slow performance condition)
perf record of plasma shell (still working good)
perf top annotate of handleSignal method
callgrind record of plasma shell (slow performance)

Description Hubert Kario 2016-10-31 12:37:50 UTC
After few hours of work, plasmashell process uses huge amounts of memory (atop: 227M VSLIBS, 2.4G VDATA, 4.8G VSIZE, 392.5M RSIZE) and large amounts of CPU: 80-90% of a single core of i7-6600U.

The issue persists until I kill the process and restart it manually.

Only atypical configuration is the fact I use 3 screens, the widgets/taskbar are mostly in default configuration (I just change it not to group processes and the time widget to include seconds and current date).

Besides that, I use only Kontact, Kopete, Konversation, Firefox and Konsole as far as GUI tools are concerned. System is configured to use X11 modesetting driver not the intel driver.


plasma-workspace-5.7.5-2.fc24.x86_64
qt5-qtbase-gui-5.6.1-3.fc24.x86_64
kdepim-common-16.08.2-1.fc24.x86_64
kde-runtime-libs-16.08.2-1.fc24.x86_64
kde-runtime-16.08.2-1.fc24.x86_64


$ qtdiag 
Qt 5.6.1 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 6.1.1 20160621 (Red Hat 6.1.1-3)) on "xcb" 
OS: Fedora 24 (Workstation Edition) [linux version 4.7.9-200.fc24.x86_64]

Architecture: x86_64; features: SSE2 SSE3 SSSE3 SSE4.1 SSE4.2 AVX AVX2 RTM HLE

Environment:
  QTLIB="/usr/lib64/qt-3.3/lib"
  QTINC="/usr/lib64/qt-3.3/include"
  QT_IM_MODULE="xim"
  QT_AUTO_SCREEN_SCALE_FACTOR="0"
  QTDIR="/usr/lib64/qt-3.3"

Features: QT_NO_EXCEPTIONS QT_NO_ZLIB

Library info:
  PrefixPath: /usr/lib64/qt5
  DocumentationPath: /usr/share/doc/qt5
  HeadersPath: /usr/include/qt5
  LibrariesPath: /usr/lib64
  LibraryExecutablesPath: /usr/lib64/qt5/libexec
  BinariesPath: /usr/lib64/qt5/bin
  PluginsPath: /usr/lib64/qt5/plugins
  ImportsPath: /usr/lib64/qt5/imports
  Qml2ImportsPath: /usr/lib64/qt5/qml
  ArchDataPath: /usr/lib64/qt5
  DataPath: /usr/share/qt5
  TranslationsPath: /usr/share/qt5/translations
  ExamplesPath: /usr/lib64/qt5/examples
  TestsPath: /usr/lib64/qt5/tests
  SettingsPath: /etc/xdg

Standard paths [*...* denote writable entry]:
  DesktopLocation: "Desktop" */home/hkario/Desktop*
  DocumentsLocation: "Documents" */home/hkario/Documents*
  FontsLocation: "Fonts" */home/hkario/.fonts*
  ApplicationsLocation: "Applications" */home/hkario/.local/share/applications* /usr/share/kde-settings/kde-profile/default/share/applications /usr/local/share/applications /usr/share/applications
  MusicLocation: "Music" */home/hkario/Music*
  MoviesLocation: "Movies" */home/hkario/Videos*
  PicturesLocation: "Pictures" */home/hkario/Pictures*
  TempLocation: "Temporary Directory" */tmp*
  HomeLocation: "Home" */home/hkario*
  AppLocalDataLocation: "Application Data" */home/hkario/.local/share/QtProject/qtdiag* /usr/share/kde-settings/kde-profile/default/share/QtProject/qtdiag /usr/local/share/QtProject/qtdiag /usr/share/QtProject/qtdiag
  CacheLocation: "Cache" */home/hkario/.cache/QtProject/qtdiag*
  GenericDataLocation: "Shared Data" */home/hkario/.local/share* /usr/share/kde-settings/kde-profile/default/share /usr/local/share /usr/share
  RuntimeLocation: "Runtime" */run/user/20970*
  ConfigLocation: "Configuration" */home/hkario/.config* /etc/xdg /usr/share/kde-settings/kde-profile/default/xdg
  DownloadLocation: "Download" */home/hkario/Downloads*
  GenericCacheLocation: "Shared Cache" */home/hkario/.cache*
  GenericConfigLocation: "Shared Configuration" */home/hkario/.config* /etc/xdg /usr/share/kde-settings/kde-profile/default/xdg
  AppDataLocation: "Application Data" */home/hkario/.local/share/QtProject/qtdiag* /usr/share/kde-settings/kde-profile/default/share/QtProject/qtdiag /usr/local/share/QtProject/qtdiag /usr/share/QtProject/qtdiag
  AppConfigLocation: "Application Configuration" */home/hkario/.config/QtProject/qtdiag* /etc/xdg/QtProject/qtdiag /usr/share/kde-settings/kde-profile/default/xdg/QtProject/qtdiag

File selectors (increasing order of precedence):
  en_GB unix linux fedora

Network:
  Using "OpenSSL 1.0.2j-fips  26 Sep 2016", version: 0x100020af

Platform capabilities: ThreadedPixmaps OpenGL WindowMasks MultipleWindows ForeignWindows NonFullScreenWindows NativeWidgets WindowManagement SyncState RasterGLSurface SwitchableWidgetComposition

Style hints:
  mouseDoubleClickInterval: 400
  mousePressAndHoldInterval: 800
  startDragDistance: 4
  startDragTime: 500
  startDragVelocity: 0
  keyboardInputInterval: 400
  keyboardAutoRepeatRate: 30
  cursorFlashTime: 1000
  showIsFullScreen: 0
  showIsMaximized: 0
  passwordMaskDelay: 0
  passwordMaskCharacter: U+25CF
  fontSmoothingGamma: 1
  useRtlExtensions: 0
  setFocusOnTouchRelease: 0
  tabFocusBehavior: Qt::TabFocusBehavior(TabFocusAllControls) 
  singleClickActivation: 1

Additional style hints (QPlatformIntegration):
  ReplayMousePressOutsidePopup: 0

Theme:
  Available    : kde,/usr/share/xsessions/plasma,generic
  Styles       : breeze,oxygen,fusion,windows
  Icon theme   : breeze, hicolor from /usr/share/icons

  System font  : "Sans Serif" 10
  Native file dialog

Fonts:
  General font : "Sans Serif" 10
  Fixed font   : "Monospace" 10
  Title font   : "Abyssinica SIL" 10
  Smallest font: "Sans Serif" 8

Palette:
  WindowText: #ff31363b
  Button: #ffeff0f1
  Light: #ffffffff
  Midlight: #fff7f7f8
  Dark: #ff888e93
  Mid: #ffc4c9cd
  Text: #ff31363b
  BrightText: #ffffffff
  ButtonText: #ff31363b
  Base: #fffcfcfc
  Window: #ffeff0f1
  Shadow: #ff474a4c
  Highlight: #ff3daee9
  HighlightedText: #ffeff0f1
  Link: #ff2980b9
  LinkVisited: #ff7f8c8d
  AlternateBase: #ffeff0f1
  NoRole: #ff000000
  ToolTipBase: #ff31363b
  ToolTipText: #ffeff0f1

Screens: 3, High DPI scaling: inactive
# 0 "eDP-1" Depth: 24 Primary: yes
  Geometry: 1920x1080+2160+840 Available: 1920x1050+2160+840
  Virtual geometry: 4080x1920+0+0 Available: 4080x1890+0+0
  3 virtual siblings
  Physical size: 309x174 mm  Refresh: 60 Hz Power state: 0
  Physical DPI: 157.825,157.655 Logical DPI: 96.3123,96.3794 Subpixel_None
  DevicePixelRatio: 1 Pixel density: 2
  Primary orientation: 2 Orientation: 2 Native orientation: 0 OrientationUpdateMask: 0

# 1 "DP-2-1" Depth: 24 Primary: no
  Geometry: 1080x1920+0+0 Available: 1080x1890+0+0
  Virtual geometry: 4080x1920+0+0 Available: 4080x1890+0+0
  3 virtual siblings
  Physical size: 287x510 mm  Refresh: 60 Hz Power state: 0
  Physical DPI: 95.5819,95.6235 Logical DPI: 96.3123,96.3794 Subpixel_None
  DevicePixelRatio: 1 Pixel density: 1
  Primary orientation: 1 Orientation: 1 Native orientation: 0 OrientationUpdateMask: 0

# 2 "DP-2-2" Depth: 24 Primary: no
  Geometry: 1080x1920+1080+0 Available: 1080x1890+1080+0
  Virtual geometry: 4080x1920+0+0 Available: 4080x1890+0+0
  3 virtual siblings
  Physical size: 287x510 mm  Refresh: 60 Hz Power state: 0
  Physical DPI: 95.5819,95.6235 Logical DPI: 96.3123,96.3794 Subpixel_None
  DevicePixelRatio: 1 Pixel density: 1
  Primary orientation: 1 Orientation: 1 Native orientation: 0 OrientationUpdateMask: 0

LibGL Vendor: Intel Open Source Technology Center
Renderer: Mesa DRI Intel(R) HD Graphics 520 (Skylake GT2) 
Version: 3.0 Mesa 12.0.3
Shading language: 1.30
Format: Version: 3.0 Profile: 0 Swap behavior: 0 Buffer size (RGB): 8,8,8
Comment 1 Ainur Shakirov 2016-10-31 15:09:46 UTC
Same problem with 2 screens and the Intel card with xf86-video-intel.

Plasma version: 5.8.2
qt5: 5.7.0
Intel driver: 2.99.917.722.g714052f (-02, march=ivybridge)

$ qtdiag

Qt 5.7.0 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 6.2.1 20160830) on "xcb" 
OS: Manjaro Linux [linux version 4.7.6-1-lqx]

Architecture: x86_64; features: SSE2 SSE3 SSSE3 SSE4.1 SSE4.2

Environment:
  QT_LINUX_ACCESSIBILITY_ALWAYS_ON="1"
  QT_QPA_PLATFORM="xcb"
  QT_AUTO_SCREEN_SCALE_FACTOR="0"

Features: QT_NO_EXCEPTIONS QT_NO_ZLIB

Library info:
  PrefixPath: /usr
  DocumentationPath: /usr/share/doc/qt
  HeadersPath: /usr/include/qt
  LibrariesPath: /usr/lib
  LibraryExecutablesPath: /usr/lib/qt/libexec
  BinariesPath: /usr/bin
  PluginsPath: /usr/lib/qt/plugins
  ImportsPath: /usr/lib/qt/imports
  Qml2ImportsPath: /usr/lib/qt/qml
  ArchDataPath: /usr/lib/qt
  DataPath: /usr/share/qt
  TranslationsPath: /usr/share/qt/translations
  ExamplesPath: /usr/share/doc/qt/examples
  TestsPath: /usr/tests
  SettingsPath: /etc/xdg

Standard paths [*...* denote writable entry]:
  DesktopLocation: "Desktop" */home/moon/Desktop*
  DocumentsLocation: "Documents" */home/moon/Documents*
  FontsLocation: "Fonts" */home/moon/.fonts*
  ApplicationsLocation: "Applications" */home/moon/.local/share/applications* /usr/share/applications /usr/local/share/applications
  MusicLocation: "Music" */home/moon/Music*
  MoviesLocation: "Movies" */home/moon/Videos*
  PicturesLocation: "Pictures" */home/moon/Pictures*
  TempLocation: "Temporary Directory" */tmp*
  HomeLocation: "Home" */home/moon*
  AppLocalDataLocation: "Application Data" */home/moon/.local/share/QtProject/qtdiag* /usr/share/QtProject/qtdiag /usr/local/share/QtProject/qtdiag
  CacheLocation: "Cache" */home/moon/.cache/QtProject/qtdiag*
  GenericDataLocation: "Shared Data" */home/moon/.local/share* /usr/share /usr/local/share
  RuntimeLocation: "Runtime" */run/user/1000*
  ConfigLocation: "Configuration" */home/moon/.config* /etc/xdg
  DownloadLocation: "Download" */home/moon/Downloads*
  GenericCacheLocation: "Shared Cache" */home/moon/.cache*
  GenericConfigLocation: "Shared Configuration" */home/moon/.config* /etc/xdg
  AppDataLocation: "Application Data" */home/moon/.local/share/QtProject/qtdiag* /usr/share/QtProject/qtdiag /usr/local/share/QtProject/qtdiag
  AppConfigLocation: "Application Configuration" */home/moon/.config/QtProject/qtdiag* /etc/xdg/QtProject/qtdiag

File selectors (increasing order of precedence):
  en_US unix linux manjaro

Network:
  Using "OpenSSL 1.0.2j  26 Sep 2016", version: 0x100020af

Platform capabilities: ThreadedPixmaps OpenGL WindowMasks MultipleWindows ForeignWindows NonFullScreenWindows NativeWidgets WindowManagement SyncState RasterGLSurface SwitchableWidgetComposition

Style hints:
  mouseDoubleClickInterval: 400
  mousePressAndHoldInterval: 800
  startDragDistance: 4
  startDragTime: 500
  startDragVelocity: 0
  keyboardInputInterval: 400
  keyboardAutoRepeatRate: 30
  cursorFlashTime: 1000
  showIsFullScreen: 0
  showIsMaximized: 0
  passwordMaskDelay: 0
  passwordMaskCharacter: U+25CF
  fontSmoothingGamma: 1
  useRtlExtensions: 0
  setFocusOnTouchRelease: 0
  tabFocusBehavior: Qt::TabFocusBehavior(TabFocusAllControls) 
  singleClickActivation: 1

Additional style hints (QPlatformIntegration):
  ReplayMousePressOutsidePopup: 0

Theme:
  Available    : kde,/usr/share/xsessions/plasma,generic
  Styles       : Breeze,breeze,oxygen,fusion,windows
  Icon theme   : breeze-dark, hicolor from /usr/share/icons,/usr/share/icons,/usr/local/share/icons

  System font  : "Noto Sans" 10
  Native file dialog

Fonts:
  General font : "Noto Sans" 10
  Fixed font   : "Noto Mono" 9
  Title font   : "Noto Sans" 10
  Smallest font: "Noto Sans" 8

Palette:
  WindowText: #ffeff0f1
  Button: #ff31363b
  Light: #ff454c54
  Midlight: #ff3c4248
  Dark: #ff1c1f22
  Mid: #ff2b2f34
  Text: #ffeff0f1
  BrightText: #ffffffff
  ButtonText: #ffeff0f1
  Base: #ff232629
  Window: #ff31363b
  Shadow: #ff141719
  Highlight: #ff3daee9
  HighlightedText: #ffeff0f1
  Link: #ff2980b9
  LinkVisited: #ff7f8c8d
  AlternateBase: #ff31363b
  NoRole: #ff000000
  ToolTipBase: #ff31363b
  ToolTipText: #ffeff0f1

Screens: 2, High DPI scaling: inactive
# 0 "HDMI1" Depth: 24 Primary: yes
  Geometry: 1920x1080+0+0 Available: 1920x1044+0+36
  Virtual geometry: 3840x1080+0+0 Available: 3840x1044+0+36
  2 virtual siblings
  Physical size: 480x270 mm  Refresh: 50 Hz Power state: 0
  Physical DPI: 101.6,101.6 Logical DPI: 96.2843,96.2526 Subpixel_None
  DevicePixelRatio: 1 Pixel density: 1
  Primary orientation: 2 Orientation: 2 Native orientation: 0 OrientationUpdateMask: 0

# 1 "VGA1" Depth: 24 Primary: no
  Geometry: 1920x1080+1920+0 Available: 1920x1044+1920+36
  Virtual geometry: 3840x1080+0+0 Available: 3840x1044+0+36
  2 virtual siblings
  Physical size: 480x270 mm  Refresh: 60 Hz Power state: 0
  Physical DPI: 101.6,101.6 Logical DPI: 96.2843,96.2526 Subpixel_None
  DevicePixelRatio: 1 Pixel density: 1
  Primary orientation: 2 Orientation: 2 Native orientation: 0 OrientationUpdateMask: 0

LibGL Vendor: Intel Open Source Technology Center
Renderer: Mesa DRI Intel(R) Ivybridge Mobile 
Version: 3.0 Mesa 13.0.0-rc2
Shading language: 1.30
Format: Version: 3.0 Profile: 0 Swap behavior: 0 Buffer size (RGB): 8,8,8
Comment 2 Enrico Tagliavini 2016-11-03 15:06:31 UTC
Same for me on Fedora 24

After multi hours usage on a laptop with external monitor attached, powered by Skylake CPU and GPU (i7-6700HQ), Plasma becomes slower and slower, even the mouse pointer slows down. I observed the plasmashell process using more and more CPU and RAM over time. Restarting plasmashell fixes the issue temporarily, it reappears after enough time.

I just found another user on IRC (Lipsum) having the exact same problem. He also has multi monitor and Skylake.

I tried both modesetting DDX and intel DDX, it happens with both. With modesetting it's worst though, probably because glamor is slower than SNA.

Version-Release number of selected component (if applicable):
root@enrico-dell ~ # rpm -qa | grep 'plasma-workspace-5\|mesa-dri\|modset\|xorg-x11-server-Xorg'
xorg-x11-server-Xorg-1.18.4-4.fc24.x86_64
plasma-workspace-5.7.5-2.fc24.x86_64
mesa-dri-drivers-12.0.3-2.fc24.x86_64

Steps to Reproduce:
1. Multi monitor setup is required
2. Start a plasma session and use it normally
3. Monitor plasmashell CPU and RAM usage over time
4. Notice the performance of plasma, especially on the external monitor, become sluggish

Actual results:
Plasma uses more and more RAM and CPU, performance is degraded and user experience is affected (sluggish interaction, slow response from the plasma shell)


Expected results:
CPU and RAM usage should be faily constant over time. Responsiveness of the shell should be constant in time and not sluggish.


Additional info:
I'm not sure if a better than full HD monitor is required. I have the following configration:

taglenri@enrico-dell ~ $ xrandr
Screen 0: minimum 8 x 8, current 4480 x 1440, maximum 32767 x 32767
eDP1 connected primary 1920x1080+2560+0 (normal left inverted right x axis y axis) 350mm x 190mm
   1920x1080     59.93*+
   1400x1050     59.98  
   1600x900      60.00  
   1280x1024     60.02  
   1280x960      60.00  
   1368x768      60.00  
   1280x720      60.00  
   1024x768      60.00  
   1024x576      60.00  
   960x540       60.00  
   800x600       60.32    56.25  
   864x486       60.00  
   640x480       59.94  
   720x405       60.00  
   640x360       60.00  
DP1 disconnected (normal left inverted right x axis y axis)
DP2 disconnected (normal left inverted right x axis y axis)
HDMI1 connected 2560x1440+0+0 (normal left inverted right x axis y axis) 600mm x 340mm
   2560x1440     59.95*+
   2048x1152     60.00  
   1920x1200     59.95  
   1920x1080     60.00    60.00    50.00    59.94    30.00    25.00    24.00    29.97    23.98  
   1920x1080i    60.00    50.00    59.94  
   1600x1200     60.00  
   1680x1050     59.88  
   1280x1024     75.02    60.02  
   1200x960      59.99  
   1152x864      75.00  
   1280x720      60.00    50.00    59.94  
   1024x768      75.03    60.00  
   800x600       75.00    60.32  
   720x576       50.00  
   720x576i      50.00  
   720x480       60.00    59.94  
   720x480i      60.00    59.94  
   640x480       75.00    60.00    59.94                                                                                                                                                                                                                                              
   720x400       70.08                                                                                                                                                                                                                                                                
HDMI2 disconnected (normal left inverted right x axis y axis)                                                                                                                                                                                                                         
VIRTUAL1 disconnected (normal left inverted right x axis y axis)


It is quite easy to notice the issue earlier if enabling the "Slide back" effect for Kwin compositing.
Comment 3 Rex Dieter 2016-11-03 15:14:55 UTC
marking confirmed for multiple reporters
Comment 4 Enrico Tagliavini 2016-11-04 09:57:03 UTC
As suggested by Rex I tried the Plasma 5.8.3 packages from the Fedora KDE unstable copr repository (which is what will become the official Fedora packages) https://copr.fedorainfracloud.org/coprs/g/kdesig/plasma-5-unstable/

Problem still exists unfortunately. I have the impression using programs like virt-manager and krdc makes the problem easier to reproduce. I frequently have a CentOS 7 VM running and open in virt-manager and I use a desktop on it. I also use krdc quite frequently to connect to remote Windows systems right after closing KRDC I noticed plasmashell process eating between 50 and 100% of one core (it started before I closed KRDC I noticed the environment to become less and less responsive).

To be clear: I think krdc and virt-manager are making the issue appear faster, they are not the only trigger
Comment 5 David Edmundson 2016-11-04 22:23:07 UTC
If there's high CPU usage we need some sort of log of what it's doing when using high CPU otherwise we can't do anything.

Options are either:

perf record -g -p `pidof plasmashell`

or

callgrind 

You can use callgrind remote to profile only part of a process:
http://zariko.taba.free.fr/c++/callgrind_profile_only_a_part.html


Both will need relevant permissions and debug symbols.
Please reopen when you have something.
Comment 6 Enrico Tagliavini 2016-11-07 08:47:03 UTC
Created attachment 102089 [details]
perf record of plasma shell (still working good)

I thought about giving you a comparison, hoping it's useful, between a fresh boot of the system (when plasma is still working as expected and there is no issue exposed yet), and when the issue is very visible.

In this capture I have all my applications open (firefox, kmail, quassel, konsole, yakuake, virt-manager) and doing my normal work (answering emails and the like). This is a fresh boot and plasma performance is still good and there is no issue.

I've installed the debug symbols for plasma-workspace dependencies. However debug info RPMs for the copr repo with plasma 5.8.3 are not available to my best knowledge.
Comment 7 Rex Dieter 2016-11-07 11:56:10 UTC
Color repos do provide -debuginfo pkgs, fyi
Comment 8 Rex Dieter 2016-11-07 11:57:30 UTC
Make that *copr* repos (sorry for bad phone autocorrect)
Comment 9 Enrico Tagliavini 2016-11-07 14:22:07 UTC
Created attachment 102102 [details]
perf record of plasma shell (slow performance)

Sorry epic fail on my side. I had a typo in the command to install the debuginfo packages (I used dnf debuginfo-install --enable-repo instead of --enablerepo, dnf doesn't complain the option doesn't exist when using the debuginfo-install plugin... sorry!).

I've the debuginfo installed! Here is the perf data collected as root. I have all my applications open (as in previous comment + okular + KRDC). Here I'm constantly jumping between windows to trigger the high CPU utilization (to make number higher let's say). It's using 100% of one core. When I just don't move from a window the CPU utilization is near zero. Also changing window without involving any animation triggers the CPU utilization.

Note I had to compress it due to the size exceeding 4 MB limitation of this bugzilla.
Comment 10 Enrico Tagliavini 2016-11-07 14:27:39 UTC
Created attachment 102103 [details]
perf record of plasma shell (systray animation when in slow performance condition)

I've done an additional capture (which actually happened right before the previous one I posted). Here I'm just doing my usual work, I'm not heavily triggering the Windows change on purpose. However I have the telepathy little message systray icon animation happening. I actually left it there quite a while before doing this capture. I thought about adding it since it might be related... better safe than sorry.

Also I think this might actually have accelerated the performance degeneration as well. I've had KRDC and virt-manager open the whole day, but it was not as bad. Performance was going down, but not too fast. So the systray animation might actually be a heavy contributor.
Comment 11 Enrico Tagliavini 2016-11-07 14:29:50 UTC
So I think I've added enough information for the time being. Please put the bug in OPEN status again (I can't I'm not the original reporter).

Tomorrow I'll also take the perf statistic after a fresh boot, as the one I posted is with the debugging symbol not installed.

Thank you Rex for pointing out the copr provides debuginfos... I couldn't find them myself and got fooled by a stupid typo :)
Comment 12 Enrico Tagliavini 2016-11-07 14:52:28 UTC
Created attachment 102105 [details]
perf record of plasma shell (still working good)

Well, since 'kquitapp5 plasmashell ; plasmashell --shut-up' temporarily fixes the issue I just restarted plasmashell and recorded it again.

In this record I constantly switch window to have a similar situation when high CPU usage is triggered. In this case plasmashell doesn't even reach 50% (it's between 40 and 50%) of a single core and the system feels perfectly responsive and smooth. Still a pretty significant CPU usage just for switching window. This again without any effect triggering, the two windows are not overlapping, the only visible change is the status bar color change. Also, for what I understand, the animation is done by kwin process.
Comment 13 Hubert Kario 2016-11-07 15:31:52 UTC
reopening since Enrico provided info

I'm currently running plasmashell under callgrind, so will have that trace too if I reproduce it today
Comment 14 Enrico Tagliavini 2016-11-09 14:37:29 UTC
Interesting new discovery. Yesterday and today the CPU usage of plasma was quite more tame than usual.

I have to digress a bit here, sorry: it's quite a long time I have two identical panels in my desktop, one per monitor. The reason is the infamous problematic multi screen support. If I was booting the laptop without an external monitor attached there was quite an high chance (around 50%) that my panel was not displayed. So I added a second one and this worked the problem around, I was getting one of the two. [end of digression].

With 5.8 multi screen situation improved, and I'm hopeful I can actually remove the second panel and live with only one. So I removed the second panel yesteday morning. Today I was a bit surprised because, while the plasma CPU usage increased over time it increased at a slower peace. So I added a second (default) panel. Plasmashell exhausted the system memory in a matter of second (for a total of 10 GB, the rest was already in use by other stuff)

[23477.201126] Out of memory: Kill process 2358 (plasmashell) score 535 or sacrifice child
[23477.201134] Killed process 2358 (plasmashell) total-vm:19426516kB, anon-rss:10795480kB, file-rss:0kB, shmem-rss:28452kB
[23477.682638] oom_reaper: reaped process 2358 (plasmashell), now anon-rss:0kB, file-rss:0kB, shmem-rss:28452kB

I started a new one, the second panel was there. I sent myself a message to trigger the telepathy icon in the systray (I had two of them now), issue appeared quite quickly. I removed the telepathy notification and also the second panel. CPU usage of plasma is still very high.

So I think this is quite an important condition to reproduce the issue: have more than one panel. I'm not sure if some of the widgets are more involved than others, but I guess the systray could be a good start. That however is not involved at all in the window switching, which would point to the task manager instead. In my testing I had two of both.
Comment 15 Hubert Kario 2016-11-09 15:14:12 UTC
yes, I think the Kopete blinking icon does make the issue more pronounced, but I had it happen also when I forgot to log in to Kopete, so I obviously couldn't get any messages triggering the blinking...

Issue with how the panel is handled in general sounds likely though
Comment 16 Hubert Kario 2016-11-09 16:28:55 UTC
Created attachment 102146 [details]
perf top annotate of handleSignal method

what's a bit weird, that even with fresh plasmashell process, `perf top` reports a lot of time being spent in QDBusConnectionPrivate::handleSignal from libQt5DBus.so
Comment 17 Raman Gupta 2016-11-11 00:10:26 UTC
Here is another report that seems related to the virtualization mentioned in comment #4, this time with VMWare:

https://bugs.kde.org/show_bug.cgi?id=361497
Comment 18 Enrico Tagliavini 2016-11-11 12:35:05 UTC
Created attachment 102168 [details]
callgrind record of plasma shell (slow performance)

I've run a profiling run with callgrind. I started it with

valgrind --tool=callgrind --instr-atstart=no --callgrind-out-file=plasmashell-callgrind.out -- plasmashell --shut-up

so the instrumentation was not on during the whole startup. I waited a couple of hours with two panels and something animating in the systray. Once the CPU usage was maximized I started the instrumentation and also started switching active window as fast I could by using the mouse between two. Then I stopped instrumentation and stopped valgrind.

Oddly enough, while plasma uses a lot of CPU and is quite slower compared to a fresh start, the system performance was not dragged down as much. Usually the whole system feels slower when plasma starts using more resources, for example kwin animations are much slower. Firefox feels slower. Probably everything related to rendering feels slower. Likely valgrind just shuffling the conditions, but I thought I should mention it.
Comment 19 kolorafa 2017-01-11 10:09:37 UTC
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
kolorafa 27275 15.5 37.8 282921676 6176060 ?   Sl   sty03 1879:08  \_ /usr/bin/plasmashell --shut-up


I have the exact same thing (100% cpu when tray icon change/blinks).

If you have any blinking icon in systray over a time it uses more and more cpu and after few hours it is like 100% cpu for every icon switch.


And aditionally after 23 days of system uptime with blinking icons i opened huge page in crome, normally only chrome would freeze for some time because of cpu, but the whole plasma did freeze and started to behave crazy ... 
I opened the shell and saw 100% MEM (16G) and swap (4G)
I did kill chrome and now i see that plasmashell still uses 6GB of ram (RSS).

If that would help i could try some profiling because on my 8G laptop that i use the same way i need to reboot my box just to get plasmashell use less memory after 24h.
Comment 20 Fajri 2017-02-27 20:14:48 UTC
Tolong diperbaiki bug tolol selalu crash juga memakan memory dan cpu yang sangat tinggi ketika dioperasikan.thank
Comment 21 David Edmundson 2017-04-10 19:35:07 UTC
Please do not repoen bugs randomly.

*** This bug has been marked as a duplicate of bug 378010 ***