On Tue, 2019-02-19 at 02:05 +0900, Masahiro Yamada wrote: [...] > "make allnoconfig; make bindeb-pkg" > failed on Ubuntu 16.04, but succeeded on Ubuntu 18.04 > > I am puzzled... [...] > dpkg-buildpackage: host architecture i386 > dpkg-source --before-build linux > dpkg-checkbuilddeps: error: Unmet build dependencies: flex > dpkg-buildpackage: warning: build dependencies/conflicts unsatisfied; aborting > dpkg-buildpackage: warning: (Use -d flag to override.) > scripts/package/Makefile:78: recipe for target 'bindeb-pkg' failed > make[1]: *** [bindeb-pkg] Error 3 > Makefile:1390: recipe for target 'bindeb-pkg' failed > make: *** [bindeb-pkg] Error 2 > > > The docker file I used is below. > > If I change "FROM ubuntu:16.04" to "FROM ubuntu:18.04", > it goes well. [...] For a cross-build, some build-dependencies may need to belong to the host architecture (what the package will run on) while others do not. In general, they must do one of: (a) Belong to the host architecture (b) Belong to any architecture, and include "Multi-Arch: foreign" in their own metadata (c) Belong to an architecture specified in the Build-Depends field We normally want (b) for tools like flex. But flex is (I assume) missing the Multi-Arch field in Ubuntu 16.04, as it used to in Debian. The way we dealt with this in Debian before flex was fixed was (c): use "flex:native". But for reasons I don't understand that *isn't* compatible with (b), so to be compatible with both old and new versions of flex you should build-depend on: flex | flex:native Ben. -- Ben Hutchings The obvious mathematical breakthrough [to break modern encryption] would be development of an easy way to factor large prime numbers. - Bill Gates
Attachment:
signature.asc
Description: This is a digitally signed message part