Project

General

Profile

Preparing a Linux machine for Bilder » History » Version 73

Seth Veitzer, 07/30/2021 02:34 PM

1 1 Redmine Admin
# Preparing a Linux machine for Bilder
2
3 15 John Cary
__If all you need is python and sphinx__ (e.g., for builds of documentation), then you need only
4 1 Redmine Admin
5 15 John Cary
* CMake (probably present)
6
* Python (probably present)
7 16 Ted Sume
* Python-dev or Python-devel (on Fedora)
8 15 John Cary
* Latex as installed below
9 53 John Cary
* Perl-dev or Perl-devel with perl-ExtUtils-Embed
10 1 Redmine Admin
11 15 John Cary
and then you can add the arguments,  -W python,cmake, and your installed Python and CMake will be used if your path is correct.
12
13
## Java
14
15
At least one package (Babel) needs Oracle's java, so we recommend installing it.
16
17 1 Redmine Admin
## GCC
18 15 John Cary
19 32 Jonathan Smith
It is often useful to get a newer gcc that has mmintrinsics. This may break compatibility with some versions of [[ CUDAgccCompatibility | CUDA ]].
20 1 Redmine Admin
21 57 John Cary
Below are the instructions for building gcc-8.3.0. [[ BilderKnownIssuesGcc730 | (As of this writing, 8.3 is the latest compiler to work with CUDA-10.2, and gcc-5.3.1 will not build QT-5.10.0) ]]
22 1 Redmine Admin
23
### Make sure 32bit glibc-devel is installed
24 42 John Cary
25
Do the applicable of
26 1 Redmine Admin
27
~~~~~~
28
yum -y install glibc-devel.i686
29 22 John Cary
dnf -y install glibc-devel.i686
30 1 Redmine Admin
zypper install glibc-devel-32bit  (SLES 11 SP3)
31
~~~~~~
32
33 28 John Cary
### Get and unpack the source package
34 1 Redmine Admin
35
~~~~~~
36 56 John Cary
export GCCVER=8.3.0
37 1 Redmine Admin
wget ftp://ftp.gnu.org/gnu/gcc/gcc-${GCCVER}/gcc-${GCCVER}.tar.xz
38 33 Jonathan Smith
tar xf gcc-${GCCVER}.tar.xz && cd gcc-${GCCVER}
39 1 Redmine Admin
~~~~~~
40
41 28 John Cary
### Patch as needed
42
43
If your system has glibc 2.26 or later, you will need to fix the source by making the changes specified in  https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=72edc2c02f8b4768ad660f46a1c7e2400c0a8e06 and also
44
45
~~~~~~
46
for i in libgcc/config/*/linux-unwind.h; do
47
  if grep -q "struct ucontext" $i; then
48
    sed -i.bak 's/struct ucontext/ucontext_t/' $i
49
  fi
50
done
51
~~~~~~
52
53 1 Redmine Admin
### Build
54
55 72 John Cary
Define GCC_INSTS_DIR to be your tarball installation directory, e.g.,
56 1 Redmine Admin
57
~~~~~~
58 72 John Cary
export GCC_INSTS_DIR=/contrib
59 1 Redmine Admin
~~~~~~
60
61 72 John Cary
Usually GCC_INSTS_DIR=/contrib, but if one does not have root access, one has to put this in a user area. If one does have root access, one should execute the following commands:
62 1 Redmine Admin
63
~~~~~~
64
mkdir /internal /contrib /volatile
65
chmod 775 /internal /contrib /volatile
66
~~~~~~
67
68
Unpack gcc, go into the gcc source directory, and build according to the instructions below.
69
70
**gcc:**
71
72 68 John Cary
You may need to set some addition options, e.g., ```ADDLOPTS=--with-cpu=power9``` on linuxppc64le.
73
74 22 John Cary
~~~~~~
75 1 Redmine Admin
./contrib/download_prerequisites
76
mkdir build && cd build
77 72 John Cary
../configure --prefix=$GCC_INSTS_DIR/gcc-${GCCVER} --enable-languages=c,c++,fortran --with-pic $ADDLOPTS
78
env LD_RUN_PATH=$GCC_INSTS_DIR/gcc-${GCCVER}/lib64 make -j 4
79 1 Redmine Admin
make install
80
# Alias as desired.
81 72 John Cary
mkdir -p $GCC_INSTS_DIR/bin && cd $GCC_INSTS_DIR/bin
82
ln -s $GCC_INSTS_DIR/gcc-${GCCVER}/bin/{c,g}* .
83 1 Redmine Admin
~~~~~~
84
85
### Fix permissions
86
87
~~~~~~
88 72 John Cary
chmod -R g+rwX $GCC_INSTS_DIR/gcc-${GCCVER}
89
chmod -R o+rX $GCC_INSTS_DIR/gcc-${GCCVER}
90
find $GCC_INSTS_DIR/gcc-${GCCVER} -type d -exec chmod g+rs '{}' \;
91 1 Redmine Admin
~~~~~~
92
93 73 Seth Veitzer
94
## Python
95
96
For Python 3
97
98
On Linux, libffi must be installed at the system level in order to properly get ctypes.
99
100
~~~~~~
101
sudo yum -y install libffi-devel
102
~~~~~~
103
104
Qt requires Python 2 to build webengine for Chromium, expected through release 5.16 at least. The Qt configure system (perl) looks for the executable "python2" in PATH, and if not found looks for executable "python". Thus Python 2 needs to be installed on the build system and in the PATH.
105 1 Redmine Admin
## Java
106
107
Install Oracle's Java.
108
109
Once it is installed, you will need to modify your path to include /usr/java/default/bin before /usr/bin or use the alternatives package:
110
111
~~~~~~
112
for i in java jar javac; do
113
  alternatives --install /usr/bin/$i j$i /usr/java/jdk1.6.0_16/bin/$i 3
114
done
115
alternatives --config java # Pick 3
116
~~~~~~
117
118
On SLES , Install using the tar package from Oracle, then change into the installation directory
119
120
~~~~~~
121
for i in java jar javac; do
122
  /usr/sbin/update-alternatives --install /usr/bin/$i $i <installation directory>/bin/$i 3
123
done
124
~~~~~~
125
126
where <installation directory\> is the absolute path to where Java was just installed  
127
128
## Version control systems
129
130
Make sure git, mercurial, and subversion are all installed.
131
132 49 Nathan Neri
For building VisIt, install git large file storage: https://git-lfs.github.com/
133 54 Nathan Neri
Download the tarball from that site, untar, and run
134
135
~~~~~~
136
git lfs install --force --skip-smudge
137
~~~~~~
138 49 Nathan Neri
139 1 Redmine Admin
## LaTeX
140
141 46 John Cary
LaTeX is needed for building documentation using Sphinx.
142 1 Redmine Admin
143 46 John Cary
Bilder prefers the texlive-latex package. For gui usage, see texworks: http://www.tug.org/texworks
144
145 1 Redmine Admin
If you cannot install in the system area, you can download
146
147
~~~~~~
148
wget http://mirror.ctan.org/systems/texlive/tlnet/install-tl-unx.tar.gz
149
tar xzf install-tl-unx.tar.gz
150
cd install-tl-20150411 (date might be different)
151
./install-tl -no-gui
152
~~~~~~
153
154
This is now interactive, so set
155 11 Matt Copper
 
156 10 Matt Copper
* Set scheme to basic
157
** To do this type 'S' and hit enter.
158
** Then enter 'd' to set the scheme to basic.
159
** Type 'R' and hit enter to return to the main configuration page.
160 1 Redmine Admin
161 10 Matt Copper
* Set TEXDIR = $CONTRIB_DIR/texlive
162
** Start by typing 'D' and hit enter.
163
** Then enter '1' to change TEXDIR.
164
** Type $CONTRIB_DIR/texlive and hit return.
165
** To return to configuration type 'R' and return.
166 1 Redmine Admin
167 10 Matt Copper
* Set page size to Letter size
168
** Type 'O' and hit enter.
169
** Enter 'P'
170
** Return to main menu by typing 'R' and enter. 
171
172
* Install
173
** Type 'I' and hit enter to install.
174
175
* Put your texlive in your PATH.
176
** Edit you bashrc (vim ~/.bashrc)
177
** Add "export PATH=$PATH:<$CONTRIB_DIR>/texlive/bin/x86_64-linux/" (enter the full CONTRIB_DIR value)
178
** Exit and save. Then source ~/.bashrc.
179
180
To ensure you are using the correct texlive installation type "which pdflatex" and make sure it 
181
the one in $CONTRIB_DIR/texlive/bin/x86_64-linux/. If it is not the correct pdflatex, you may
182 1 Redmine Admin
have to remove the system version (sudo yum remove texlive). 
183 38 John Cary
184 46 John Cary
and then install the packages noted at
185 45 John Cary
186 46 John Cary
[[LaTeX packages needed by Bilder]]
187 38 John Cary
188 1 Redmine Admin
189 25 John Cary
## Additional packages
190 1 Redmine Admin
191 25 John Cary
Other parts of the toolchain introduce other package requirements.  Below are the initial lists.
192
193 61 Nathan Neri
### Fedora / Redhat / CentOS
194 24 John Cary
195 44 John Cary
The following packages (cut and paste after dnf install or yum install) are needed for Fedora, Redhat, CentOS
196 1 Redmine Admin
197 40 John Cary
~~~~~~
198 69 David Alexander
bc bison git-lfs glib2-devel imake krb5-devel lapack-devel blas-devel blas-static libcurl-devel libxkbcommon-devel libxkbcommon-x11-devel libxml2-devel openssl-devel patch redhat-lsb zlib-devel libXt-devel
199 40 John Cary
~~~~~~
200 9 David Alexander
201
For more recent versions of Fedora, you will need.
202 40 John Cary
203
~~~~~~
204 43 John Cary
egl-wayland mesa-libEGL-devel redhat-rpm-config
205 18 John Cary
~~~~~~
206 1 Redmine Admin
207 47 David Alexander
For centos7 you will also need.
208
209
~~~~~~
210 62 John Cary
imake xorg-x11-utils
211 1 Redmine Admin
~~~~~~
212 61 Nathan Neri
213
and to build Qt 5 for VisIt you will need.
214 1 Redmine Admin
215 61 Nathan Neri
~~~~~~
216 71 Ted Sume
dbus-devel nss-devel gperf libxcb-devel xcb-util-renderutil-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-wm-devel xcb-util-devel xcb-util-cursor-devel
217 61 Nathan Neri
~~~~~~
218
219 47 David Alexander
220 18 John Cary
### Ubuntu
221 24 John Cary
222 1 Redmine Admin
The following packages are needed for Ubuntu
223
224
~~~~~~
225 48 Benjamin Cowan
ace-netsvcs
226
bc
227 1 Redmine Admin
bison
228 48 Benjamin Cowan
flex
229
gfortran
230
graphviz
231
libblas-dev
232
libfreetype6-dev
233
libgl1-mesa-dev
234
libglu1-mesa-dev
235
libgraphviz-dev
236
liblapack-dev
237
libntlm0
238
libpng-dev
239
libxext-dev
240
libxrender-dev
241
libxtst-dev
242
libzzip-dev
243
mailutils
244
python2.7
245
python2.7-dev
246
zlib1g-dev
247 1 Redmine Admin
~~~~~~
248 14 Jonathan Smith
* You will probably want a lightweight command line editor other than gedit, so "sudo apt-get install vim"  or "sudo apt-get install emacs" 
249
* zlib-dev doesn't exist on ubuntu 16.04 - use zlib1g-dev instead.
250
251 1 Redmine Admin
mailutils is necessary for configuring the system for jenkins. 
252 14 Jonathan Smith
You'll be offered to choose:
253
* Internet site
254
* Internet with smarthost
255
* Satellite system
256 1 Redmine Admin
* Local only
257 14 Jonathan Smith
258
Internet with smarthost is recommended.
259 1 Redmine Admin
260 14 Jonathan Smith
261 1 Redmine Admin
The use of the following commands are helpful. To search for an available package dealing with a keyword, use:
262
263
~~~~~~
264
$ sudo apt-cache search keyword
265
~~~~~~
266
267
To install a particular package, use:
268
269
~~~~~~
270
$ sudo apt-get install libblah-dev
271
~~~~~~
272
273
Note: that development packages names typically end with "dev" not "devel" as in other flavors of linux.
274
275
### Suse Linux Enterprise Server (SLES)
276
277 43 John Cary
The following packages (in cut/paste for zypper form) are needed on SLES
278 1 Redmine Admin
279
~~~~~~
280 43 John Cary
bc bison blas-devel blas-devel-static libblas3 flex freetype2-devel
281
gcc gcc-32bit gcc-fortran git glibc-devel glibc-devel-32bit
282
graphviz graphviz-devel libbz2-devel lapack-devel lapack-devel-static liblapack3 libpng-devel libssh-devel libxml2-devel
283
mailx mercurial Mesa-devel python-devel
284
xorg-x11-devel xorg-x11-libXext-devel xorg-x11-libXrender-devel xorg-x11-libs zlib-devel
285 1 Redmine Admin
~~~~~~
286 43 John Cary
287
The following are needed to build subversion
288
289
~~~~~~
290
libapr-util1 libapr1 libneon27
291
~~~~~~
292
293 1 Redmine Admin
294
To get blas-devel, blas-devel-static and lapack-devel, lapack-devel-static on SLES 11 SP3 , add the Science repository
295
296
~~~~~~
297 40 John Cary
zypper addrepo http://download.opensuse.org/repositories/science/SLE_11_SP3/science.repo
298
zypper refresh
299
zypper install blas-devel blas-devel-static lapack-devel lapack-devel-static
300 1 Redmine Admin
~~~~~~
301 24 John Cary
302 1 Redmine Admin
## Qt Prerequisites
303
304 25 John Cary
Qt-5 must be built with QtWebEngine, which particularly introduces requirements for other packages as noted at
305 24 John Cary
306 25 John Cary
* https://doc.qt.io/qt-5.10/qtwebengine-platform-notes.html
307
* https://wiki.qt.io/QtWebEngine/How_to_Try
308
* https://www.ics.com/blog/building-qtwebengine
309
* http://www.linuxfromscratch.org/blfs/view/svn/x/qtwebengine.html
310
311
Each of the above websites appears to have made assumptions about what is already installed, so as one encounters more workstations, one is likely to find yet another package missing.  This is our list so far.
312 1 Redmine Admin
313 24 John Cary
### Fedora
314
315
~~~~~~
316 41 John Cary
sudo yum install alsa-lib-devel bison cups-devel dbus-devel flex fontconfig-devel gperf libicu-devel
317 64 John Cary
sudo yum install libcap-devel libgcrypt-devel libgcrypt libgudev1-devel libsndfile-devel libstdc++-static libwebp-devel
318 27 John Cary
sudo yum install libXcomposite-devel libXcursor-devel libXi-devel libXrandr-devel libxslt-devel libXtst-devel
319 1 Redmine Admin
sudo yum install mesa-libEGL-devel nss-devel opus-devel pciutils-devel pulseaudio-libs-devel re2c ruby systemd-devel
320
~~~~~~
321
322
## Vendor-specific version of graphics driver
323
324
If you are preparing a Linux machine for the VisIt Visualization package, the vendor-specific graphics driver for your graphics card should be installed.
325
326
By default, a generic graphics driver is installed.  On Fedora, the generic driver is "nouveau".
327
328
To determine if the nouveau driver is installed on your system, enter the command
329
330
~~~~~~
331 40 John Cary
lsmod | grep nouv
332 1 Redmine Admin
~~~~~~
333
334
You will need to download and install the appropriate driver from your graphics card vendor.  This generally uninstalls the nouveau drivers.
335 3 Matt Copper
336 4 Matt Copper
## NVIDIA CUDA Toolkit
337 3 Matt Copper
338
If you have a compatible GPU and wish to compile with nvcc code, you must first install the CUDA Toolkit. The linux installation page is 
339
340
~~~~~~
341 40 John Cary
https://developer.nvidia.com/cuda-toolkit-70
342 3 Matt Copper
~~~~~~
343
344
Download the applicable file. Your Linux distribution may or may not be natively supported for version 7.0. You may alternatively use version 7.5 if supported or an older version if necessary. As an example, we will include the steps known to work for Fedora 22. On Fedora 22, download the Fedora 21 Local RPM package. 
345
346
~~~~~~
347 40 John Cary
cd <location of download>
348
sudo rpm -i cuda-repo-fedora21-7-0-local-7.0-28.x86_64.rpm   #<or whatever file you downloaded> 
349
sudo dnf install cuda
350 3 Matt Copper
~~~~~~
351
352 5 Matt Copper
Different Linux distributions will have different package handlers (here we use dnf, ubuntu has apt-get, fedora < 22 uses yum). You should now have the directory /usr/local/cuda-7.0. Add /usr/local/cuda-7.0/bin to your path. To ensure you have gotten the necessary components, type:
353 3 Matt Copper
354
~~~~~~
355 40 John Cary
which nvcc
356 3 Matt Copper
~~~~~~
357 23 John Cary
The output should be /usr/local/cuda-7.0/bin/nvcc. This will allow bilder to build GPU c++ code.
358 31 Jonathan Smith
359
IMPORTANT NOTE: CUDA versions only support particular GCC versions, and the latest GCC may not support your CUDA.[[ CUDAgccCompatibility | See this wiki page for details ]]