dpkg-cross(1)



Name

   dpkg-cross - manage libraries for cross compiling

Copyright and Licence

    Copyright (C) 1997-2000  Roman Hodek <roman@hodek.net>
    Copyright (C) 2000-2002  Colin Watson <cjwatson@debian.org>
    Copyright (C) 2002-2004  David Schleef <ds@schleef.org>
    Copyright (C) 2004  Nikita Youshchenko <yoush@cs.msu.su>
    Copyright (C) 2004  Raphael Bossek <bossekr@debian.org>
    Copyright (c) 2007-2011  Neil Williams <codehelp@debian.org>
    Copyright (c) 2011  Wookey <wookey@debian.org>

    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.

SYNOPSIS

    dpkg-cross [OPTIONS] [--install|-i] <files...>
    dpkg-cross [OPTIONS] [--build|-b] <files...>
    dpkg-cross [OPTIONS] [--remove|--purge|-r] <packages...>
    dpkg-cross [OPTIONS] [--status|-s] <packages...>
    dpkg-cross [OPTIONS] [--list|-l] <packages...>
    dpkg-cross [OPTIONS] [--list-files|-L] <packages...>
    dpkg-cross [OPTIONS] [--query|-Q] <pkgpath>
    dpkg-cross [OPTIONS] [--update|-u] <pkgpath>

    OPTIONS: [ -v | --verbose ] [ -q | --quiet ]
    { [ -a | --arch ] architecture } { [ -X | --exclude ] PACKAGE }
    [ -A | --convert-anyway ] [ -M | --convert-multiarch ]  [ -k | --keep-temp ]

DESCRIPTION

   dpkg-cross is a tool to install and manage libraries and header files
   for cross compiling. dpkg-cross converts native Debian packages for the
   target architecture to cross compiling support packages that can be
   installed on any architecture, but in different paths to avoid
   conflicts. It then calls dpkg to install the converted package. The
   conversion step alone can be done with the --build option. Other
   options are wrappers around corresponding dpkg functionality.

   dpkg-cross is intended to make it easier for you to keep your cross
   compiling libraries up-to-date, as it works directly on Debian
   packages. It saves you copying the libs and headers from a machine with
   your target  architecture, or extracting them via dpkg-deb
   --fsys-tarfile.

   dpkg-cross also collects and install the .shlibs files in -dev
   packages, which are needed by dpkg-shlibdeps.

CMAKE

   CMake cross-building support is experimental!

   CMake requires a little support from dpkg-cross to cross-build. The
   included cmake support file is an example for Linux kernels.  Use:

    rm CMakeCache.txt
    cmake -DCMAKE_TOOLCHAIN_FILE=/etc/dpkg-cross/cmake/CMakeCross.txt

   The  main changes involve setting PKG_CONFIG_LIBDIR within CMake an
   setting the include directories to locate the cross libraries installed
   by dpkg-cross e.g.

    #Make pkg-config look in the right place
    SET(ENV{PKG_CONFIG_LIBDIR} ${CMAKE_FIND_ROOT_PATH}/lib/pkgconfig/)
    ELSE (CMAKE_CROSSCOMPILING)

   Packages using cmake may need some tweaks to debian/rules, e.g.

    ifneq ($(DEB_HOST_GNU_TYPE),$(DEB_BUILD_GNU_TYPE))
    export CC=$(DEB_HOST_GNU_TYPE)-gcc
    export CXX=$(DEB_HOST_GNU_TYPE)-g++
    export CMAKE_TOOLCHAIN_FILE=/etc/dpkg-cross/cmake/CMakeCross.txt
    else
    export CC=gcc
    export CXX=g++
    endif

OPTIONS

   dpkg-cross follows the usual GNU command line syntax, with long options
   starting with two dashes ('-').

    -h|--help

   Show summary of options.

    -v|--verbose

   Be more verbose.

    -q|--quiet

   Be more quiet.

    -a|--arch architecture

   Install for architecture architecture.

    -i|--install

   Install Debian packages (.deb) named on the command line. Only files in
   the directories /lib, /usr/lib and /usr/include are extracted, since
   only they can be relevant for cross compiling. In the lib directories,
   also no subdirectories are extracted.

    -A|--convert-anyway

   Convert Debian package even if it does not provide any files useful for
   cross-compile environment.

    -M|--convert-multiarch

   Convert package even if it is a multiarch package. If the package is
   not a multiarch package, processing continues as normal.

    -X|--exclude PACKAGE

   Removes the specified package from the dependencies of the current
   package. Typically used to drop dependencies on packages that are not
   required within a cross-build environment, e.g. packages containing
   only executables or architecture independent files.

   dpkg-cross can only check the current package and information about a
   dependency is not available (for that, use xapt). By default, dpkg-
   cross converts all dependencies to specify the cross version of the
   dependency package.

   If you know that a particular dependency should not be converted (it
   provides no useful files or is architecture  independent), that
   dependency can be excluded and dpkg-cross will remove that package from
   the dependency information of the cross package. -X has replaced the
   use of keepdeps and removedeps in /etc/dpkg-cross/cross-compile.

   -X|--exclude PACKAGE needs to be repeated for each package to be
   excluded.

    -k|--keep-temp

   Keep the built and installed package instead of deleting it.  Requires
   --install.

    -b|--build

   Just build the converted Debian package, but do not install it with
   dpkg.

    -r|--remove

   Remove the cross compiling packages named on the command line.

    -s|--status

   Print status of the named packages.

    -l|--list

   Print short version of status of named packages or package name
   patterns.

    -L|--list-files

   List files belonging to the named packages.

    -u|--update

   Update current cross-installation with Debian packages found in/under
   the paths given as arguments. Will check all packages there if they are
   installed already as cross-compiling packages and if they are really
   updates. Those packages will be installed as with -i.

    -Q|--query

   Much like --update, but just prints available update packages and does
   not install them.

FILES

   /etc/dpkg-cross/cross-compile defines the default_arch for dpkg-cross:

   The default architecture for dpkg-cross is normally set by debconf.  To
   change the system-wide value, use:

    $ sudo dpkg-reconfigure dpkg-cross

   Alternatively, the default can be overridden on a per-user basis using
   the optional file in $HOME/.dpkg-cross/

Conversion process

   There is no safe way for dpkg-cross to mangle certain files in -dev
   packages, particularly files in /usr/share or to determine precisely
   which of these files could be parsed and which cannot. Special cases do
   not help - dpkg-cross already has too many of those.

   It is not safe to leave files in the package nor is it safe to move
   files into arbitrary locations when there is no reliable and
   standardised way to determine the usefulness of a particular kind of
   file. Package specific config scripts cannot be supported and even
   build-system specific ones are not necessarily going to work without a
   lot of ongoing maintenance.

   Therefore, "dpkg-cross" is very restrictive on which files are retained
   in the -cross package.

   Files to be converted
   All files in

    /usr/include/*

   Also /usr/src and /usr/lib are searched for includes - files with .h,
   .hh, .hpp extensions (case insensitive).

   Library files - *.so* and *.a and *.o files from /lib and /usr/lib (and
   all the multilib eqivalents (lib64, lib32, libo32, libhf, libx32 etc).
   Other library files are not copied.  *.la files in library directories
   are also copied, and library and paths are modified there. Same for
   /usr/lib/pkgconfig/*.pc files.

   Symlinks are copied (and modified appropriately) if their destination
   is copied. Also, symlinks to non-existing shared libraries are copied
   (this is common case for libdevel packages)

   Directories are created only to hold some files or symlinks.  No empty
   directories are copied.

Multiarch behaviour

   By default <dpkg-cross> does nothing with packages from Debian which
   already support Multi-Arch - the package is simply copied to the
   current work directory, if it does not already exist. Any package
   containing a Multi-Arch: field in DEBIAN/control is skipped in this
   manner.

   --convert-multiarch can be specified to instead force the generation of
   a -<arch>-cross package with the files moved into the conventional
   dpkg-cross locations.

   The Multiarch spec ensures that multiarch packages will only be
   available from Debian mirrors once dpkg itself is capable of installing
   the packages and installing a Multiarch package means being able to
   install a 32bit multiarch package alongside a 64bit multiarch package.
   Installing an armel multiarch package alongside an x86 multiarch
   package is no different to 32bit vs 64bit. (What changes is how the
   multiarch package itself handles the header files and pkg-config
   files.)




Free and Open Source Software


Free Software Video

Useful Programs

Free Online Courses

Open Opportunity

Open Business