From: "Jose A. Ortega Ruiz" <mail@jao.io>
To: 56546@debbugs.gnu.org
Subject: bug#56546: 29.0.50; unbounded RAM comsumption when displaying images
Date: Thu, 14 Jul 2022 02:35:46 +0100 [thread overview]
Message-ID: <87cze84gst.fsf@mail.jao.io> (raw)
It seems to be easy to make emacs (under X) to consume more and more
RAM, which is never released, by making it display images. A extreme
(in my experience) case is animated GIFs, try:
- emacs -Q
- M-x eww RET https://xenodium.com/emacs-zones-to-lift-you-up/
- RAM consumption grows to ~600Mb
- R (redisplay page): RAM grows to ~1100Mb
- R (redisplay page): RAM grows to ~1752Mb
- R (redisplay page): RAM grows to ~2222Mb
- rinse and repeat: RAM never goes down
- (image-cache-size) reports a modest 82Mb
- Kill buffer: high RAM consumption is still at its maximum, even
after (image-cache-size) goes to 0
My impression is that this bad behaviour is not limited to animated
gifts, although for regular images i don't have a solid recipe: what i
observe is that running long sessions in term mode for days of continous
use in an xterm, RAM tops at about 0.5Mb, while running similar sessions
under X (using the same packages and doing the same kind of things
inside of emacs), RAM will steadily increase. The only difference
between the two scenarios i can think of is that in X i sometimes
display images, mainly in eww and, sometimes, inside HTML email messages
rendered via shr. I also observe that while it's pretty common for
emacs in an x term (either run directly or connected to a demon) to
release memory (i.e., to have its RSS decrease), that almost never
happens when running under X: there RAM almost never goes down, no
matter what.
In GNU Emacs 29.0.50 (build 16, x86_64-pc-linux-gnu, cairo version 1.16.0)
of 2022-07-14 built on rivendell
Repository revision: 9a888323c60c60fb37f471ef03f0bcdff91cb850
Repository branch: master
System Description: Debian GNU/Linux bookworm/sid
Configured using:
'configure --prefix=/usr/local/stow/emacs --with-x-toolkit=no
--with-imagemagick'
Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ
IMAGEMAGICK JPEG JSON LCMS2 LIBOTF LIBSELINUX LIBSYSTEMD LIBXML2
M17N_FLT MODULES NOTIFY INOTIFY OLDXMENU PDUMPER PNG RSVG SECCOMP SOUND
SQLITE3 THREADS TIFF WEBP X11 XDBE XIM XINPUT2 XPM ZLIB
Important settings:
value of $LANG: en_GB.UTF-8
locale-coding-system: utf-8-unix
Major mode: Lisp Interaction
Minor modes in effect:
telega-root-auto-fill-mode: t
telega-active-locations-mode: t
telega-patrons-mode: t
telega-mode-line-mode: t
diff-hl-margin-mode: t
global-diff-hl-mode: t
eshell-vterm-mode: t
eshell-syntax-highlighting-global-mode: t
pdf-occur-global-minor-mode: t
winner-mode: t
global-git-commit-mode: t
magit-auto-revert-mode: t
global-auto-revert-mode: t
shell-dirtrack-mode: t
vertico-mode: t
global-company-mode: t
company-mode: t
marginalia-mode: t
persistent-scratch-autosave-mode: t
global-so-long-mode: t
pulsar-global-mode: t
pulsar-mode: t
display-battery-mode: t
jao-minibuffer-mode: t
minibuffer-electric-default-mode: t
minibuffer-depth-indicate-mode: t
xclip-mode: t
repeat-mode: t
savehist-mode: t
recentf-mode: t
save-place-mode: t
override-global-mode: t
tooltip-mode: t
global-eldoc-mode: t
eldoc-mode: t
show-paren-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
column-number-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
Load-path shadows:
/home/jao/lib/elisp/org-static-blog/org-static-blog hides /home/jao/.emacs.d/elpa.29/org-static-blog-20220508.1410/org-static-blog
/home/jao/etc/emacs/site/custom hides /usr/local/stow/emacs/share/emacs/29.0.50/lisp/custom
/home/jao/.emacs.d/elpa.29/transient-20220527.2213/transient hides /usr/local/stow/emacs/share/emacs/29.0.50/lisp/transient
Features:
(shadow mailalias bbdb-message vertico-directory tramp-cmds sort
gnus-cite mm-archive mail-extr textsec uni-scripts idna-mapping
ucs-normalize uni-confusable textsec-check gnus-async gnus-bcklg
gnus-dup qp gnus-ml gnus-topic nnml bbdb-gnus network-stream bbdb-mua
gnus-icalendar icalendar ol-gnus nnselect org-capture gnus-delay
gnus-draft gnus-agent gnus-srvr gnus-score score-mode nnvirtual
gnus-cache gnus-msg gnus-art mm-uu mml2015 mm-view mml-smime smime dig
gnus-sum nndraft nnmh gnus-demon nntp gnus-group gnus-undo gnus-start
gnus-dbus gnus-cloud nnimap nnmail mail-source utf7 netrc nnoo gnus-spec
gnus-int gnus-range gnus-win org-duration org-appear org-agenda
org-refile cal-iso mule-util cal-move bigml bml-logs bml bml-misc
bml-whizzml bml-clojure bml-clj-tests bml-python bml-skels bml-utils
multisession sqlite whizzml-skeletons whizzml-mode lice sieve sieve-mode
sieve-manage sasl sasl-anonymous sasl-login sasl-plain jao-mpc
jao-random-album jao-lyrics jao-mpris telega-obsolete telega
telega-tdlib-events telega-webpage visual-fill-column telega-match
telega-root telega-info telega-chat telega-modes telega-company
telega-user telega-notifications telega-voip telega-msg telega-tme
telega-sticker telega-i18n telega-vvnote bindat telega-ffplay
telega-sort telega-filter telega-ins telega-folders telega-inline
telega-util telega-media telega-tdlib rainbow-identifiers dired-aux
telega-server telega-core cursor-sensor telega-customize emacsbug
jao-mullvad bluetooth enwc enwc-backend json-mode json-snatcher js
cc-mode cc-fonts cc-guess cc-menus cc-cmds cc-styles cc-align cc-engine
cc-vars cc-defs yaml-mode virtualenvwrapper gud ediprolog pie
haskell-doc inf-haskell haskell-decl-scan haskell haskell-completions
haskell-load haskell-commands highlight-uses-mode haskell-modules
haskell-sandbox haskell-navigate-imports haskell-repl haskell-svg
haskell-collapse hideshow haskell-debug haskell-interactive-mode
haskell-presentation-mode haskell-compile haskell-hoogle haskell-process
haskell-session haskell-mode haskell-cabal haskell-utils
haskell-font-lock haskell-indentation haskell-string
haskell-sort-imports haskell-lexeme haskell-align-imports
haskell-complete-module haskell-ghc-support flymake-proc flymake
warnings dabbrev haskell-customize geiser-guile info-look geiser-repl
geiser-compile geiser-debug geiser-image geiser-capf geiser-doc
geiser-menu geiser-edit etags fileloop xref project geiser-completion
geiser-autodoc geiser-eval geiser-connection geiser-syntax scheme
geiser-impl help-fns radix-tree geiser-log geiser-popup view
geiser-custom geiser-base geiser idris-mode idris-commands
idris-hole-list idris-ipkg-mode idris-tree-info idris-warnings-tree
idris-info idris-repl idris-highlight-input idris-prover inferior-idris
idris-warnings idris-log idris-events idris-simple-indent idris-syntax
idris-common-utils idris-settings idris-keys idris-core idris-compat
prop-menu package-lint finder lisp-mnt edit-list outline-minor-faces
git-modes gitignore-mode gitconfig-mode conf-mode gitattributes-mode
git-link git-timemachine diff-hl-margin diff-hl-dired diff-hl log-view
vc-dir ewoc vc jao-eshell-here eshell-autojump em-dirs esh-var eshell-up
git-ps1-mode eshell-vterm em-term eshell-syntax-highlighting em-alias
vterm tramp tramp-loaddefs trampver tramp-integration files-x
tramp-compat ls-lisp face-remap term ehelp vterm-module term/xterm xterm
jao-custom-email bbdb-anniv bbdb-com bbdb bbdb-site timezone randomsig
nov esxml-query saveplace-pdf-view pdf-occur ibuf-ext ibuffer
ibuffer-loaddefs tablist tablist-filter semantic/wisent/comp
semantic/wisent semantic/wisent/wisent semantic/util-modes semantic/util
semantic semantic/tag semantic/lex semantic/fw mode-local cedet
pdf-isearch pdf-misc socks elpher jao-custom-eww ol-eww jao-eww-session
eww xdg url-queue mm-url gnus nnheader range markdown-toc
jao-custom-blog htmlize jao-custom-org jao-org-links jao-doc-view
doc-view pdf-tools pdf-view pdf-cache pdf-info tq pdf-util pdf-macs
image-mode exif ol-info ol-eshell esh-mode eshell esh-cmd esh-ext
esh-opt esh-proc esh-io esh-arg esh-module esh-groups esh-util
jao-org-notes ob-shell ob-scheme ob-python python ob-org ob-ocaml
ob-makefile ob-haskell ob-gnuplot ob-clojure ob-calc calc-store
calc-trail ob-prolog prolog smie align org-tempo tempo ox-texinfo
ox-latex ox-html table ox-ascii ox-publish ox org-fragtog org-element
avl-tree generator jao-afio winner consult-recoll embark-consult
consult-vertico consult compat-28 magit-bookmark bookmark jao-recoll org
ob ob-tangle ob-ref ob-lob ob-table ob-exp org-macro org-footnote
org-src ob-comint org-pcomplete org-list org-faces org-entities
org-version ob-emacs-lisp ob-core ob-eval org-table oc-basic bibtex ol
org-keys oc org-compat org-macs org-loaddefs find-func
jao-custom-completion embark-vc s code-review code-review-actions
code-review-comment code-review-section code-review-bitbucket
code-review-faces shr pixel-fill kinsoku url-file url-dired svg dom
emojify apropos tar-mode arc-mode archive-mode ht code-review-gitlab
code-review-utils code-review-parse-hunk code-review-github
code-review-db uuidgen calc-misc calc-ext calc calc-loaddefs rect
calc-macs a code-review-interfaces deferred forge-list forge-commands
forge-semi forge-bitbucket buck forge-gogs gogs forge-gitea gtea
forge-gitlab glab forge-github ghub-graphql treepy gsexp ghub let-alist
gnutls forge-notify forge-revnote forge-pullreq forge-issue forge-topic
yaml parse-time iso8601 bug-reference forge-post markdown-mode
edit-indirect noutline outline forge-repo forge forge-core forge-db
closql emacsql-sqlite advice emacsql emacsql-compiler url-http url-auth
url-gw nsm magit-submodule magit-obsolete magit-blame magit-stash
magit-reflog magit-bisect magit-push magit-pull magit-fetch magit-clone
magit-remote magit-commit magit-sequence magit-notes magit-worktree
magit-tag magit-merge magit-branch magit-reset magit-files magit-refs
magit-status magit magit-repos magit-apply magit-wip magit-log
which-func magit-diff smerge-mode diff git-commit log-edit message
sendmail yank-media puny rfc822 mml mml-sec gnus-util time-date
mm-decode mm-bodies mm-encode mail-parse rfc2231 rfc2047 rfc2045 mm-util
ietf-drums mail-prsvr mailabbrev mail-utils gmm-utils mailheader
pcvs-util add-log magit-core magit-autorevert autorevert filenotify
magit-margin magit-transient magit-process with-editor shell pcomplete
magit-mode magit-git magit-base magit-section crm dash compat-27
compat-26 embark ffap thingatpt vertico company-keywords company-dabbrev
company-files company-capf company pcase marginalia orderless imenu
jao-skel-latex jao-skel-haskell jao-compilation jao-skel-lisp
jao-skel-geiser jao-skel skeleton autoinsert wgrep grep compile
text-property-search comint ring jka-compr dired-x dired dired-loaddefs
persistent-scratch so-long cal-china lunar solar cal-dst cal-bahai
cal-islam cal-hebrew holidays holiday-loaddefs vc-git diff-mode
vc-dispatcher appt diary-lib diary-loaddefs cal-menu calendar
cal-loaddefs pulsar pulse color tmr jao-tracking tracking shorten
jao-notify alert log4e notifications gntp battery jao-mode-line
jao-minibuffer minibuf-eldef mb-depth xclip diminish
jao-light-term-theme jao-themes ansi-color disp-table server pinentry
epa-file epa derived epg rfc6068 epg-config transient format-spec compat
cus-edit pp cus-load repeat edmacro kmacro jao-shell jao-sleep dbus xml
savehist recentf tree-widget wid-edit saveplace jao-gnus-private
gnu-elpa-keyring-update cl-extra help-mode use-package
use-package-ensure use-package-delight use-package-diminish
use-package-bind-key bind-key easy-mmode use-package-core finder-inf
tex-site bbdb-autoloads cider-autoloads clojure-mode-autoloads
company-autoloads diff-hl-autoloads edit-indirect-autoloads
elpher-autoloads embark-consult-autoloads consult-autoloads
embark-vc-autoloads embark-autoloads code-review-autoloads
forge-autoloads ghub-autoloads git-link-autoloads idris-mode-autoloads
json-mode-autoloads rx link-hint-autoloads magit-autoloads
git-commit-autoloads magit-section-autoloads marginalia-autoloads
markdown-mode-autoloads org-appear-autoloads org-fragtog-autoloads
outline-minor-faces-autoloads paredit-autoloads pdf-tools-autoloads
persistent-scratch-autoloads pulsar-autoloads racket-mode-autoloads
request-autoloads switch-window-autoloads telega-autoloads tmr-autoloads
vertico-autoloads dash-autoloads vterm-autoloads with-editor-autoloads
info compat-autoloads xclip-autoloads yaml-autoloads package browse-url
url url-proxy url-privacy url-expand url-methods url-history url-cookie
generate-lisp-file url-domsuf url-util mailcap url-handlers url-parse
auth-source cl-seq eieio eieio-core cl-macs password-cache json subr-x
map byte-opt gv bytecomp byte-compile cconv url-vars cl-loaddefs cl-lib
rmc iso-transl tooltip eldoc paren electric uniquify ediff-hook vc-hooks
lisp-float-type elisp-mode mwheel term/x-win x-win term/common-win x-dnd
tool-bar dnd fontset image regexp-opt fringe tabulated-list replace
newcomment text-mode lisp-mode prog-mode register page tab-bar menu-bar
rfn-eshadow isearch easymenu timer select scroll-bar mouse jit-lock
font-lock syntax font-core term/tty-colors frame minibuffer nadvice seq
simple cl-generic indonesian philippine cham georgian utf-8-lang
misc-lang vietnamese tibetan thai tai-viet lao korean japanese eucjp-ms
cp51932 hebrew greek romanian slovak czech european ethiopic indian
cyrillic chinese composite emoji-zwj charscript charprop case-table
epa-hook jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button
loaddefs faces cus-face macroexp files window text-properties overlay
sha1 md5 base64 format env code-pages mule custom widget keymap
hashtable-print-readable backquote threads dbusbind inotify lcms2
dynamic-setting system-font-setting font-render-setting cairo xinput2 x
multi-tty make-network-process emacs)
Memory information:
((conses 16 1050346 86454)
(symbols 48 89440 112)
(strings 32 323218 19301)
(string-bytes 1 9679236)
(vectors 16 148160)
(vector-slots 8 2070697 64427)
(floats 8 1357 901)
(intervals 56 4457 7319)
(buffers 992 29))
--
The greatest of faults, I should say, is to be conscious of none.
-Thomas Carlyle, writer (1795-1881)
next reply other threads:[~2022-07-14 1:35 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-07-14 1:35 Jose A. Ortega Ruiz [this message]
2022-07-14 5:45 ` bug#56546: 29.0.50; unbounded RAM comsumption when displaying images Eli Zaretskii
2022-07-14 6:04 ` Eli Zaretskii
2022-07-14 8:53 ` Lars Ingebrigtsen
2022-07-14 9:15 ` Eli Zaretskii
2022-07-14 9:20 ` Lars Ingebrigtsen
2022-07-14 10:01 ` Lars Ingebrigtsen
2022-07-14 10:10 ` Eli Zaretskii
2022-07-14 10:15 ` Lars Ingebrigtsen
2022-07-14 12:23 ` Jose A. Ortega Ruiz
2022-07-14 16:59 ` Lars Ingebrigtsen
2022-07-14 17:26 ` Eli Zaretskii
2022-07-14 17:51 ` Glenn Morris
2022-07-14 18:08 ` Lars Ingebrigtsen
2022-07-15 23:42 ` Jose A. Ortega Ruiz
2022-07-16 10:37 ` Lars Ingebrigtsen
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87cze84gst.fsf@mail.jao.io \
--to=mail@jao.io \
--cc=56546@debbugs.gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).