m (moved Extras/SIGs/Embedded/CrossCompiling to Packaging Cross Compiling Toolchains: The page seems to have been forgotten to be moved earlier when all the Content from Extras, Extras/SIGs or Extras/SIGS/Embedded was moved) |
(fix wiki syntax) |
||
Line 13: | Line 13: | ||
The following guidelines apply to GCC, Binutils, glibc and other C libraries. | The following guidelines apply to GCC, Binutils, glibc and other C libraries. | ||
# Whenever possible, use the same version as the native tools. | |||
# All package names should be prefixed with <code>arch-os-libc-custom_tag-</code>, excluding each part if it is not required. Example: | |||
* Cross-compilers for the ARM that uses Linux as the operating system and ulibc as the C library, should be prefixed <code>arm-linux-ulibc-</code>. | #* Cross-compilers for the ARM that uses Linux as the operating system and ulibc as the C library, should be prefixed <code>arm-linux-ulibc-</code>. | ||
* The <code>custom_tag</code> is reserved to indicate that the cross-compiler is intended for a spesific target that requires some additional customization. | #* The <code>custom_tag</code> is reserved to indicate that the cross-compiler is intended for a spesific target that requires some additional customization. | ||
* Exceptions are allowed if this deviates from common practice. Example: Tools for the AVR are usually just prefixed with <code>avr-</code>. Deviation from this would break lots of peoples existing Makefiles. | #* Exceptions are allowed if this deviates from common practice. Example: Tools for the AVR are usually just prefixed with <code>avr-</code>. Deviation from this would break lots of peoples existing Makefiles. | ||
# All cross-compilers should add <code>--prefix=/usr/arch-os-libc</code> to <code>./configure</code> when building the toolchain. This is according to the cross-compiling guidelines in GCC's INSTALL document. | |||
# Symlinks to the binaries in <code>/usr/arch-os-libc-custom_tag/bin/</code> prefixed with the cross-compiler prefix should be created in <code>/usr/bin</code>. | |||
# Docs (man-pages, info and docs under %doc) should not be installed as they are identical to the native versions docs. Instead a README.Fedora will be installed through %doc redirecting people to the native docs. | |||
Line 26: | Line 26: | ||
For targets that do not use the GCC tool-chain for building software, no strict guidelines exist, and things therefore have to be decided on a case-by-case basis. However, the following guidelines should be good starting point: | For targets that do not use the GCC tool-chain for building software, no strict guidelines exist, and things therefore have to be decided on a case-by-case basis. However, the following guidelines should be good starting point: | ||
# Try to stay close to upstream's <code>Makefile</code>/<code>configure</code>. Deviating from this causes trouble, because <code>Makefile</code>s for projects tend to hardcode paths and names of binaries. | |||
# Be as FHS compatible as possible, except when it breaks 1. | |||
# Avoid generic file names. If a package f.ex. wants to install a binary names <code>cc</code> in <code>/usr/bin</code>, the binary should be moved to <code>/usr/libexec/%{name}</code>, and symlink with a <code>%{name -</code> prefix should be created in <code>/usr/bin/</code> |
Latest revision as of 13:00, 22 October 2009
Guidelines for Cross Compilation packages
Cross-compiling refers to the process of building software for one architecture on a different architecture. This is usually done either because the targeted platform is not powerful enough to build its own software, or because it makes development inconvenient.
Cross-compilers can be divided into two general categories:
- Cross-compiling GCC tool-chains.
- Other compilers.
Each category is described in the following sections.
Cross-compiling GCC tool-chains
The following guidelines apply to GCC, Binutils, glibc and other C libraries.
- Whenever possible, use the same version as the native tools.
- All package names should be prefixed with
arch-os-libc-custom_tag-
, excluding each part if it is not required. Example:- Cross-compilers for the ARM that uses Linux as the operating system and ulibc as the C library, should be prefixed
arm-linux-ulibc-
. - The
custom_tag
is reserved to indicate that the cross-compiler is intended for a spesific target that requires some additional customization. - Exceptions are allowed if this deviates from common practice. Example: Tools for the AVR are usually just prefixed with
avr-
. Deviation from this would break lots of peoples existing Makefiles.
- Cross-compilers for the ARM that uses Linux as the operating system and ulibc as the C library, should be prefixed
- All cross-compilers should add
--prefix=/usr/arch-os-libc
to./configure
when building the toolchain. This is according to the cross-compiling guidelines in GCC's INSTALL document. - Symlinks to the binaries in
/usr/arch-os-libc-custom_tag/bin/
prefixed with the cross-compiler prefix should be created in/usr/bin
. - Docs (man-pages, info and docs under %doc) should not be installed as they are identical to the native versions docs. Instead a README.Fedora will be installed through %doc redirecting people to the native docs.
Other compilers
For targets that do not use the GCC tool-chain for building software, no strict guidelines exist, and things therefore have to be decided on a case-by-case basis. However, the following guidelines should be good starting point:
- Try to stay close to upstream's
Makefile
/configure
. Deviating from this causes trouble, becauseMakefile
s for projects tend to hardcode paths and names of binaries. - Be as FHS compatible as possible, except when it breaks 1.
- Avoid generic file names. If a package f.ex. wants to install a binary names
cc
in/usr/bin
, the binary should be moved to/usr/libexec/%{name}
, and symlink with a%{name -
prefix should be created in/usr/bin/