[Pkg-javascript-devel] help to port nodejs to Debian riscv

Bo YU tsu.yubo at gmail.com
Sat Mar 12 13:38:17 GMT 2022


On Fri, Mar 11, 2022 at 10:35 PM Jérémy Lal <kapouer at melix.org> wrote:

>
>
> On Fri, Mar 11, 2022 at 3:26 PM vimer <tsu.yubo at gmail.com> wrote:
>
>> Hi,
>> On Fri, Mar 11, 2022 at 10:12:49AM +0100, Jérémy Lal wrote:
>> >   On Fri, Mar 11, 2022 at 6:03 AM Yadd <[1]yadd at debian.org> wrote:
>> >
>> >     On 11/03/2022 04:29, Bo YU wrote:
>> >     > hi
>> >     >
>> >     > On Thu, Mar 10, 2022 at 6:45 PM Jérémy Lal <[2]kapouer at melix.org
>> >     > <mailto:[3]kapouer at melix.org>> wrote:
>> >     >
>> >     >
>> >     >
>> >     >     On Thu, Mar 10, 2022 at 11:26 AM Bo YU <[4]tsu.yubo at gmail.com
>> ...
>> >     >
>> >     >         E: Unable to correct problems, you have held broken
>> >     packages.
>> >     >         apt-get failed.
>> >     >         E: Package installation failed
>> >     >         ```
>> >     >         This may be a common error on Debian riscv arch. I am
>> >     thinking
>> >     >         that I have to build from a package without
>> >     node-*dependencies?
>> >     >         Below is my operations step how to build(please point to
>> >     me
>> >     >         wrong as I am newbie to gbp also):
>> >     >         1. git clone
>> >     >               git clone git at salsa.debian.org:js-team/nodejs.git
>> >     >         2. checkout 16.14
>> >     >               git checkout -b main origin/master-16.x
>> >     >                git checkout -b upstream origin/upstream-16.x //
>> >     not need -b
>> >     >               git checkout -b pristine-tar origin/pristine-tar //
>> >     not
>> >     >         need -b also
>> >     >                git checkout main
>> >     >         3. gbp buildpackage --git-pbuilder --git-submodules
>> >     >         --git-upstream-branch='upstream/16.14'
>> >     --git-debian-branch=main
>> >     >         --git-no-pristine-tar --git-upstream-tree=tag
>> >     --git-ignore-new
>> >     >         -sa // the step to generate *.orig.tar.gz file. But I do
>> >     not
>> >     >         have the base directory /var/cache/pbuilder/base.cow and
>> >     it fail
>> >     >         at last(*.orig.tzr.gz has been generated)
>> >     >
>> >     >
>> >     >     You can do it a bit simpler because of the debian/gbp.conf
>> >     file, so
>> >     >     no need to rename any branch at all.
>> >     >     git checkout master-16.x
>> >     >     gbp buildpackage --git-pbuilder --git-ignore-new -sa
>> >     >
>> >     >         4. execute ` sudo sbuild --arch=riscv64 -d
>> >     sid-riscv64-sbuild `
>> >     >         and got above errors.
>> >     >
>> >     >         Just as I am editing the email, Suddenly IT occurred to
>> >     me,
>> >     >         maybe the distribution sid should be experimental, right?
>> >     >
>> >     >
>> >     >     yes, as i wrote above, those flags will need to be set (i
>> >     don't know
>> >     >     if gbp pass them along to pbuilder correctly, but that's the
>> >     idea):
>> >     >     -d experimental '--extra-repository=deb
>> >     [18]http://deb.debian.org/debian
>> >     >     <[19]http://deb.debian.org/debian> experimental main'
>> >     >     --build-dep-resolver=aspcud
>> >     >
>> >     >     Also you really will want to use the DEB_BUILD_PROFILES="nodoc
>> >     >     nocheck nobuiltin"
>> >     >
>> >     > I build it(last 17+ h) with your help.
>> >     > vimer at debian-local:~/build_test/nodejs/nodejs$ ls ../
>> >     > libnode93_16.14.0~dfsg-1_riscv64.deb
>> >     > nodejs_16.14.0~dfsg-1_riscv64.buildinfo
>> >     > libnode93-dbgsym_16.14.0~dfsg-1_riscv64.deb
>> >     >   nodejs_16.14.0~dfsg-1_riscv64.changes
>> >     > libnode-dev_16.14.0~dfsg-1_riscv64.deb
>> >     > nodejs_16.14.0~dfsg-1_riscv64.deb
>> >     > master-16.x
>> >     >   nodejs-16.14.0~dfsg.obsolete.1646911112.6398954
>> >     > nodejs
>> >     > nodejs-16.14.0~dfsg.obsolete.1646911132.04706
>> >     > nodejs-16.14.0~dfsg
>> >     >   nodejs_16.14.0~dfsg.orig-node-acorn.tar.xz
>> >     > nodejs_16.14.0~dfsg-1_amd64.build
>> >     nodejs_16.14.0~dfsg.orig.tar.xz
>> >     > nodejs_16.14.0~dfsg-1.debian.tar.xz
>> >     >   nodejs_16.14.0~dfsg.orig-types-node.tar.xz
>> >     > nodejs_16.14.0~dfsg-1.dsc
>> >     >   nodejs-dbgsym_16.14.0~dfsg-1_riscv64.deb
>> >     > nodejs_16.14.0~dfsg-1_riscv64.build
>> >     >   nodejs-doc_16.14.0~dfsg-1_all.deb
>> >     >   But there are mirror error :
>> >     > ···
>> >     > dwz: debian/libnode93/usr/lib/riscv64-linux-gnu/libnode.so.93: Too
>> >     many
>> >     > DIEs, not optimizing
>> >     > dh_dwz: error: dwz --max-die-limit 100000000 --
>> >
>> >   Hi Yadd, Bo,
>> >   That failure is not fatal and happens on some other archs too, you
>> >   don't really need to fix it.
>> >   Anyway once you built nodejs on riscv64 with DEB_BUILD_PROFILES as
>> >   above,
>> >   you should now try to build all the build-dependencies of nodejs that
>> >   themselves depend on nodejs
>> >   (they have the <!nocheck> or <!nodoc> flag in debian/control).
>> I checked those package with above tags, they are:
>>      sse2-support [i386]
>>      curl
>>      node_acron
>>      openssl
>>      pkg_js_tools
>>      procps
>>      node-js-yaml
>>      node-marked
>>      node-highlights.js
>> In fact, I must first resolve compiling Node-* package separately, right?
>>
>
> Attention: those packages must be rebuilt with DEB_BUILD_PROFILES="nocheck"
> or else you'll have to face a dependency hell, which i'm not sure you will
> not fall into anyway :)
>
> I try to build the pkg-js-tools package firstly(maybe it has the minimum
dependency of node, at last, it can build startup).
1. DEB_BUILD_PROFILES="nocheck"
2. sudo sbuild --arch=riscv64 -d sid-riscv64-sbuild
--extra-package=/home/vimer/nodejs_riscv64_debs/
the ` --extra-package`  argument is path the point to  riscv64 nodejs-* deb
packages last time build. It seem like to start build, but at last get:
···
dh_auto_configure: error: unable to load build system class 'nodejs': Can't
locate JSON.pm in @INC (you may need to install the JSON module) (@INC
contains: /<<PKGBUILDDIR>>/blib/lib /<<PKGBUILDDIR>>/blib/arch /etc/perl
/usr/local/lib/riscv64-linux-gnu/perl/5.34.0 /usr/local/share/perl/5.34.0
/usr/lib/riscv64-linux-gnu/perl5/5.34 /usr/share/perl5
/usr/lib/riscv64-linux-gnu/perl-base /usr/lib/riscv64-linux-gnu/perl/5.34
/usr/share/perl/5.34 /usr/local/lib/site_perl .) at
/<<PKGBUILDDIR>>/blib/lib/Debian/Debhelper/Buildsystem/nodejs.pm line 12.
BEGIN failed--compilation aborted at
/<<PKGBUILDDIR>>/blib/lib/Debian/Debhelper/Buildsystem/nodejs.pm line 12.
Compilation failed in require at (eval 2) line 1.
BEGIN failed--compilation aborted at (eval 2) line 1.

dh_additional.t: error: dh_auto_configure --buildsystem=nodejs subprocess
returned exit status 25
# Looks like your test exited with 25 before it could output anything.
t/dh_additional.t ..........
1..19
Dubious, test returned 25 (wstat 6400, 0x1900)
Failed 19/19 subtests
 ...
In fact, I have looked into dh_auto_configure usage to see what it is, but
have nothing to get. Could you to help find some clues
to train it? thank again!
BR,
Bo

Another question: How can i add  nodejs's build-dependencies package in
>> riscv64
>> vm as described in previous mail, For example, after building node_acron
>> package
>>
>
> It depends on your tools. --extra-package, --extra-repository are the
> options you need to look into.
>
> Jérémy
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/pkg-javascript-devel/attachments/20220312/ee8b5766/attachment.htm>


More information about the Pkg-javascript-devel mailing list