source: xsoft/graphweb/firefox.xml@ 7877690

12.1 ken/TL2024 ken/tuningfonts lazarus plabs/newcss python3.11 rahul/power-profiles-daemon renodr/vulkan-addition trunk xry111/llvm18
Last change on this file since 7877690 was 7877690, checked in by Xi Ruoyao <xry111@…>, 10 months ago

firefox: Remove zip dependency, and demote yasm to optional

I can build it w/o zip and I cannot see how zip is used. And yasm is
only used for building shipped libvpx, but we are recommending system
libvpx anyway.

  • Property mode set to 100644
File size: 23.2 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY firefox-download-http "&mozilla-http;/firefox/releases/&firefox-version;esr/source/firefox-&firefox-version;esr.source.tar.xz">
8 <!ENTITY firefox-download-ftp " ">
9 <!ENTITY firefox-md5sum "747043bb967bdbc6f4bd3b29b5bdd438">
10 <!ENTITY firefox-size "491 MB">
11
12 <!-- NB with stylo, much of the build uses rust, and therefore cargo files.
13 But the extra cached cargo files, if any, seem to be minimal -->
14 <!ENTITY firefox-buildsize "6.4 GB (209 MB installed) without tests">
15 <!-- editors: with ff63 and rust-1.29, ./mach build -j4 is probably the
16 most practical way to get a timing on a machine with more cores, if taking
17 cores offline is not practical. If in doubt, round up -->
18 <!ENTITY firefox-time "22 SBU using -j4, without tests">
19]>
20
21<sect1 id="firefox" xreflabel="Firefox-&firefox-version;">
22 <?dbhtml filename="firefox.html" ?>
23
24
25<!-- indicate this is the ESR variant,
26 The point is that the stable release differs slightly.
27 <title>Firefox-&firefox-version;</title>-->
28 <title>Firefox-&firefox-version;esr</title>
29
30 <indexterm zone="firefox">
31 <primary sortas="a-Firefox">Firefox</primary>
32 </indexterm>
33
34 <sect2 role="package">
35 <title>Introduction to Firefox</title>
36
37 <para>
38 <application>Firefox</application> is a stand-alone browser based on the
39 <application>Mozilla</application> codebase.
40 </para>
41
42 &lfs120_checked;
43
44 <bridgehead renderas="sect3">Package Information</bridgehead>
45 <itemizedlist spacing="compact">
46 <listitem>
47 <para>
48 Download (HTTP): <ulink url="&firefox-download-http;"/>
49 </para>
50 </listitem>
51 <listitem>
52 <para>
53 Download (FTP): <ulink url="&firefox-download-ftp;"/>
54 </para>
55 </listitem>
56 <listitem>
57 <para>
58 Download MD5 sum: &firefox-md5sum;
59 </para>
60 </listitem>
61 <listitem>
62 <para>
63 Download size: &firefox-size;
64 </para>
65 </listitem>
66 <listitem>
67 <para>
68 Estimated disk space required: &firefox-buildsize;
69 </para>
70 </listitem>
71 <listitem>
72 <para>
73 Estimated build time: &firefox-time;
74 </para>
75 </listitem>
76 </itemizedlist>
77
78<!--<bridgehead renderas="sect3">Additional Downloads</bridgehead>
79 <itemizedlist spacing="compact">
80 <listitem>
81 <para>
82 Required patch:
83 <ulink url="&patch-root;/firefox-&firefox-version;-consolidated-1.patch"/>
84 </para>
85 </listitem>
86 <listitem>
87 <para>
88 Required patch for new <xref linkend="ffmpeg"/> API:
89 <ulink url="&patch-root;/firefox-&firefox-version;-ffmpeg_6-1.patch"/>
90 </para>
91 </listitem>
92 </itemizedlist>-->
93
94 <note>
95 <para>
96 The directory name is firefox-&firefox-version;
97 </para>
98
99 <para>
100 Extracting the tarball
101 will reset the permissions of the current directory to 0755 if you
102 have permission to do that. If you do this in a directory where
103 the sticky bit is set, such
104 as <filename class="directory">/tmp</filename> it will end with error
105 messages:
106 </para>
107
108<literallayout>tar: .: Cannot utime: Operation not permitted
109tar: .: Cannot change mode to rwxr-xr-t: Operation not permitted
110tar: Exiting with failure status due to previous errors
111</literallayout>
112
113 <para>
114 This does finish with non-zero status, but it does
115 <emphasis>NOT</emphasis> mean there is a real problem.
116 Do not untar as the <systemitem class="username">root</systemitem> user
117 in a directory where the sticky bit is set - that will unset it.
118 </para>
119
120 <para>
121 As with other large packages which use C++ (or rust), the SBU times
122 to build this vary more widely than you might expect. The build times
123 will increase significantly if your machine has to swap.
124 </para>
125
126 <para>
127 Although upstream prefer to use <application>PulseAudio</application>,
128 for the moment <application>Alsa</application> can still be used. Both
129 may need runtime configuration to get sound working.
130 </para>
131 </note>
132
133 <bridgehead renderas="sect3">Firefox Dependencies</bridgehead>
134
135 <bridgehead renderas="sect4">Required</bridgehead>
136 <para role="required">
137 <xref linkend="cbindgen"/>,
138 <xref linkend="dbus-glib"/>,
139 <xref linkend="gtk3"/>,
140 <xref linkend="libnotify"/>,
141 <xref linkend="llvm"/> (with clang, used for bindgen even if using gcc),
142 <xref linkend="nodejs"/>,
143 <xref linkend="pulseaudio"/>
144 (or
145 <xref linkend="alsa-lib"/> if you edit the mozconfig;
146 now deprecated by mozilla), in either case please read the
147 Configuration Information,
148 <xref linkend="python3"/> (rebuilt after installing <xref linkend="sqlite"/>),
149 <xref linkend="startup-notification"/>, and
150 <xref linkend="unzip"/>
151 </para>
152
153 <bridgehead renderas="sect4">Recommended</bridgehead>
154 <para role="recommended">
155 <xref linkend="icu"/>,
156 <xref linkend="libevent"/>,
157 <xref linkend="libvpx"/>,
158 <xref linkend="libwebp"/>,
159 <xref linkend="nasm"/>,
160 <xref linkend="nss"/>
161 </para>
162
163 <note>
164 <para>
165 If you don't install recommended dependencies, then internal copies of
166 those packages will be used. They might be tested to work, but they can
167 be out of date or contain security holes.
168 </para>
169 </note>
170
171 <bridgehead renderas="sect4">Optional</bridgehead>
172 <para role="optional">
173 <xref linkend="curl"/>,
174 <xref linkend="doxygen"/>,
175 <xref role="runtime" linkend="ffmpeg"/> (runtime, to play mov, mp3 or mp4 files),
176 <xref linkend="liboauth"/>,
177 <xref role="runtime" linkend="pciutils"/> (runtime),
178 <xref linkend="valgrind"/>,
179 <xref linkend="wget"/>,
180 <xref linkend="wireless_tools"/>,
181 <xref linkend="yasm"/>,
182 <ulink url="https://github.com/libproxy/libproxy">libproxy</ulink>
183 </para>
184
185 <para condition="html" role="usernotes">
186 Editor Notes: <ulink url="&blfs-wiki;/firefox"/>
187 </para>
188 </sect2>
189
190 <sect2 role="installation">
191 <title>Installation of Firefox</title>
192
193 <para>
194 The configuration of <application>Firefox</application> is accomplished
195 by creating a <filename>mozconfig</filename> file containing the desired
196 configuration options. A default <filename>mozconfig</filename> is
197 created below. To see the entire list of available configuration options
198 (and an abbreviated description of some of them), issue <command>./mach
199 configure -- --help | less</command>. You may also
200 wish to review the entire file and uncomment any other desired options.
201 Create the file by issuing the following command:
202 </para>
203
204<screen><userinput>cat &gt; mozconfig &lt;&lt; "EOF"
205<literal># If you have a multicore machine, all cores will be used by default.
206
207# If you have installed (or will install) wireless-tools, and you wish
208# to use geolocation web services, comment out this line
209ac_add_options --disable-necko-wifi
210
211# API Keys for geolocation APIs - necko-wifi (above) is required for MLS
212# Uncomment the following line if you wish to use Mozilla Location Service
213#ac_add_options --with-mozilla-api-keyfile=$PWD/mozilla-key
214
215# Uncomment the following line if you wish to use Google's geolocation API
216# (needed for use with saved maps with Google Maps)
217#ac_add_options --with-google-location-service-api-keyfile=$PWD/google-key
218
219# startup-notification is required since firefox-78
220
221# Uncomment the following option if you have not installed PulseAudio and
222# want to use alsa instead
223#ac_add_options --enable-audio-backends=alsa
224
225# Comment out following options if you have not installed
226# recommended dependencies:
227ac_add_options --with-system-icu
228ac_add_options --with-system-libevent
229ac_add_options --with-system-libvpx
230ac_add_options --with-system-nspr
231ac_add_options --with-system-nss
232ac_add_options --with-system-webp
233
234# Unlike with thunderbird, although using the gold linker can
235# save four megabytes in the installed file it does not make
236# the build faster.
237
238# libdav1d (av1 decoder) requires nasm. Uncomment this if nasm
239# has not been installed. Do not uncomment this if you have
240# ffmpeg installed.
241#ac_add_options --disable-av1
242
243# You cannot distribute the binary if you do this
244ac_add_options --enable-official-branding
245
246# Stripping is now enabled by default.
247# Uncomment these lines if you need to run a debugger:
248#ac_add_options --disable-strip
249#ac_add_options --disable-install-strip
250
251# Disabling debug symbols makes the build much smaller and a little
252# faster. Comment this if you need to run a debugger. Note: This is
253# required for compilation on i686.
254ac_add_options --disable-debug-symbols
255
256# The elf-hack is reported to cause failed installs (after successful builds)
257# on some machines. It is supposed to improve startup time and it shrinks
258# libxul.so by a few MB - comment this if you know your machine is not affected.
259ac_add_options --disable-elf-hack
260
261# The BLFS editors recommend not changing anything below this line:
262ac_add_options --prefix=/usr
263ac_add_options --enable-application=browser
264ac_add_options --disable-crashreporter
265ac_add_options --disable-updater
266# enabling the tests will use a lot more space and significantly
267# increase the build time, for no obvious benefit.
268ac_add_options --disable-tests
269
270# The default level of optimization again produces a working build with gcc.
271ac_add_options --enable-optimize
272
273ac_add_options --enable-system-ffi
274ac_add_options --enable-system-pixman
275
276ac_add_options --with-system-jpeg
277ac_add_options --with-system-png
278ac_add_options --with-system-zlib
279
280# Sandboxing works well on x86_64 but might cause issues on other
281# platforms. If not on x86_64, e.g. i686, it is recommended to
282# uncomment the following switch.
283#ac_add_options --disable-sandbox
284
285# Using sandboxed wasm libraries has been moved to all builds instead
286# of only mozilla automation builds. It requires extra llvm packages
287# and was reported to seriously slow the build. Disable it.
288ac_add_options --without-wasm-sandboxed-libraries
289
290# The following option unsets Telemetry Reporting. With the Addons Fiasco,
291# Mozilla was found to be collecting user's data, including saved passwords and
292# web form data, without users consent. Mozilla was also found shipping updates
293# to systems without the user's knowledge or permission.
294# As a result of this, use the following command to permanently disable
295# telemetry reporting in Firefox.
296unset MOZ_TELEMETRY_REPORTING
297
298mk_add_options MOZ_OBJDIR=@TOPSRCDIR@/firefox-build-dir</literal>
299EOF</userinput></screen>
300
301 <para>
302 Compile <application>Firefox</application> by issuing the following
303 commands:
304 </para>
305<!-- Not needed with clang. Upstream bug at
306 https://bugzilla.mozilla.org/show_bug.cgi?id=1729459
307
308 <para>
309 If building on a 32 bit machine, the following sed works around
310 an issue with an incompatible <quote>double</quote> type in one
311 header file:
312 </para>
313
314<screen><userinput>case "$(uname -m)" in
315 i?86) sed -e '/typedef[ ]*double/s/double/long double/' \
316 -i modules/fdlibm/src/math_private.h ;;
317esac</userinput></screen>
318-->
319 <para>
320 If the geolocation APIs are needed:
321 </para>
322
323 <note>
324 <para>
325 <!-- Taken from Arch Linux - an immensely helpful link - Thanks -->
326 The Google and Mozilla API Keys below are specific to LFS. If using
327 these instructions for another distro, or if you intend to distribute
328 binary copies of the software using these instructions, please obtain
329 your own keys following the instructions located at
330 <ulink url="https://www.chromium.org/developers/how-tos/api-keys"/> and
331 <ulink url="https://location.services.mozilla.com/api"/> respectively.
332 <!-- BLFS Devs, register an account at Google with your
333 @linuxfromscratch.org email address, and I'll make you an administrator
334 for the 'Google APIs for LFS' project (where the API and OAuth keys
335 were created for use in the book).-->
336 </para>
337 </note>
338
339<screen><userinput>echo "AIzaSyDxKL42zsPjbke5O8_rPVpVrLrJ8aeE9rQ" > google-key
340echo "613364a7-9418-4c86-bcee-57e32fd70c23" > mozilla-key</userinput></screen>
341
342 <note>
343
344 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
345 href="../../xincludes/mozshm.xml"/>
346
347 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
348 href="../../xincludes/mozmach.xml"/>
349
350 </note>
351
352<!--<para>
353 Fix building Firefox with Clang 16 or C++ headers from GCC 13.
354 And, work around a build failure with Rustc-1.70.0:
355 </para>
356
357<screen><userinput remap="pre">patch -Np1 -i ../firefox-&firefox-version;-consolidated-1.patch</userinput></screen>
358
359 <para>
360 Apply the following patch so that firefox is able to play H.264 videos:
361 </para>
362
363<screen><userinput remap="pre">patch -Np1 -i ../firefox-&firefox-version;-ffmpeg_6-1.patch</userinput></screen>-->
364
365 <para>
366 Now invoke the Python <command>mach</command> script to compile the package.
367 </para>
368
369<screen><userinput>export MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE=none &amp;&amp;
370export MOZBUILD_STATE_PATH=${PWD}/mozbuild &amp;&amp;
371./mach configure &amp;&amp;
372./mach build</userinput></screen>
373
374 <para>
375 The <filename>mozconfig</filename> above disables the tests because
376 they use a lot more time and disk space for no obvious benefit. If
377 you have nevertheless enabled them, you can run the tests by executing
378 <command>./mach gtest</command>. This will require a network connection,
379 and to be run from within an Xorg session - there is a popup dialog
380 when it fails to connect to ALSA (that does not create a failed test).
381 One or two tests will fail. To see the details of the failure(s) you
382 will need to log the output from that command so that you can review it.
383 </para>
384
385 <para>
386 Now, as the <systemitem class="username">root</systemitem> user:
387 </para>
388
389<screen role="root"><userinput>MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE=none ./mach install</userinput></screen>
390
391 <para>
392 Empty the environment variables which were set above:
393 </para>
394
395<screen><userinput>unset MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE MOZBUILD_STATE_PATH</userinput></screen>
396
397 </sect2>
398
399 <sect2 role="commands">
400 <title>Command Explanations</title>
401
402<!--<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
403 href="../../xincludes/SIOCGSTAMP.xml"/>-->
404
405 <para>
406 <command>export MOZBUILD_STATE_PATH=${PWD}/mozbuild</command>: The build
407 is now supposed to tell you that it intends to create <filename
408 class="directory">~/.mozbuild</filename>, and offer you an option to
409 press &lt;ENTER&gt; to accept this, or Ctrl-C to cancel and restart the
410 build after specifying the directory. In practice, the message may not
411 appear until after &lt;ENTER&gt; is keyed, i.e. the build stalls.
412 </para>
413
414 <para>
415 That directory is used for a (probably random) telemetry identifier.
416 Creating this in the build directory, and deleting that after the
417 installation, prevents it being used. If you wish to participate in
418 telemetry, export MOZBUILD_STATE_PATH to point to its default directory
419 and remove the entry from the <filename>mozconfig</filename>.
420 </para>
421
422 <para>
423 <command>MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE=none</command>: Use the
424 system python to create a virtual environment for <command>mach</command>
425 without downloading any python wheels nor using the system python modules.
426 This prevents version mismatches between system modules and bundled ones.
427 </para>
428
429 <para>
430 <command>./mach configure</command>: This validates the supplied
431 dependencies and the <filename>mozconfig</filename>.
432 </para>
433
434 <para>
435 <option>./mach build --verbose</option>: Use this alternative if you
436 need details of which files are being compiled, together with any C or
437 C++ flags being used. But do not add '--verbose' to the install command
438 since it is not accepted there.
439 </para>
440
441 <para>
442 <option>./mach build -jN</option>: The build should, by default, use
443 all the online CPU cores. If using all the cores causes the build to swap
444 because you have insufficient memory, using fewer cores can be faster.
445 </para>
446
447 <para>
448 <option><envar>CC=gcc CXX=g++</envar></option>: BLFS used to
449 prefer to use gcc and g++ instead of upstream's defaults of the
450 <application>clang</application> programs. With the release of
451 gcc-12 the build takes longer with gcc and g++, primarily because
452 of extra warnings, and is bigger. Set these environment variables
453 <emphasis>before you run the configure script</emphasis>
454 if you wish to continue to use gcc, g++. Building
455 with GCC on i?86 is currently broken.
456 </para>
457
458 </sect2>
459
460 <sect2 role="configuration">
461 <title>Configuring Firefox</title>
462
463 <para>
464 If you use a desktop environment like <application>Gnome</application> or
465 <application>KDE</application> you may want to create a
466 <filename>firefox.desktop</filename> file so that
467 <application>Firefox</application> appears in the panel's menus.
468 As the &root; user:
469 </para>
470
471<screen role="root"><userinput>mkdir -pv /usr/share/applications &amp;&amp;
472mkdir -pv /usr/share/pixmaps &amp;&amp;
473
474MIMETYPE="text/xml;text/mml;text/html;" &amp;&amp;
475MIMETYPE+="application/xhtml+xml;application/vnd.mozilla.xul+xml;" &amp;&amp;
476MIMETYPE+="x-scheme-handler/http;x-scheme-handler/https" &amp;&amp;
477
478cat &gt; /usr/share/applications/firefox.desktop &lt;&lt; EOF &amp;&amp;
479<literal>[Desktop Entry]
480Encoding=UTF-8
481Name=Firefox Web Browser
482Comment=Browse the World Wide Web
483GenericName=Web Browser
484Exec=firefox %u
485Terminal=false
486Type=Application
487Icon=firefox
488Categories=GNOME;GTK;Network;WebBrowser;
489MimeType=$MIMETYPE
490StartupNotify=true</literal>
491EOF
492
493unset MIMETYPE &amp;&amp;
494
495ln -sfv /usr/lib/firefox/browser/chrome/icons/default/default128.png \
496 /usr/share/pixmaps/firefox.png</userinput></screen>
497
498 <sect3><title>Configuration Information</title>
499
500 <para>
501 The application settings for firefox are accessible by keying
502 <command>about:config</command> in the address bar.
503 </para>
504
505 <para>
506 Occasionally, getting working sound in
507 <application>firefox</application> can be a problem. Although upstream
508 prefers pulseaudio,
509 on balance using <application>Alsa</application> may be easier.
510 </para>
511
512 <para>
513 If you enabled <application>Alsa</application> for sound, you may need
514 to alter one variable to get working sound. If you run
515 <command>firefox</command> from a terminal and try to play something
516 with sound you might encounter error messages like:
517 </para>
518
519 <para>
520 <literal>Sandbox: seccomp sandbox violation: pid 3941, tid 4030,
521 syscall 16, args 48 2147767296 139909894784796 0 0 0.</literal>
522 </para>
523
524 <para>
525 That was on x86_64, on i686 the syscall number is 54. To allow this
526 syscall, in <command>about:config</command> change
527 <command>security.sandbox.content.syscall_whitelist</command> to 16
528 (or 54 if using i686).
529 </para>
530
531 <para>
532 If you use <command>pulseaudio</command> in a Desktop Environment, it
533 might already be started by that DE. But if it is not, although
534 firefox-57 managed to start it, firefox-58 did not. If you run
535 <command>firefox</command> from a terminal and this problem is present,
536 trying to play sound will
537 encounter error messages warning <literal>Can't get cubeb
538 context!</literal>
539 </para>
540
541 <para>
542 The fix for this is to close firefox, start pulseaudio to check it
543 does start (if not, read the information on Configuring in <xref
544 linkend="pulseaudio"/>) and restart firefox to check it is working.
545 If it now works, add the following to your <filename>~/.xinitrc</filename>:
546<phrase revision="sysv">
547<literal>pulseaudio --verbose --log-target=syslog&amp;</literal></phrase>
548<phrase revision="systemd">
549<literal>pulseaudio --verbose --log-target=journald&amp;</literal></phrase>
550 (unfortunately, on some systems this does not work).
551 </para>
552
553 <para>
554 You may wish to use multiple profiles within firefox. To do that, invoke
555 firefox as <command>firefox --ProfileManager</command>. You can also
556 check which profile is currently in use from
557 <command>about:profiles</command>.
558 </para>
559
560 <para>
561 Although WebRender (using the GPU for compositing) is not used by
562 default, it now appears to work well on supported hardware (ATI, Nvidia
563 and Intel GPUs with Mesa-18 or later). For an explanation, please see
564 <ulink
565 url="https://hacks.mozilla.org/2017/10/the-whole-web-at-maximum-fps-how-webrender-gets-rid-of-jank/">hacks.mozilla.org</ulink>.
566 The only downside seems to be that on a machine with limited RAM it might
567 use more RAM.
568 </para>
569
570 <para>
571 To check if WebRender is being used, look in about:support. In the Graphics
572 section, Compositing will either show 'Basic' (i.e. not in use) or
573 'WebRender'. To enable it, go to about:config and change gfx.webrender.all
574 to True. You will need to restart firefox.
575 </para>
576
577 <para>
578 It may be useful to mention the processes from firefox which can appear in
579 <command>top</command> - as well as firefox itself, there may be multiple
580 Web Content processes, and now an RDD Process (Remote Data Decoder) which
581 appears when playing web videos encoded with av1 (libdav1d). If WebRender
582 has been enabled, a GPU Process will also appear when firefox has to
583 repaint (e.g. scrolling, opening a new tab, or playing a video).
584 </para>
585
586 </sect3>
587 </sect2>
588
589 <sect2 role="content">
590 <title>Contents</title>
591
592 <segmentedlist>
593 <segtitle>Installed Programs</segtitle>
594 <segtitle>Installed Libraries</segtitle>
595 <segtitle>Installed Directory</segtitle>
596
597 <seglistitem>
598 <seg>
599 firefox
600 </seg>
601 <seg>
602 Numerous libraries, browser components, plugins, extensions, and
603 helper modules installed in /usr/lib/firefox
604 </seg>
605 <seg>
606 /usr/lib/firefox
607 </seg>
608 </seglistitem>
609 </segmentedlist>
610
611 <variablelist>
612 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
613 <?dbfo list-presentation="list"?>
614 <?dbhtml list-presentation="table"?>
615
616 <varlistentry id="firefox-prog">
617 <term><command>firefox</command></term>
618 <listitem>
619 <para>
620 is a <application>GTK+-3</application> internet browser that uses
621 the Mozilla Gecko rendering engine
622 </para>
623 <indexterm zone="firefox firefox-prog">
624 <primary sortas="b-firefox">firefox</primary>
625 </indexterm>
626 </listitem>
627 </varlistentry>
628
629 </variablelist>
630
631 </sect2>
632
633</sect1>
Note: See TracBrowser for help on using the repository browser.