Project

General

Profile

Preparing a Linux machine for Bilder » History » Version 49

Nathan Neri, 02/25/2019 02:10 PM
Adding instrutions for git lfs.

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