Difference between revisions of "Linux"

From sigrok
Jump to: navigation, search
(libserialport)
(explicitly link from Linux to Building FAQ)
(42 intermediate revisions by 11 users not shown)
Line 1: Line 1:
[[File:Sigrok-gtk-0.1.png|thumb|320px|right|sigrok-gtk 0.1.0 on Linux]]
 
 
 
This page describes how to build/install the sigrok subprojects on Linux.
 
This page describes how to build/install the sigrok subprojects on Linux.
  
Line 8: Line 6:
  
 
== Building ==
 
== Building ==
 +
 +
<div style="background-color:#ff6666">
 +
'''IMPORTANT''': The following sections on installing build requirements are distro-specific examples and may or may not be out of date, depending on which distro you use. Please check the [[Building#Build_requirements|official build requirements list]] in the wiki or the current [http://sigrok.org/gitweb/?p=libsigrok.git;a=blob;f=README libsigrok README] for the full list of requirements.
 +
</div>
  
 
=== libserialport ===
 
=== libserialport ===
  
'''Installing the [[Building#Build_requirements|requirements]]:'''
+
==== Installing the [[Building#Build_requirements|requirements]] ====
  
Example on Debian/Ubuntu (please check your respective distro's package manager tool if you use other distros):
+
'''Debian/Ubuntu/Mint'''
 +
$ '''sudo apt-get install git-core gcc make autoconf automake libtool'''
  
  $ '''sudo apt-get install git-core gcc make autoconf automake libtool'''
+
'''Arch'''
 +
  $ '''sudo pacman -S git gcc make autoconf automake libtool'''
  
'''Building:'''
+
==== Building ====
  
 
  $ '''git clone git://sigrok.org/libserialport'''
 
  $ '''git clone git://sigrok.org/libserialport'''
Line 28: Line 32:
 
=== libsigrok ===
 
=== libsigrok ===
  
'''Installing the [[Building#Build_requirements|requirements]]:'''
+
==== Installing the [[Building#Build_requirements|requirements]] ====
  
Example on Debian/Ubuntu (please check your respective distro's package manager tool if you use other distros):
+
'''Debian/Ubuntu/Mint'''
  
  $ '''sudo apt-get install git-core gcc make autoconf automake libtool pkg-config \'''
+
  $ '''sudo apt-get install git-core gcc g++ make autoconf autoconf-archive \'''
   '''libglib2.0-dev libzip-dev libusb-1.0-0-dev libftdi-dev libudev-dev libasound2-dev check'''
+
   '''automake libtool pkg-config libglib2.0-dev libglibmm-2.4-dev libzip-dev \'''
 +
  '''libusb-1.0-0-dev libftdi1-dev check doxygen python-numpy \'''
 +
  '''python-dev python-gi-dev python-setuptools swig default-jdk'''
  
Fedora (18, 19):
+
'''Fedora (18, 19, 20, 21, 22, 23)'''
  
  $ '''sudo yum install git gcc make autoconf automake libtool pkgconfig glib2-devel \'''
+
  $ '''sudo yum install git gcc make autoconf autoconf-archive automake libtool pkgconfig \'''
   '''libzip-devel libusb1-devel libftdi-devel libudev-devel alsa-lib-devel check-devel'''
+
   ''' glib2-devel libzip-devel libusb1-devel libftdi-devel check-devel doxygen'''
  
Fedora 20:
+
:: For C++ bindings, add '''sudo yum install glibmm24-devel'''.
As above, but replace '''libudev-devel''' with '''systemd-devel'''
+
:: For Python bindings, add '''sudo yum install python-devel numpy pygobject3-devel swig'''.
 +
:: For Fedora 23, you need as well: '''redhat-rpm-config''' and note that '''libusb1-devel''' is now '''libusbx-devel'''.
  
OpenSuSE (12.2):
+
'''Arch'''
  
  $ '''zypper install git gcc make autoconf automake libtool pkg-config glib2-devel \'''
+
  $ '''sudo pacman -S git gcc make autoconf autoconf-archive automake libtool \'''
   '''libzip-devel libusb-1_0-devel libftdi1-devel libudev-devel alsa-devel check \'''
+
   '''pkg-config glib2 glibmm libzip libusb libftdi check doxygen python-numpy \'''
   '''python3-devel'''
+
   '''python-setuptools swig jdk8-openjdk'''
  
'''Building:'''
+
==== Building ====
  
 
  $ '''git clone git://sigrok.org/libsigrok'''
 
  $ '''git clone git://sigrok.org/libsigrok'''
Line 57: Line 64:
 
  $ '''make'''
 
  $ '''make'''
 
  $ '''sudo make install'''
 
  $ '''sudo make install'''
 +
 +
==== Device access ====
 +
 +
Please read [[Building#Cannot_access_USB_.2F_serial_.2F_other_device|this FAQ entry]] for any extra steps you may need to take to get your specific device working.
 +
 +
<div style="background-color:#ff6666">
 +
Please see [[Building#FAQ]] if you are sure that you installed all requirements properly but still encounter some issues.
 +
</div>
  
 
=== libsigrokdecode ===
 
=== libsigrokdecode ===
  
'''Installing the [[Building#Build_requirements|requirements]]:'''
+
==== Installing the [[Building#Build_requirements|requirements]] ====
 
 
Example on Debian/Ubuntu (please check your respective distro's package manager tool if you use other distros):
 
  
 +
'''Debian/Ubuntu/Mint'''
 
  $ '''sudo apt-get install git-core gcc make autoconf automake libtool pkg-config libglib2.0-dev python3-dev'''
 
  $ '''sudo apt-get install git-core gcc make autoconf automake libtool pkg-config libglib2.0-dev python3-dev'''
  
Fedora (18, 19, 20):
+
'''Fedora (18, 19, 20)'''
 +
$ '''sudo yum install git gcc make autoconf automake libtool pkgconfig glib2-devel python3-devel check-devel'''
  
  $ '''sudo yum install git gcc make autoconf automake libtool pkgconfig glib2-devel python3-devel check-devel'''
+
'''Arch'''
 +
  $ '''sudo pacman -S git gcc make autoconf automake libtool pkgconfig glib2 python check'''
  
'''Building:'''
+
==== Building ====
  
 
  $ '''git clone git://sigrok.org/libsigrokdecode'''
 
  $ '''git clone git://sigrok.org/libsigrokdecode'''
Line 81: Line 97:
 
=== sigrok-cli ===
 
=== sigrok-cli ===
  
'''Installing the [[Building#Build_requirements|requirements]]:'''
+
==== Installing the [[Building#Build_requirements|requirements]] ====
 
 
Example on Debian/Ubuntu (please check your respective distro's package manager tool if you use other distros):
 
  
 +
'''Debian/Ubuntu/Mint''''
 
  $ '''sudo apt-get install git-core gcc make autoconf automake libtool pkg-config libglib2.0-dev'''
 
  $ '''sudo apt-get install git-core gcc make autoconf automake libtool pkg-config libglib2.0-dev'''
  
Fedora (18, 19):
+
'''Fedora (18, 19)'''
 
 
 
  $ '''sudo yum install git gcc make autoconf automake libtool pkgconfig glib2-devel'''
 
  $ '''sudo yum install git gcc make autoconf automake libtool pkgconfig glib2-devel'''
  
OpenSuse (13.1):
+
'''OpenSuse'''
 +
$ '''sudo zypper install git gcc make autoconf automake libtool pkgconfig glib2-devel'''
  
  $ '''zypper install git gcc make autoconf automake libtool pkgconfig glib2-devel'''
+
'''Arch'''
 +
  $ '''sudo pacman -S git gcc make autoconf automake libtool pkgconfig glib2'''
  
'''Building:'''
+
==== Building ====
  
 
  $ '''git clone git://sigrok.org/sigrok-cli'''
 
  $ '''git clone git://sigrok.org/sigrok-cli'''
Line 106: Line 122:
 
=== PulseView ===
 
=== PulseView ===
  
'''Installing the [[Building#Build_requirements|requirements]]:'''
+
==== Installing the [[Building#Build_requirements|requirements]] ====
 
 
Example on Debian/Ubuntu (please check your respective distro's package manager tool if you use other distros):
 
  
 +
'''Debian/Ubuntu/Mint'''
 
  $ '''sudo apt-get install git-core g++ make cmake libtool pkg-config \'''
 
  $ '''sudo apt-get install git-core g++ make cmake libtool pkg-config \'''
   '''libglib2.0-dev libqt4-dev libboost-dev libboost-test-dev libboost-thread-dev libboost-filesystem-dev libboost-system-dev'''
+
   '''libglib2.0-dev libboost-test-dev libboost-serialization-dev \'''
 +
  '''libboost-filesystem-dev libboost-system-dev libqt5svg5-dev qtbase5-dev'''
  
Fedora (18, 19):
+
'''Fedora (18, 19, 23, 27)'''
 +
$ '''sudo yum install git gcc cmake libtool pkgconfig glib2-devel \'''
 +
  '''boost-devel qt5-devel'''
  
  $ '''sudo yum install git gcc cmake libtool pkgconfig glib2-devel \'''
+
'''Arch'''
   '''boost-devel qt-devel boost-devel'''
+
  $ '''sudo pacman -S git gcc make cmake libtool pkgconfig glib2 boost qt5 \'''
 +
   '''qt5-base qt5-svg'''
  
'''Building:'''
+
==== Building ====
  
 
  $ '''git clone git://sigrok.org/pulseview'''
 
  $ '''git clone git://sigrok.org/pulseview'''
Line 125: Line 144:
 
  $ '''make'''
 
  $ '''make'''
 
  $ '''sudo make install'''
 
  $ '''sudo make install'''
<!--
 
=== sigrok-gtk ===
 
  
'''Note:''' [[sigrok-gtk]] is not yet usable!
+
==== Troubleshooting ====
  
'''Installing the [[Building#Build_requirements|requirements]]:'''
+
When building pulseview from [https://sigrok.org/gitweb/?p=pulseview.git;a=summary the repository], make sure to install [https://sigrok.org/gitweb/?p=libsigrok.git;a=summary libsigrok] and [https://sigrok.org/gitweb/?p=libsigrokdecode.git;a=summary libsigrokdecode] by building them from source too. Building the newest pulseview with outdated libraries (forked GH repositories, debian/ubuntu packages, etc) may cause errors like these to show up when running cmake.
  
  TODO.
+
  CMake Error at CMakeLists.txt:86 (message):
 +
  libsigrok C++ bindings missing, check libsigrok's 'configure' output
 +
  (missing dependencies?)
  
'''Building:'''
+
CMake Error at /usr/share/cmake-3.7/Modules/FindPkgConfig.cmake:415 (message):
 +
  A required package was not found
 +
Call Stack (most recent call first):
 +
  /usr/share/cmake-3.7/Modules/FindPkgConfig.cmake:588 (_pkg_check_modules_internal)
 +
  CMakeLists.txt:83 (pkg_check_modules)
  
$ '''git clone git://sigrok.org/sigrok-gtk'''
+
To make sure the dependencies are installed, you can use the following (Devuan/Debian/Ubuntu):
$ '''cd sigrok-gtk'''
+
 
$ '''./autogen.sh'''
+
  $ '''sudo pkg-config --list-all | grep '''<dependency package name>
$ '''./configure'''
 
$ '''make'''
 
  $ '''sudo make install'''
 
  
=== sigrok-qt ===
+
To check the installed version, use:
  
'''Note:''' [[sigrok-qt]] is not yet usable!
+
$ '''sudo pkg-config --print-provides''' <dependency package name>
  
'''Installing the [[Building#Build_requirements|requirements]]:'''
+
'''Hint''': If something goes wrong, you can see what make is doing by running:
  
  TODO.
+
  $ '''make VERBOSE=1'''
  
'''Building:'''
+
== FAQ ==
  
$ '''git clone git://sigrok.org/sigrok-qt'''
+
Make sure to also see the [[Building#FAQ|Building FAQ]] for subjects that are not specific to Linux.
$ '''cd sigrok-qt'''
 
$ '''qmake-qt4'''
 
$ '''make'''
 
$ '''sudo make install'''
 
  
If you get warnings claiming potential symbol conflicts when running qmake, you are likely not invoking '''qmake-qt4'''. Try running '''qmake-qt4''' to force the correct version.
+
=== Cannot open shared object file: No such file or directory ===
-->
 
  
== Common problems ==
+
See [[Building#Cannot_open_shared_object_file:_No_such_file_or_directory|here]].
  
If you get this error:
+
=== TEST FAILED: .../lib/python2.7/site-packages/ does NOT support .pth files ===
  
sigrok-cli: error while loading shared libraries: libsigrok.so.0: cannot open shared object file: No such file or directory
+
See [[Building#TEST_FAILED:_....2Flib.2Fpython2.7.2Fsite-packages.2F_does_NOT_support_.pth_files|here]].
  
Then you have to rebuild the links to your shared libraries:
+
=== Cannot access USB / serial / other device ===
  
$ '''sudo ldconfig /usr/local/lib'''
+
See [[Building#Cannot_access_USB_.2F_serial_.2F_other_device|here]].

Revision as of 15:40, 8 July 2018

This page describes how to build/install the sigrok subprojects on Linux.

Distribution packages

See Downloads.

Building

IMPORTANT: The following sections on installing build requirements are distro-specific examples and may or may not be out of date, depending on which distro you use. Please check the official build requirements list in the wiki or the current libsigrok README for the full list of requirements.

libserialport

Installing the requirements

Debian/Ubuntu/Mint

$ sudo apt-get install git-core gcc make autoconf automake libtool

Arch

$ sudo pacman -S git gcc make autoconf automake libtool

Building

$ git clone git://sigrok.org/libserialport
$ cd libserialport
$ ./autogen.sh
$ ./configure
$ make
$ sudo make install

libsigrok

Installing the requirements

Debian/Ubuntu/Mint

$ sudo apt-get install git-core gcc g++ make autoconf autoconf-archive \
  automake libtool pkg-config libglib2.0-dev libglibmm-2.4-dev libzip-dev \
  libusb-1.0-0-dev libftdi1-dev check doxygen python-numpy \
  python-dev python-gi-dev python-setuptools swig default-jdk

Fedora (18, 19, 20, 21, 22, 23)

$ sudo yum install git gcc make autoconf autoconf-archive automake libtool pkgconfig \
   glib2-devel libzip-devel libusb1-devel libftdi-devel check-devel doxygen
For C++ bindings, add sudo yum install glibmm24-devel.
For Python bindings, add sudo yum install python-devel numpy pygobject3-devel swig.
For Fedora 23, you need as well: redhat-rpm-config and note that libusb1-devel is now libusbx-devel.

Arch

$ sudo pacman -S git gcc make autoconf autoconf-archive automake libtool \
  pkg-config glib2 glibmm libzip libusb libftdi check doxygen python-numpy \
  python-setuptools swig jdk8-openjdk

Building

$ git clone git://sigrok.org/libsigrok
$ cd libsigrok
$ ./autogen.sh
$ ./configure
$ make
$ sudo make install

Device access

Please read this FAQ entry for any extra steps you may need to take to get your specific device working.

Please see Building#FAQ if you are sure that you installed all requirements properly but still encounter some issues.

libsigrokdecode

Installing the requirements

Debian/Ubuntu/Mint

$ sudo apt-get install git-core gcc make autoconf automake libtool pkg-config libglib2.0-dev python3-dev

Fedora (18, 19, 20)

$ sudo yum install git gcc make autoconf automake libtool pkgconfig glib2-devel python3-devel check-devel

Arch

$ sudo pacman -S git gcc make autoconf automake libtool pkgconfig glib2 python check

Building

$ git clone git://sigrok.org/libsigrokdecode
$ cd libsigrokdecode
$ ./autogen.sh
$ ./configure
$ make
$ sudo make install

sigrok-cli

Installing the requirements

Debian/Ubuntu/Mint'

$ sudo apt-get install git-core gcc make autoconf automake libtool pkg-config libglib2.0-dev

Fedora (18, 19)

$ sudo yum install git gcc make autoconf automake libtool pkgconfig glib2-devel

OpenSuse

$ sudo zypper install git gcc make autoconf automake libtool pkgconfig glib2-devel

Arch

$ sudo pacman -S git gcc make autoconf automake libtool pkgconfig glib2

Building

$ git clone git://sigrok.org/sigrok-cli
$ cd sigrok-cli
$ ./autogen.sh
$ ./configure
$ make
$ sudo make install

PulseView

Installing the requirements

Debian/Ubuntu/Mint

$ sudo apt-get install git-core g++ make cmake libtool pkg-config \
  libglib2.0-dev libboost-test-dev libboost-serialization-dev \
  libboost-filesystem-dev libboost-system-dev libqt5svg5-dev qtbase5-dev

Fedora (18, 19, 23, 27)

$ sudo yum install git gcc cmake libtool pkgconfig glib2-devel \
  boost-devel qt5-devel

Arch

$ sudo pacman -S git gcc make cmake libtool pkgconfig glib2 boost qt5 \
  qt5-base qt5-svg

Building

$ git clone git://sigrok.org/pulseview
$ cd pulseview
$ cmake .
$ make
$ sudo make install

Troubleshooting

When building pulseview from the repository, make sure to install libsigrok and libsigrokdecode by building them from source too. Building the newest pulseview with outdated libraries (forked GH repositories, debian/ubuntu packages, etc) may cause errors like these to show up when running cmake.

CMake Error at CMakeLists.txt:86 (message):
 libsigrok C++ bindings missing, check libsigrok's 'configure' output
 (missing dependencies?)
CMake Error at /usr/share/cmake-3.7/Modules/FindPkgConfig.cmake:415 (message):
  A required package was not found
Call Stack (most recent call first):
  /usr/share/cmake-3.7/Modules/FindPkgConfig.cmake:588 (_pkg_check_modules_internal)
  CMakeLists.txt:83 (pkg_check_modules)

To make sure the dependencies are installed, you can use the following (Devuan/Debian/Ubuntu):

$ sudo pkg-config --list-all | grep <dependency package name>

To check the installed version, use:

$ sudo pkg-config --print-provides <dependency package name>

Hint: If something goes wrong, you can see what make is doing by running:

$ make VERBOSE=1

FAQ

Make sure to also see the Building FAQ for subjects that are not specific to Linux.

Cannot open shared object file: No such file or directory

See here.

TEST FAILED: .../lib/python2.7/site-packages/ does NOT support .pth files

See here.

Cannot access USB / serial / other device

See here.