Project

General

Profile

Preparing a Linux machine for Bilder » History » Version 53

John Cary, 02/27/2019 07:03 AM

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 42 John Cary
Below are the instructions for building gcc-6.4.0. [[ BilderKnownIssuesGcc730 | (As of this writing 6.4 is the latest compiler to work with CUDA-9.1, 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 25 John Cary
export GCCVER=6.4.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
Define CONTRIB_DIR to be your tarball installation directory, e.g.,
56
57
~~~~~~
58
export CONTRIB_DIR=/contrib
59
~~~~~~
60
61
Usually CONTRIB_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
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 22 John Cary
~~~~~~
73 1 Redmine Admin
./contrib/download_prerequisites
74
mkdir build && cd build
75 25 John Cary
../configure --prefix=$CONTRIB_DIR/gcc-${GCCVER} --enable-languages=c,c++,fortran --with-pic
76 1 Redmine Admin
env LD_RUN_PATH=$CONTRIB_DIR/gcc-${GCCVER}/lib64 make -j 4
77
make install
78
# Alias as desired.
79
mkdir -p $CONTRIB_DIR/bin && cd $CONTRIB_DIR/bin
80
ln -s $CONTRIB_DIR/gcc-${GCCVER}/bin/{c,g}* .
81
~~~~~~
82
83
### Fix permissions
84
85
~~~~~~
86
chmod -R g+rwX $CONTRIB_DIR/gcc-${GCCVER}
87
chmod -R o+rX $CONTRIB_DIR/gcc-${GCCVER}
88
find $CONTRIB_DIR/gcc-${GCCVER} -type d -exec chmod g+rs '{}' \;
89
~~~~~~
90
91
## Java
92
93
Install Oracle's Java.
94
95
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:
96
97
~~~~~~
98
for i in java jar javac; do
99
  alternatives --install /usr/bin/$i j$i /usr/java/jdk1.6.0_16/bin/$i 3
100
done
101
alternatives --config java # Pick 3
102
~~~~~~
103
104
On SLES , Install using the tar package from Oracle, then change into the installation directory
105
106
~~~~~~
107
for i in java jar javac; do
108
  /usr/sbin/update-alternatives --install /usr/bin/$i $i <installation directory>/bin/$i 3
109
done
110
~~~~~~
111
112
where <installation directory\> is the absolute path to where Java was just installed  
113
114
## Version control systems
115
116
Make sure git, mercurial, and subversion are all installed.
117
118 49 Nathan Neri
For building VisIt, install git large file storage: https://git-lfs.github.com/
119 50 Nathan Neri
(download the tarball, unpack, and run the install script)
120 49 Nathan Neri
121 1 Redmine Admin
## LaTeX
122
123 46 John Cary
LaTeX is needed for building documentation using Sphinx.
124 1 Redmine Admin
125 46 John Cary
Bilder prefers the texlive-latex package. For gui usage, see texworks: http://www.tug.org/texworks
126
127 1 Redmine Admin
If you cannot install in the system area, you can download
128
129
~~~~~~
130
wget http://mirror.ctan.org/systems/texlive/tlnet/install-tl-unx.tar.gz
131
tar xzf install-tl-unx.tar.gz
132
cd install-tl-20150411 (date might be different)
133
./install-tl -no-gui
134
~~~~~~
135
136
This is now interactive, so set
137 11 Matt Copper
 
138 10 Matt Copper
* Set scheme to basic
139
** To do this type 'S' and hit enter.
140
** Then enter 'd' to set the scheme to basic.
141
** Type 'R' and hit enter to return to the main configuration page.
142 1 Redmine Admin
143 10 Matt Copper
* Set TEXDIR = $CONTRIB_DIR/texlive
144
** Start by typing 'D' and hit enter.
145
** Then enter '1' to change TEXDIR.
146
** Type $CONTRIB_DIR/texlive and hit return.
147
** To return to configuration type 'R' and return.
148 1 Redmine Admin
149 10 Matt Copper
* Set page size to Letter size
150
** Type 'O' and hit enter.
151
** Enter 'P'
152
** Return to main menu by typing 'R' and enter. 
153
154
* Install
155
** Type 'I' and hit enter to install.
156
157
* Put your texlive in your PATH.
158
** Edit you bashrc (vim ~/.bashrc)
159
** Add "export PATH=$PATH:<$CONTRIB_DIR>/texlive/bin/x86_64-linux/" (enter the full CONTRIB_DIR value)
160
** Exit and save. Then source ~/.bashrc.
161
162
To ensure you are using the correct texlive installation type "which pdflatex" and make sure it 
163
the one in $CONTRIB_DIR/texlive/bin/x86_64-linux/. If it is not the correct pdflatex, you may
164 1 Redmine Admin
have to remove the system version (sudo yum remove texlive). 
165 38 John Cary
166 46 John Cary
and then install the packages noted at
167 45 John Cary
168 46 John Cary
[[LaTeX packages needed by Bilder]]
169 38 John Cary
170 1 Redmine Admin
171 25 John Cary
## Additional packages
172 1 Redmine Admin
173 25 John Cary
Other parts of the toolchain introduce other package requirements.  Below are the initial lists.
174
175 24 John Cary
### Fedora
176
177 44 John Cary
The following packages (cut and paste after dnf install or yum install) are needed for Fedora, Redhat, CentOS
178 1 Redmine Admin
179 40 John Cary
~~~~~~
180 44 John Cary
bc bison glib2-devel imake lapack-devel libblas-devel libcurl-devel libxml2-devel openssl-devel patch redhat-lsb zlib-devel
181 40 John Cary
~~~~~~
182 9 David Alexander
183
For more recent versions of Fedora, you will need.
184 40 John Cary
185
~~~~~~
186 43 John Cary
egl-wayland mesa-libEGL-devel redhat-rpm-config
187 18 John Cary
~~~~~~
188 1 Redmine Admin
189 47 David Alexander
For centos7 you will also need.
190
191
~~~~~~
192
imake
193
~~~~~~
194
195 18 John Cary
### Ubuntu
196 24 John Cary
197 1 Redmine Admin
The following packages are needed for Ubuntu
198
199
~~~~~~
200 48 Benjamin Cowan
ace-netsvcs
201
bc
202 1 Redmine Admin
bison
203 48 Benjamin Cowan
flex
204
gfortran
205
graphviz
206
libblas-dev
207
libfreetype6-dev
208
libgl1-mesa-dev
209
libglu1-mesa-dev
210
libgraphviz-dev
211
liblapack-dev
212
libntlm0
213
libpng-dev
214
libxext-dev
215
libxrender-dev
216
libxtst-dev
217
libzzip-dev
218
mailutils
219
python2.7
220
python2.7-dev
221
zlib1g-dev
222 1 Redmine Admin
~~~~~~
223 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" 
224
* zlib-dev doesn't exist on ubuntu 16.04 - use zlib1g-dev instead.
225
226 1 Redmine Admin
mailutils is necessary for configuring the system for jenkins. 
227 14 Jonathan Smith
You'll be offered to choose:
228
* Internet site
229
* Internet with smarthost
230
* Satellite system
231 1 Redmine Admin
* Local only
232 14 Jonathan Smith
233
Internet with smarthost is recommended.
234 1 Redmine Admin
235 14 Jonathan Smith
236 1 Redmine Admin
The use of the following commands are helpful. To search for an available package dealing with a keyword, use:
237
238
~~~~~~
239
$ sudo apt-cache search keyword
240
~~~~~~
241
242
To install a particular package, use:
243
244
~~~~~~
245
$ sudo apt-get install libblah-dev
246
~~~~~~
247
248
Note: that development packages names typically end with "dev" not "devel" as in other flavors of linux.
249
250
### Suse Linux Enterprise Server (SLES)
251
252 43 John Cary
The following packages (in cut/paste for zypper form) are needed on SLES
253 1 Redmine Admin
254
~~~~~~
255 43 John Cary
bc bison blas-devel blas-devel-static libblas3 flex freetype2-devel
256
gcc gcc-32bit gcc-fortran git glibc-devel glibc-devel-32bit
257
graphviz graphviz-devel libbz2-devel lapack-devel lapack-devel-static liblapack3 libpng-devel libssh-devel libxml2-devel
258
mailx mercurial Mesa-devel python-devel
259
xorg-x11-devel xorg-x11-libXext-devel xorg-x11-libXrender-devel xorg-x11-libs zlib-devel
260 1 Redmine Admin
~~~~~~
261 43 John Cary
262
The following are needed to build subversion
263
264
~~~~~~
265
libapr-util1 libapr1 libneon27
266
~~~~~~
267
268 1 Redmine Admin
269
To get blas-devel, blas-devel-static and lapack-devel, lapack-devel-static on SLES 11 SP3 , add the Science repository
270
271
~~~~~~
272 40 John Cary
zypper addrepo http://download.opensuse.org/repositories/science/SLE_11_SP3/science.repo
273
zypper refresh
274
zypper install blas-devel blas-devel-static lapack-devel lapack-devel-static
275 1 Redmine Admin
~~~~~~
276 24 John Cary
277 1 Redmine Admin
## Qt Prerequisites
278
279 25 John Cary
Qt-5 must be built with QtWebEngine, which particularly introduces requirements for other packages as noted at
280 24 John Cary
281 25 John Cary
* https://doc.qt.io/qt-5.10/qtwebengine-platform-notes.html
282
* https://wiki.qt.io/QtWebEngine/How_to_Try
283
* https://www.ics.com/blog/building-qtwebengine
284
* http://www.linuxfromscratch.org/blfs/view/svn/x/qtwebengine.html
285
286
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.
287 1 Redmine Admin
288 24 John Cary
### Fedora
289
290
~~~~~~
291 41 John Cary
sudo yum install alsa-lib-devel bison cups-devel dbus-devel flex fontconfig-devel gperf libicu-devel
292 27 John Cary
sudo yum install libcap-devel libgcrypt-devel libgcrypt libgudev1-devel libsndfile-devel libwebp-devel
293
sudo yum install libXcomposite-devel libXcursor-devel libXi-devel libXrandr-devel libxslt-devel libXtst-devel
294 1 Redmine Admin
sudo yum install mesa-libEGL-devel nss-devel opus-devel pciutils-devel pulseaudio-libs-devel re2c ruby systemd-devel
295
~~~~~~
296
297
## Vendor-specific version of graphics driver
298
299
If you are preparing a Linux machine for the VisIt Visualization package, the vendor-specific graphics driver for your graphics card should be installed.
300
301
By default, a generic graphics driver is installed.  On Fedora, the generic driver is "nouveau".
302
303
To determine if the nouveau driver is installed on your system, enter the command
304
305
~~~~~~
306 40 John Cary
lsmod | grep nouv
307 1 Redmine Admin
~~~~~~
308
309
You will need to download and install the appropriate driver from your graphics card vendor.  This generally uninstalls the nouveau drivers.
310 3 Matt Copper
311 4 Matt Copper
## NVIDIA CUDA Toolkit
312 3 Matt Copper
313
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 
314
315
~~~~~~
316 40 John Cary
https://developer.nvidia.com/cuda-toolkit-70
317 3 Matt Copper
~~~~~~
318
319
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. 
320
321
~~~~~~
322 40 John Cary
cd <location of download>
323
sudo rpm -i cuda-repo-fedora21-7-0-local-7.0-28.x86_64.rpm   #<or whatever file you downloaded> 
324
sudo dnf install cuda
325 3 Matt Copper
~~~~~~
326
327 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:
328 3 Matt Copper
329
~~~~~~
330 40 John Cary
which nvcc
331 3 Matt Copper
~~~~~~
332 23 John Cary
The output should be /usr/local/cuda-7.0/bin/nvcc. This will allow bilder to build GPU c++ code.
333 31 Jonathan Smith
334
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 ]]