Project

General

Profile

Preparing a Linux machine for Bilder » History » Version 34

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