1. 环境准备与依赖分析
在开始ARM-Linux下的CUPS交叉编译之前,我们需要先搞清楚整个环境的搭建思路。想象一下,你手里有一台ARM开发板,比如树莓派或者其他的工业控制板,它需要通过USB直接连接打印机来工作。但是板子本身性能有限,没法直接在上面编译复杂的软件,所以我们得在一台x86的电脑上(比如Ubuntu虚拟机)先编译好,再把成品搬过去。
这里有个关键点:交叉编译工具链。简单说,就是一套在x86电脑上运行,但能生成ARM可执行文件的编译器。我用的版本是arm-2014.05,虽然老但稳定,适合工业场景。你可能会问为什么不用新的?实测过,新版本工具链在某些老内核上反而容易出问题,所以保守点好。
依赖库的安装是第一步,也是最容易踩坑的地方。原始文档里列了一堆dev包,但有些需要调整。比如libavahi-client-dev是用于网络发现的,如果你的设备纯粹用USB打印,其实可以不要。但libusb-1.0-0-dev必须装,不然USB打印机识别不了。还有zlib1g-dev,压缩库,CUPS靠它处理数据流,缺了会编译失败。
我的习惯是先把基础依赖装全,避免后面反复折腾:
sudo apt-get update
sudo apt-get install autoconf build-essential libgnutls28-dev libkrb5-dev libpam-dev libusb-1.0-0-dev zlib1g-dev
注意,这里故意去掉了libavahi-client-dev和libsystemd-dev,因为很多嵌入式系统根本用不到这些服务。少一个依赖,就少一份移植时的麻烦。
2. 源码配置与交叉编译参数详解
下载CUPS源码建议选2.3.x版本,这个系列对ARM兼容性好,新版本反而容易出幺蛾子。解压后别急着configure,先看一眼README和INSTALL——我知道很多人跳过这步,但里面真有宝藏。比如INSTALL里提到,如果目标设备没有systemd,得加--disable-systemd参数,不然编译通不过。<


5485

被折叠的 条评论
为什么被折叠?



