树莓派交叉编译知识

 

关键字:Recipes  ubuntu12

步骤1.构建工具链

由于我们要在具有Intel处理器的笔记本电脑上运行,并且我们希望在Raspberry Pi的核心上为ARM处理器构建目标代码,因此我们需要一个交叉编译器及其相关工具,通常称为“工具链”。 ”。在这里,我们使用“ crosstool-ng ”来构建这种工具链。

遵循安德鲁的建议,下面的许多说明都遵循克里斯·博特的这篇文章:http :
//www.bootc/archives/2012/05/26/how-to-build-a-cross-compiler-for-your-树莓派/

 

步骤1.1下载crosstool-ng

我们转到:http : //crosstool-ng/#download_and_usage

并下载最新版本,在撰写此博客时为:  1.17.0
请注意,在下载页面中,版本号按字母顺序(而不是数字)排序。
在我的第一次访问中,我直接进入页面底部并错误地获取了1.9.3版,
因为它位于页面底部…

下面的链接,按日期对下载进行了排序,可能对您有用:

  • /?sort=modtime&order=desc

文件00-LATEST-is-1.17.0也应该是一个提示……如果我注意的话……

We created a directory to host it and then downloaded and extracted the sources by doing:

  • mkdir -p  ~/src/RaspberryPi/toolchain
  • cd ~/src/RaspberryPi/toolchain
  • wget .17.0.tar.bz2
  • tar xjf crosstool-ng-1.17.0.tar.bz2
  • cd crosstool-ng-1.17.0

 

Step 1.2 Configure and Build

Here we continue following Chris Boot’s instructions.

We chose to configure the tool to be installed in a local directory inside our home directory.

  • cd ~/src/RaspberryPi/toolchain/crosstool-ng-1.17.0
  • mkdir -p ~/local/crosstool-ng
  • ./configure –prefix=/home/ibanez/local/crosstool-ng

to get this to work, we had to install the following Ubuntu packages (most of which were listed in Andrew’s recipe),

  • bison
  • cvs
  • flex
  • gperf
  • texinfo
  • automake
  • libtool

The whole is done with the command:

  • sudo aptitude install bison cvs flex gperf texinfo automake libtool

then we can do

  • make
  • make install

and add to the PATH the bin directory where crosstool-ng was installed:

  • export PATH=$PATH:/home/ibanez/local/crosstool-ng/bin/

In some cases, it might be necessary to unset the LD_LIBRARY_PATH,
to prevent the toolchain from grabbing other shared libraries from the host machine:

  • unset LD_LIBRARY_PATH

Step 1.3 Build Raspberry Toolchain

Create a staging directory. This is a temporary directory where the toolchain will be configured and built, but it is not its final installation place.

  • mkdir -p ~/src/RaspberryPi/staging
  • cd ~/src/RaspberryPi/staging/
  • ct-ng  menuconfig

 

/

Then, start the build process by typing

  • ct-ng  build

It was nice to see that the build projects uses the proper “make -j ” options for parallel building
and therefore makes use of all the available cores:

Step 1.4 Build the C++ compiler in the toolchain

By default, our process above only built the C compiler.

We are now going to build the C++ compiler as well.

To build the C++ compiler we do the following:

  • We go back to the staging directory:
    /home/ibanez/src/RaspberryPi/staging
  • and run the configuration process
    ct-ng menuconfig
  • We go into the “C compiler” option Enable the option “C++”
  • Save and Exit
  • and type again
    “ct-ng  build”
    to build the toolchain.
  • This completes the set up of the tool chain.

    We are now ready to use CMake to cross compile bigger projects.

Then, we can change directories to the bin directory and configure with CMake, by pointing to the toolchain file as:

  • cd /tmp/hello/bin
  • cmake -DCMAKE_TOOLCHAIN_FILE=/home/ibanez/bin/RaspberryPi/CMakeToolChain/Toolchain-RaspberryPi.cmake ../src
  • and simply build with “make”
  • Then copy the resulting executable to the Raspberry Pi, and run it.

Step 3. Setting up additional bin and lib files for cross compiling.

If you need access to the libraries on the RaspberryPi for compiling
(for example if you have built the latest boost libriaries on the RaspberryPi
and it is installed in /usr/local), you can copy these to a directory on your
host computer using rsync that will preserve the symlinks.

  • On your host machine you may also have to install rsync
    •  sudo aptitude install rsync
  • On the RaspberryPi install rsync:
    •  sudo apt-get istall rsync
  • Create a folder on the cross compiling machine. For example, here we call it: ~/bin/RaspberryPi
    • mkdir -p ~/bin/RaspberryPi
  • cd to this folder
    • cd  ~/bin/RaspberryPi
  • and do the following:
    • rsync -rl pi@raspberrypi.bigpond:/lib .
    • rsync -rl pi@raspberrypi.bigpond:/usr .

Remember to run these rsync commands whenever new libraries are added to the RaspberryPi system or when the RaspberryPi is upgraded.

 

内核编译

.md

  • 更新中
    • 在Raspberry Pi上更新Linux内核
  • 建造
    • 在Raspberry Pi上构建Linux内核
  • 配置中
    • 在Raspberry Pi上配置Linux内核
  • 打补丁
    • 在Raspberry Pi上将补丁应用到Linux内核
  • 标头
    • 获取内核头文件

在Raspberry Pi 4上安装64位Debian

.html

/

交叉编译C/c++

/@au42/the-useful-raspberrypi-cross-compile-guide-ea56054de187

  docker

/   cmake

/   cmake

/

 windows

交叉编译python环境

 

 

交叉编译QT

Step 3. Setting up additional bin and lib files for cross compiling.

If you need access to the libraries on the RaspberryPi for compiling
(for example if you have built the latest boost libriaries on the RaspberryPi
and it is installed in /usr/local), you can copy these to a directory on your
host computer using rsync that will preserve the symlinks.

  • On your host machine you may also have to install rsync
    •  sudo aptitude install rsync
  • On the RaspberryPi install rsync:
    •  sudo apt-get istall rsync
  • Create a folder on the cross compiling machine. For example, here we call it: ~/bin/RaspberryPi
    • mkdir -p ~/bin/RaspberryPi
  • cd to this folder
    • cd  ~/bin/RaspberryPi
  • and do the following:
    • rsync -rl pi@raspberrypi.bigpond:/lib .
    • rsync -rl pi@raspberrypi.bigpond:/usr .

Remember to run these rsync commands whenever new libraries are added to the RaspberryPi system or when the RaspberryPi is upgraded.

/

It is assumed that you have a SD card with Raspbian strech installed in your Raspberry Pi, otherwise download it and follow the installation guide. Also, check that you have the latest firmware, or install it and reboot the system. Execute the following command in the Raspberry Pi command-line interface for updating the firmware.

sudo rpi-update

reboot

Make sure that you have activated the Secure Shell (SSH) protocol in Raspbian. We will need it later to comunicate Qt Creator with your Raspbery Pi.

sudo raspi-config

Select Interfacing Options, select ssh, choose yes and finish.

The following list summarizes the main steps to cross-compile Qt 5.12 for Raspberry Pi, we will be describing each of them in this post. The [Pi] label means this action is done in the Raspberry Pi, whereas [Co] means it has to be performed in you computer.

  1. Install development libraries – [Pi]
  2. Prepare target folder – [Pi]
  3. Create working folder and set a toolchain – [Co]
  4. Create and configure a sysroot – [Co]
  5. Download Qt – [Co]
  6. Configure Qt for cross compilation – [Co]
  7. Compile, install and deploy Qt – [Co]
  8. Setup Qt Creator for Raspberry Pi cross compilation – [Co]

制作arm版本的deb包

 

 

构建针对Debian或Rasbian的.deb软件包的推荐方法是在计算机上或仿真的计算机内编译软件包。因此,为Raspberry Pi交叉编译.deb的推荐方法是在X86机器上使用qemu模拟一个完整的系统,然后使用它进行编译。 /(archive副本)

最新的Debian和Ubuntu sbuild工具中内置了真正的交叉编译支持,可用于编译或交叉编译.deb软件包,您可以通过遵循最新的Debian / Ubuntu Wiki指南来了解如何使用sbuild的交叉编译功能。(假设您正在运行最新的Debian或Ubuntu开发分支)。  

 

 

第一种方法是使用与Raspberry Pi Debian相同的主机Debian发行版。例如7.0。添加deb / unstable main 至您/etc/apt/sources.list并安装工具链:

apt-get update
apt-get install emdebian-archive-keyring
apt-get install gcc-4.7-arm-linux-gnueabihf g++-4.7-arm-linux-gnueabihf
apt-get install build-essential git debootstrap u-boot-tools

然后,可以通过xapt安装交叉编译的依赖项。也许您dpkg-buildpackage那时就可以使用。

替代方案:

您可以将软件包转换为使用CMake并使用CPack生成一个deb文件。这种方法也适用于其他发行版,例如openSuSe,Fedora。

更新:

随着Emdebian发行版更新的停止,建议切换到较新的Debian版本并使用多体系结构功能。

树莓派交叉编译知识

 

关键字:Recipes  ubuntu12

步骤1.构建工具链

由于我们要在具有Intel处理器的笔记本电脑上运行,并且我们希望在Raspberry Pi的核心上为ARM处理器构建目标代码,因此我们需要一个交叉编译器及其相关工具,通常称为“工具链”。 ”。在这里,我们使用“ crosstool-ng ”来构建这种工具链。

遵循安德鲁的建议,下面的许多说明都遵循克里斯·博特的这篇文章:http :
//www.bootc/archives/2012/05/26/how-to-build-a-cross-compiler-for-your-树莓派/

 

步骤1.1下载crosstool-ng

我们转到:http : //crosstool-ng/#download_and_usage

并下载最新版本,在撰写此博客时为:  1.17.0
请注意,在下载页面中,版本号按字母顺序(而不是数字)排序。
在我的第一次访问中,我直接进入页面底部并错误地获取了1.9.3版,
因为它位于页面底部…

下面的链接,按日期对下载进行了排序,可能对您有用:

  • /?sort=modtime&order=desc

文件00-LATEST-is-1.17.0也应该是一个提示……如果我注意的话……

We created a directory to host it and then downloaded and extracted the sources by doing:

  • mkdir -p  ~/src/RaspberryPi/toolchain
  • cd ~/src/RaspberryPi/toolchain
  • wget .17.0.tar.bz2
  • tar xjf crosstool-ng-1.17.0.tar.bz2
  • cd crosstool-ng-1.17.0

 

Step 1.2 Configure and Build

Here we continue following Chris Boot’s instructions.

We chose to configure the tool to be installed in a local directory inside our home directory.

  • cd ~/src/RaspberryPi/toolchain/crosstool-ng-1.17.0
  • mkdir -p ~/local/crosstool-ng
  • ./configure –prefix=/home/ibanez/local/crosstool-ng

to get this to work, we had to install the following Ubuntu packages (most of which were listed in Andrew’s recipe),

  • bison
  • cvs
  • flex
  • gperf
  • texinfo
  • automake
  • libtool

The whole is done with the command:

  • sudo aptitude install bison cvs flex gperf texinfo automake libtool

then we can do

  • make
  • make install

and add to the PATH the bin directory where crosstool-ng was installed:

  • export PATH=$PATH:/home/ibanez/local/crosstool-ng/bin/

In some cases, it might be necessary to unset the LD_LIBRARY_PATH,
to prevent the toolchain from grabbing other shared libraries from the host machine:

  • unset LD_LIBRARY_PATH

Step 1.3 Build Raspberry Toolchain

Create a staging directory. This is a temporary directory where the toolchain will be configured and built, but it is not its final installation place.

  • mkdir -p ~/src/RaspberryPi/staging
  • cd ~/src/RaspberryPi/staging/
  • ct-ng  menuconfig

 

/

Then, start the build process by typing

  • ct-ng  build

It was nice to see that the build projects uses the proper “make -j ” options for parallel building
and therefore makes use of all the available cores:

Step 1.4 Build the C++ compiler in the toolchain

By default, our process above only built the C compiler.

We are now going to build the C++ compiler as well.

To build the C++ compiler we do the following:

  • We go back to the staging directory:
    /home/ibanez/src/RaspberryPi/staging
  • and run the configuration process
    ct-ng menuconfig
  • We go into the “C compiler” option Enable the option “C++”
  • Save and Exit
  • and type again
    “ct-ng  build”
    to build the toolchain.
  • This completes the set up of the tool chain.

    We are now ready to use CMake to cross compile bigger projects.

Then, we can change directories to the bin directory and configure with CMake, by pointing to the toolchain file as:

  • cd /tmp/hello/bin
  • cmake -DCMAKE_TOOLCHAIN_FILE=/home/ibanez/bin/RaspberryPi/CMakeToolChain/Toolchain-RaspberryPi.cmake ../src
  • and simply build with “make”
  • Then copy the resulting executable to the Raspberry Pi, and run it.

Step 3. Setting up additional bin and lib files for cross compiling.

If you need access to the libraries on the RaspberryPi for compiling
(for example if you have built the latest boost libriaries on the RaspberryPi
and it is installed in /usr/local), you can copy these to a directory on your
host computer using rsync that will preserve the symlinks.

  • On your host machine you may also have to install rsync
    •  sudo aptitude install rsync
  • On the RaspberryPi install rsync:
    •  sudo apt-get istall rsync
  • Create a folder on the cross compiling machine. For example, here we call it: ~/bin/RaspberryPi
    • mkdir -p ~/bin/RaspberryPi
  • cd to this folder
    • cd  ~/bin/RaspberryPi
  • and do the following:
    • rsync -rl pi@raspberrypi.bigpond:/lib .
    • rsync -rl pi@raspberrypi.bigpond:/usr .

Remember to run these rsync commands whenever new libraries are added to the RaspberryPi system or when the RaspberryPi is upgraded.

 

内核编译

.md

  • 更新中
    • 在Raspberry Pi上更新Linux内核
  • 建造
    • 在Raspberry Pi上构建Linux内核
  • 配置中
    • 在Raspberry Pi上配置Linux内核
  • 打补丁
    • 在Raspberry Pi上将补丁应用到Linux内核
  • 标头
    • 获取内核头文件

在Raspberry Pi 4上安装64位Debian

.html

/

交叉编译C/c++

/@au42/the-useful-raspberrypi-cross-compile-guide-ea56054de187

  docker

/   cmake

/   cmake

/

 windows

交叉编译python环境

 

 

交叉编译QT

Step 3. Setting up additional bin and lib files for cross compiling.

If you need access to the libraries on the RaspberryPi for compiling
(for example if you have built the latest boost libriaries on the RaspberryPi
and it is installed in /usr/local), you can copy these to a directory on your
host computer using rsync that will preserve the symlinks.

  • On your host machine you may also have to install rsync
    •  sudo aptitude install rsync
  • On the RaspberryPi install rsync:
    •  sudo apt-get istall rsync
  • Create a folder on the cross compiling machine. For example, here we call it: ~/bin/RaspberryPi
    • mkdir -p ~/bin/RaspberryPi
  • cd to this folder
    • cd  ~/bin/RaspberryPi
  • and do the following:
    • rsync -rl pi@raspberrypi.bigpond:/lib .
    • rsync -rl pi@raspberrypi.bigpond:/usr .

Remember to run these rsync commands whenever new libraries are added to the RaspberryPi system or when the RaspberryPi is upgraded.

/

It is assumed that you have a SD card with Raspbian strech installed in your Raspberry Pi, otherwise download it and follow the installation guide. Also, check that you have the latest firmware, or install it and reboot the system. Execute the following command in the Raspberry Pi command-line interface for updating the firmware.

sudo rpi-update

reboot

Make sure that you have activated the Secure Shell (SSH) protocol in Raspbian. We will need it later to comunicate Qt Creator with your Raspbery Pi.

sudo raspi-config

Select Interfacing Options, select ssh, choose yes and finish.

The following list summarizes the main steps to cross-compile Qt 5.12 for Raspberry Pi, we will be describing each of them in this post. The [Pi] label means this action is done in the Raspberry Pi, whereas [Co] means it has to be performed in you computer.

  1. Install development libraries – [Pi]
  2. Prepare target folder – [Pi]
  3. Create working folder and set a toolchain – [Co]
  4. Create and configure a sysroot – [Co]
  5. Download Qt – [Co]
  6. Configure Qt for cross compilation – [Co]
  7. Compile, install and deploy Qt – [Co]
  8. Setup Qt Creator for Raspberry Pi cross compilation – [Co]

制作arm版本的deb包

 

 

构建针对Debian或Rasbian的.deb软件包的推荐方法是在计算机上或仿真的计算机内编译软件包。因此,为Raspberry Pi交叉编译.deb的推荐方法是在X86机器上使用qemu模拟一个完整的系统,然后使用它进行编译。 /(archive副本)

最新的Debian和Ubuntu sbuild工具中内置了真正的交叉编译支持,可用于编译或交叉编译.deb软件包,您可以通过遵循最新的Debian / Ubuntu Wiki指南来了解如何使用sbuild的交叉编译功能。(假设您正在运行最新的Debian或Ubuntu开发分支)。  

 

 

第一种方法是使用与Raspberry Pi Debian相同的主机Debian发行版。例如7.0。添加deb / unstable main 至您/etc/apt/sources.list并安装工具链:

apt-get update
apt-get install emdebian-archive-keyring
apt-get install gcc-4.7-arm-linux-gnueabihf g++-4.7-arm-linux-gnueabihf
apt-get install build-essential git debootstrap u-boot-tools

然后,可以通过xapt安装交叉编译的依赖项。也许您dpkg-buildpackage那时就可以使用。

替代方案:

您可以将软件包转换为使用CMake并使用CPack生成一个deb文件。这种方法也适用于其他发行版,例如openSuSe,Fedora。

更新:

随着Emdebian发行版更新的停止,建议切换到较新的Debian版本并使用多体系结构功能。