- 1 Installing
- 2 Add-ons
- 3 Plugins
- 4 Configuration
- 5 Tips and tricks
- 6 Troubleshooting
- 6.1 All Firefox extensions disabled (May 2019)
- 6.2 Firefox startup takes very long
- 6.3 Font troubleshooting
- 6.4 Setting an email client
- 6.5 File association
- 6.6 Firefox keeps creating ~/Desktop even when this is not desired
- 6.7 Make plugins respect blocked pop-ups
- 6.8 Middle-click behavior
- 6.9 Backspace does not work as the 'Back' button
- 6.10 Firefox does not remember login information
- 6.11 "Do you want Firefox to save your tabs for the next time it starts?" dialog does not appear
- 6.12 Firefox detects the wrong version of my plugin
- 6.14 Firefox does not remember default spell check language
- 6.15 Some MathML symbols are missing
- 6.16 Tearing video in fullscreen mode
- 6.17 Firefox WebRTC module cannot detect a microphone
- 7 See also
Firefox can be installed with the package.
Other alternatives include:
- Firefox Developer Edition — for developers
- Firefox Extended Support Release — long-term supported version
- https://www.mozilla.org/firefox/organizations/ || AUR or AUR
- Firefox Beta — cutting-edge version
- https://www.mozilla.org/firefox/channel/desktop/#beta || AUR or AUR
- Firefox Nightly — nightly builds for testing (experimental features)
- Firefox KDE — Version of Firefox that incorporates an OpenSUSE patch for better KDE integration than is possible through simple Firefox plugins.
- On top of the different Mozilla build channels, a number of forks exist with more or less special features; see List of applications#Gecko-based.
A number of language packs are available for Firefox, other than the standard English. Language packs are usually named as
languagecode can be any language code, such as de, ja, fr, etc.). For a list of available language packs see firefox-i18n for ,firefox-developer-edition-i18n for and firefox-nightly- for AUR.
Firefox is well known for its large library of add-ons which can be used to add new features or modify the behavior of existing features. Firefox's "Add-ons Manager" is used to manage installed add-ons or find new ones.
For instructions on how to install add-ons and a list of add-ons, see Browser extensions.
Adding search engines
Search engines can be added to Firefox through normal add-ons, see this page for a list of available search engines.
A very extensive list of search engines can be found at the Mycroft Project.
Also, you can use the add-to-searchbar extension to add a search to your search bar from any web site, by simply right clicking on the site's search field and selecting Add to Search Bar...
Install the AUR package to add Arch-specific searches (AUR, wiki, forum, etc, as specified by user) to the Firefox search toolbar.
To find out what plugins are installed/enabled, enter:
in the Firefox address bar or go to the Add-ons entry in the Firefox Menu and select the Plugins tab.
Firefox exposes a number of configuration options. To examine them, enter in the Firefox address bar:
Once set, these affect the user's current profile, and may be synchronized across all devices via Firefox Sync. Please note that only a subset of the
about:config entries are synchronized by this method, and the exact subset may be found by searching for
about:config. Additional preferences and third party preferences may be synchronized by creating new boolean entries prepending the config value with
services.sync.prefs.sync (documentation is still applicable.) To synchronize the whitelist for the extension NoScript:
noscript.sync.enabled must be set to
true to synchronize the remainder of NoScript's preferences via Firefox Sync.
Firefox also allows configuration for a profile via a
user.js file: user.js kept in the profile folder, usually
~/.mozilla/firefox/xxxxxxxx.default/. For a useful starting point, see e.g custom user.js which is targeted at privacy/security conscious users.
One drawback of the above approach is that it is not applied system-wide. Furthermore, this is not useful as a "pre-configuration", since the profile directory is created after first launch of the browser. You can, however, let firefox create a new profile and, after closing it again, copy the contents of an already created profile folder into it.
Sometimes it may be desired to lock certain settings, a feature useful in widespread deployments of customized Firefox. In order to create a system-wide configuration, follow the steps outlined in Locking preferences:
pref("general.config.obscure_value", 0); pref("general.config.filename", "mozilla.cfg");
/usr/lib/firefox/mozilla.cfg (this stores the actual configuration):
// //...your settings... // e.g to disable Pocket, uncomment the following line // lockPref("browser.pocket.enabled", false);
Please note that the first line must contain exactly
//. The syntax of the file is similar to that of
HTML5 DRM playback is supported by the Google Widevine CDM, it is however not enabled by default. See Preferences > General > Digital Rights Management (DRM) Content if you want to learn more.
See Firefox/Tweaks#Enable additional media codecs for advanced configuration and enabling support for Widevine (Netflix, Amazon Video, etc.).
Firefox uses PulseAudio for audio playback and capture. For sound to work, you need to install the package.
In case, for whatever reason, PulseAudio is not an option for you, you can use apulse instead. To make this work, it is necessary to exclude
/dev/snd/ from Firefox' sandboxing by adding it to the comma-separated list in
/dev/snd/is important, otherwise apulse will report "Permission denied" errors.
If you have no audio even when using apulse, try adding
Open With extension
- Install Open With add-on.
- Go to Add-ons > Open With > Preferences.
- Proceed with instructions to install a file in your system and test the installation.
- Click Add browser.
- In the dialog write a name for this menu entry and command to start a video streaming capable player (e.g. /usr/bin/mpv).
- (Optional step) Add needed arguments to the player (e.g. you may want
--force-window --ytdlfor mpv)
- Right click on links or visit pages containing videos. Select newly created entry from Open With's menu and if the site is supported, the player will open as expected.
The same procedure can be used to associate video downloaders such as youtube-dl.
Install thepackage. You also need to install dictionaries for your language, such as (for the French language) or (for Hebrew).
To enable spell checking for a specific language right click on any text field and check the Check Spelling box. To select a language for spell checking to you have right click again and select your language from the Languages sub-menu.
To get more languages just click Add Dictionaries... and select the dictionary you want to install from the list. For Russian there is.
When your default language choice does not stick, see #Firefox does not remember default spell check language.
- To bring the KDE look to GTK apps (including Firefox), install and . Afterwards, go to System Settings > Application Style > GNOME/GTK Application Style. Be sure to choose 'Breeze' in 'Select a GTK2/GTK3 Theme' and check 'Show icons in GTK buttons' and 'Show icons in GTK menus'.
- To make the left mouse button warp the scrollbar instead of the middle one on KDE, go to System Settings > Application Style > GNOME/GTK Application Style and choose 'Jump to the mouse cursor position' in the 'On left-clicking the scroll bar' option.
- To use the KDE file selection and print dialogs in Firefox 64 or newer:
- For integration with KDE MIME type system and file dialog, one can use AUR variant from AUR with OpenSUSE’s patches applied. Alternatively, integration with MIME types can be achieved by creating a symbolic link to the MIME database
~/.config/mimeapps.listfrom the deprecated
~/.local/share/applications/mimeapps.listthat is used by Firefox. See XDG MIME Applications#mimeapps.list.
- Extensions/add-ons may provide additional integration, such as:
- Browser integration in Plasma: requires and the Plasma Integration add-on.
- GNOME Keyring. To make firefox-gnome-keyring use your login keychain, set
In order to get smooth physics-based scrolling in Firefox, the
general.smoothScroll.msdPhysics configurations can be changed to emulate a snappier behaviour like in other web browsers. For a quicker configuration, append the following to
~/.mozilla/firefox/your-profile/user.js (requires restart):
user_pref("general.smoothScroll.lines.durationMaxMS", 125); user_pref("general.smoothScroll.lines.durationMinMS", 125); user_pref("general.smoothScroll.mouseWheel.durationMaxMS", 200); user_pref("general.smoothScroll.mouseWheel.durationMinMS", 100); user_pref("general.smoothScroll.msdPhysics.enabled", true); user_pref("general.smoothScroll.other.durationMaxMS", 125); user_pref("general.smoothScroll.other.durationMinMS", 125); user_pref("general.smoothScroll.pages.durationMaxMS", 125); user_pref("general.smoothScroll.pages.durationMinMS", 125);
Additionally the mouse wheel scroll settings have to be changed to react in a smooth way as well:
user_pref("mousewheel.min_line_scroll_amount", 30); user_pref("mousewheel.system_scroll_override_on_root_content.enabled", true); user_pref("mousewheel.system_scroll_override_on_root_content.horizontal.factor", 175); user_pref("mousewheel.system_scroll_override_on_root_content.vertical.factor", 175); user_pref("toolkit.scrollbox.horizontalScrollDistance", 6); user_pref("toolkit.scrollbox.verticalScrollDistance", 2);
If you have troubles on machines with varying performance, try modifying the
mousewheel.min_line_scroll_amount until it feels snappy enough.
Tips and tricks
If a dark GTK theme is in use (e.g. Arc Dark), it is recommended to start Firefox with a brighter one (e.g. Adwaita). See GTK#Themes and Firefox/Tweaks#Unreadable input fields with dark GTK themes for more information.
Alternatively, starting with Firefox 68 you can make the all Firefox interfaces and even other websites respect dark themes, irrespective of the system GTK theme and Firefox theme. To do this, set
If you have a high refresh rate monitor, Firefox might not be able to automatically detect the right value, in which case it will default to rendering at 60 Hz. To manually set this, set
layout.frame_rate to the refresh rate of your monitor, e.g. 144 for 144 Hz.
To prevent pages from abusing memory (and possible OOM), we can use Firejail with the
Decreasing swappiness may also help.
New tabs position
To control where new tabs appears (relative or absolute), use
browser.tabs.insertRelatedAfterCurrent. See  for more informations.
Screenshot of webpage
You can Take a Screenshot by either clicking the Page actions button (the three horizontal dots) in the address bar or by right-clicking on the webpage. See  for more information.
- The Save button misleadingly uploads your screenshot to a firefox.com subdomain. Set
trueto disable this behaviour. 
- If privacy.resistFingerprinting is enabled, to take a screenshot of a website using the above method, you need to grant it Extract Canvas Data permission.
As an alternative you can use the full-page screenshot button in the Developer Tools, which you can open with
Ctrl+Shift+i (you might need to enable the button first in the Developer Tools Settings > Available Toolbox Buttons > Take a screenshot of the entire page).
More recent versions of Firefox support opting into Wayland via an environment variable.
To opt in, first make sure you really are in a Wayland session:
$ printenv XDG_SESSION_TYPE
Next, start Firefox like this:
$ MOZ_ENABLE_WAYLAND=1 firefox
Next go to about:support in the URL bar and check the Window Protocol field. If this worked, then it should say
wayland. Otherwise, it will say
To make this permanent, edit Firefox's .desktop file (
firefox.desktop) and add
env MOZ_ENABLE_WAYLAND=1 to all
Exec= lines. See Desktop entries#Modify environment variables for instructions.
Finally, open Firefox via the launcher like you normally would and verify it worked by checking Window Protocol again.
Window manager rules
To apply different configurations to Firefox windows, change the WM_CLASS string by using Firefox's
--class option, to a custom one.
To start new Firefox instances, multiple profiles are required. To create a new profile:
$ firefox [--new-instance] -P
Class can be specified when launching Firefox with a not-in-use profile:
$ firefox [--new-instance] -P profile_name --class=class_name
Touchscreen gestures and pixel-perfect trackpad scrolling
To enable touch gestures (like scrolling and pinch-to-zoom) and one-to-one trackpad scrolling (as can be witnessed with GTK3 applications like Nautilus), set the
MOZ_USE_XINPUT2=1 environment variable before starting Firefox.
All Firefox extensions disabled (May 2019)
Between 3–5 May 2019, all Firefox addons (web extensions, themes, search engines, and language packs) were mistakenly marked as Legacy addons, and could not be enabled. The bug was caused by an expired intermediate certificate.
For most users, the issue has been fixed in Firefox 66.0.4 and Firefox ESR 60.6.2. The addons should be automatically re-enabled as soon as the patched version of Firefox is installed. Certain users, such as those who have set a Master Password, might require extra steps. Please see Firefox's official support page for more information.
Firefox startup takes very long
If Firefox takes much longer to start up than other browsers, it may be due to lacking configuration of the localhost in
/etc/hosts. See Network configuration#Local network hostname resolution on how to set it up.
See Font configuration.
Firefox has a setting which determines how many replacements it will allow from fontconfig. To allow it to use all your replacement-rules, change
127 (the highest possible value).
Setting an email client
Inside the browser,
mailto links by default are opened by a web application such as Gmail or Yahoo Mail. To set an external email program, go to Preferences > Applications and modify the action corresponding to the
mailto content type; the file path will need to be designated (e.g.
/usr/bin/kmail for Kmail).
See Default applications.
Firefox keeps creating ~/Desktop even when this is not desired
~/Desktop as the default place for download and upload files. To change it to another folder, set the
XDG_DESKTOP_DIR option as explained in XDG user directories.
Make plugins respect blocked pop-ups
Some plugins can misbehave and bypass the default settings, such as the Flash plugin. You can prevent this by doing the following:
about:configinto the address bar.
- Right-click on the page and select New > Integer.
- Name it
- Set the value to
The possible values are:
0: Allow all popups from plugins.
1: Allow popups, but limit them to
2: Block popups from plugins.
3: Block popups from plugins, even on whitelisted sites.
To use the middle mouse button to paste whatever text has been highlighted/added to the clipboard, as is common in UNIX-like operating systems, set either
middlemouse.contentLoadURL enabled was the default behaviour prior to Firefox 57.
To scroll on middle-click (default for Windows browsers) set
According to MozillaZine, the
Backspace key was mapped based on which platform the browser was running on. As a compromise, this preference was created to allow the
Backspace key to either go back/forward, scroll up/down a page, or do nothing.
Backspace go back one page in the tab's history and
Shift+Backspace go forward, set
To have the
Backspace key scroll up one page and
Shift+Backspace scroll down one page, set
1. Setting this property to any other value will leave the key unmapped (Arch Linux defaults to
2, in other words, it is unmapped by default).
Firefox does not remember login information
It may be due to a corrupted
cookies.sqlite file in Firefox's profile folder. In order to fix this, just rename or remove
cookie.sqlite while Firefox is not running.
Open a terminal of choice and type the following:
$ rm -f ~/.mozilla/firefox/<profile id>.default/cookies.sqlite
The profile id is a random 8 character string.
Restart Firefox and see if it solved the problem.
"Do you want Firefox to save your tabs for the next time it starts?" dialog does not appear
From the Mozilla support site:
about:configin the address bar.
Firefox detects the wrong version of my plugin
When you close Firefox, the latter saves the current timestamp and version of your plugins inside
pluginreg.dat located in your profile folder, typically in
If you upgraded your plugin when Firefox was still running, you will thus have the wrong information inside that file. The next time you will restart Firefox you will get that message
Firefox has prevented the outdated plugin "XXXX" from running on ... when you will be trying to open content dedicated to that plugin on the web. This problem often appears with the official Adobe Flash Player plugin which has been upgraded while Firefox was still running.
The solution is to remove the file
pluginreg.dat from your profile and that is it. Firefox will not complain about the missing file as it will be recreated the next time Firefox will be closed. 
You can try setting
Firefox does not remember default spell check language
The default spell checking language can be set as follows:
about:configin the address bar.
spellchecker.dictionaryto your language of choice, for instance
- Notice that the for dictionaries installed as a Firefox plugin the notation is
en-GB, and for dictionaries the notation is
When you only have system wide dictionaries installed with dictionary installed as a Firefox plugin. Notice that now you will also have a tab Dictionaries in Add-ons. You may have to change the order of preferred language for displaying pages in
about:preferences#general to make the spell check default to the language of the addon dictionary.
Some MathML symbols are missing
You need some Math fonts, namely Latin Modern Math and STIX (see this MDN page: ), to display MathML correctly.
Tearing video in fullscreen mode
If you are using the Xorg Intel or Nouveau drivers and experience tearing video in fullscreen mode, try Firefox tweaks#Enable OpenGL Off-Main-Thread Compositing (OMTC).
Firefox WebRTC module cannot detect a microphone
WebRTC applications for instance Firefox WebRTC getUserMedia test page say that microphone cannot be found. Issue is reproducible for both ALSA or PulseAudio setup. Firefox debug logs show the following error:
$ NSPR_LOG_MODULES=MediaManager:5,GetUserMedia:5 firefox
... [Unnamed thread 0x7fd7c0654340]: D/GetUserMedia VoEHardware:GetRecordingDeviceName: Failed 1
You can try setting
media.navigator.audio.full_duplex property to
about:config Firefox page and restart Firefox.
This can also help if you are using the PulseAudio module-echo-cancel and Firefox does not recognise the virtual echo canceling source.