* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo
@ 2018-07-10 16:46 Hollis Blanchard
2018-07-10 19:52 ` Arnout Vandecappelle
` (2 more replies)
0 siblings, 3 replies; 9+ messages in thread
From: Hollis Blanchard @ 2018-07-10 16:46 UTC (permalink / raw)
To: buildroot
# HG changeset patch
# User Hollis Blanchard <hollis_blanchard@mentor.com>
# Date 1531239381 25200
# Tue Jul 10 09:16:21 2018 -0700
# Node ID 5f7fe697b92ac0145674a6c96aad0f787b4bae32
# Parent d71314cdccf1993ccdb05cddb16a5491f0bf723e
ncurses: make host-ncurses use host terminfo
Host GDB suffers a serious problem: pressing backspace (or ^W ^U or any other
"delete" key) results in a plain space being printed instead, making the
command prompt almost completely unusable.
That's because it's using host-ncurses, which embeds a path for the terminfo
database into the library itself. That path ends up being something like
/home/hollisb/buildroot.git/output/host/share/terminfo, which obviously doesn't
generally exist other hosts. ('relocate-sdk.sh' cannot and does not edit
binaries like libncurses.so.6, so doesn't resolve this problem.)
/usr/share/terminfo is a far better path to use, since it almost certainly
exists on the host. Theoretically, it could be from a different ncurses version
with incompatible terminfo database format, but this doesn't seem to be a
problem in practice. (Future patches could address the theoretical problem if
it actually appears in real life.)
This change allows buildroot's host gdb, which uses ncurses 6.x, to work on
RHEL5, RHEL6, and RHEL7, which all provide terminfo from ncurses 5.x.
Signed-off-by: Hollis Blanchard <hollis_blanchard@mentor.com>
diff --git a/package/ncurses/ncurses.mk b/package/ncurses/ncurses.mk
--- a/package/ncurses/ncurses.mk
+++ b/package/ncurses/ncurses.mk
@@ -153,6 +153,7 @@ HOST_NCURSES_CONF_OPTS = \
--without-cxx \
--without-cxx-binding \
--without-ada \
+ --with-default-terminfo-dir=/usr/share/terminfo \
--without-normal
$(eval $(autotools-package))
^ permalink raw reply [flat|nested] 9+ messages in thread* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-07-10 16:46 [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo Hollis Blanchard @ 2018-07-10 19:52 ` Arnout Vandecappelle 2018-07-17 14:40 ` Thomas Petazzoni 2018-07-19 21:38 ` Peter Korsgaard 2 siblings, 0 replies; 9+ messages in thread From: Arnout Vandecappelle @ 2018-07-10 19:52 UTC (permalink / raw) To: buildroot On 10-07-18 18:46, Hollis Blanchard wrote: > # HG changeset patch > # User Hollis Blanchard <hollis_blanchard@mentor.com> > # Date 1531239381 25200 > # Tue Jul 10 09:16:21 2018 -0700 > # Node ID 5f7fe697b92ac0145674a6c96aad0f787b4bae32 > # Parent d71314cdccf1993ccdb05cddb16a5491f0bf723e > ncurses: make host-ncurses use host terminfo > > Host GDB suffers a serious problem: pressing backspace (or ^W ^U or any other > "delete" key) results in a plain space being printed instead, making the > command prompt almost completely unusable. > > That's because it's using host-ncurses, which embeds a path for the terminfo > database into the library itself. That path ends up being something like > /home/hollisb/buildroot.git/output/host/share/terminfo, which obviously doesn't > generally exist other hosts. ('relocate-sdk.sh' cannot and does not edit > binaries like libncurses.so.6, so doesn't resolve this problem.) > > /usr/share/terminfo is a far better path to use, since it almost certainly > exists on the host. Theoretically, it could be from a different ncurses version > with incompatible terminfo database format, but this doesn't seem to be a > problem in practice. (Future patches could address the theoretical problem if > it actually appears in real life.) Indeed, the terminfo information is standardized AFAIU so this should indeed work. Reviewed-by: Arnout Vandecappelle (Essensium/Mind) <arnout@mind.be> Regards, Arnout > This change allows buildroot's host gdb, which uses ncurses 6.x, to work on > RHEL5, RHEL6, and RHEL7, which all provide terminfo from ncurses 5.x. > > Signed-off-by: Hollis Blanchard <hollis_blanchard@mentor.com> > > diff --git a/package/ncurses/ncurses.mk b/package/ncurses/ncurses.mk > --- a/package/ncurses/ncurses.mk > +++ b/package/ncurses/ncurses.mk > @@ -153,6 +153,7 @@ HOST_NCURSES_CONF_OPTS = \ > --without-cxx \ > --without-cxx-binding \ > --without-ada \ > + --with-default-terminfo-dir=/usr/share/terminfo \ > --without-normal > > $(eval $(autotools-package)) > _______________________________________________ > buildroot mailing list > buildroot at busybox.net > http://lists.busybox.net/mailman/listinfo/buildroot > -- Arnout Vandecappelle arnout at mind be Senior Embedded Software Architect +32-16-286500 Essensium/Mind http://www.mind.be G.Geenslaan 9, 3001 Leuven, Belgium BE 872 984 063 RPR Leuven LinkedIn profile: http://www.linkedin.com/in/arnoutvandecappelle GPG fingerprint: 7493 020B C7E3 8618 8DEC 222C 82EB F404 F9AC 0DDF ^ permalink raw reply [flat|nested] 9+ messages in thread
* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-07-10 16:46 [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo Hollis Blanchard 2018-07-10 19:52 ` Arnout Vandecappelle @ 2018-07-17 14:40 ` Thomas Petazzoni 2018-07-17 16:53 ` Hollis Blanchard 2018-07-19 21:38 ` Peter Korsgaard 2 siblings, 1 reply; 9+ messages in thread From: Thomas Petazzoni @ 2018-07-17 14:40 UTC (permalink / raw) To: buildroot Hello, On Tue, 10 Jul 2018 09:46:03 -0700, Hollis Blanchard wrote: > # HG changeset patch > # User Hollis Blanchard <hollis_blanchard@mentor.com> > # Date 1531239381 25200 > # Tue Jul 10 09:16:21 2018 -0700 > # Node ID 5f7fe697b92ac0145674a6c96aad0f787b4bae32 > # Parent d71314cdccf1993ccdb05cddb16a5491f0bf723e This mercurial stuff is a bit annoying, as it becomes part of the commit log. I removed it when applying the patch. > ncurses: make host-ncurses use host terminfo > > Host GDB suffers a serious problem: pressing backspace (or ^W ^U or any other > "delete" key) results in a plain space being printed instead, making the > command prompt almost completely unusable. > > That's because it's using host-ncurses, which embeds a path for the terminfo > database into the library itself. That path ends up being something like > /home/hollisb/buildroot.git/output/host/share/terminfo, which obviously doesn't > generally exist other hosts. ('relocate-sdk.sh' cannot and does not edit > binaries like libncurses.so.6, so doesn't resolve this problem.) > > /usr/share/terminfo is a far better path to use, since it almost certainly > exists on the host. Theoretically, it could be from a different ncurses version > with incompatible terminfo database format, but this doesn't seem to be a > problem in practice. (Future patches could address the theoretical problem if > it actually appears in real life.) > > This change allows buildroot's host gdb, which uses ncurses 6.x, to work on > RHEL5, RHEL6, and RHEL7, which all provide terminfo from ncurses 5.x. > > Signed-off-by: Hollis Blanchard <hollis_blanchard@mentor.com> Applied, thanks! Thomas Petazzoni -- Thomas Petazzoni, CTO, Bootlin (formerly Free Electrons) Embedded Linux and Kernel engineering https://bootlin.com ^ permalink raw reply [flat|nested] 9+ messages in thread
* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-07-17 14:40 ` Thomas Petazzoni @ 2018-07-17 16:53 ` Hollis Blanchard 0 siblings, 0 replies; 9+ messages in thread From: Hollis Blanchard @ 2018-07-17 16:53 UTC (permalink / raw) To: buildroot On 07/17/2018 07:40 AM, Thomas Petazzoni wrote: > Hello, > > On Tue, 10 Jul 2018 09:46:03 -0700, Hollis Blanchard wrote: >> # HG changeset patch >> # User Hollis Blanchard <hollis_blanchard@mentor.com> >> # Date 1531239381 25200 >> # Tue Jul 10 09:16:21 2018 -0700 >> # Node ID 5f7fe697b92ac0145674a6c96aad0f787b4bae32 >> # Parent d71314cdccf1993ccdb05cddb16a5491f0bf723e > This mercurial stuff is a bit annoying, as it becomes part of the > commit log. I removed it when applying the patch. You're right, and thank you for removing it. Hollis Blanchard Mentor Graphics Emulation Division ^ permalink raw reply [flat|nested] 9+ messages in thread
* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-07-10 16:46 [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo Hollis Blanchard 2018-07-10 19:52 ` Arnout Vandecappelle 2018-07-17 14:40 ` Thomas Petazzoni @ 2018-07-19 21:38 ` Peter Korsgaard 2018-08-08 14:10 ` Peter Korsgaard 2 siblings, 1 reply; 9+ messages in thread From: Peter Korsgaard @ 2018-07-19 21:38 UTC (permalink / raw) To: buildroot >>>>> "Hollis" == Hollis Blanchard <hollis_blanchard@mentor.com> writes: > # HG changeset patch > # User Hollis Blanchard <hollis_blanchard@mentor.com> > # Date 1531239381 25200 > # Tue Jul 10 09:16:21 2018 -0700 > # Node ID 5f7fe697b92ac0145674a6c96aad0f787b4bae32 > # Parent d71314cdccf1993ccdb05cddb16a5491f0bf723e > ncurses: make host-ncurses use host terminfo > Host GDB suffers a serious problem: pressing backspace (or ^W ^U or any other > "delete" key) results in a plain space being printed instead, making the > command prompt almost completely unusable. > That's because it's using host-ncurses, which embeds a path for the terminfo > database into the library itself. That path ends up being something like > /home/hollisb/buildroot.git/output/host/share/terminfo, which obviously doesn't > generally exist other hosts. ('relocate-sdk.sh' cannot and does not edit > binaries like libncurses.so.6, so doesn't resolve this problem.) > /usr/share/terminfo is a far better path to use, since it almost certainly > exists on the host. Theoretically, it could be from a different ncurses version > with incompatible terminfo database format, but this doesn't seem to be a > problem in practice. (Future patches could address the theoretical problem if > it actually appears in real life.) > This change allows buildroot's host gdb, which uses ncurses 6.x, to work on > RHEL5, RHEL6, and RHEL7, which all provide terminfo from ncurses 5.x. > Signed-off-by: Hollis Blanchard <hollis_blanchard@mentor.com> Committed to 2018.02.x and 2018.05.x, thanks. -- Bye, Peter Korsgaard ^ permalink raw reply [flat|nested] 9+ messages in thread
* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-07-19 21:38 ` Peter Korsgaard @ 2018-08-08 14:10 ` Peter Korsgaard 2018-08-08 20:37 ` Arnout Vandecappelle 0 siblings, 1 reply; 9+ messages in thread From: Peter Korsgaard @ 2018-08-08 14:10 UTC (permalink / raw) To: buildroot >>>>> "Peter" == Peter Korsgaard <peter@korsgaard.com> writes: Hi, >> # HG changeset patch >> # User Hollis Blanchard <hollis_blanchard@mentor.com> >> # Date 1531239381 25200 >> # Tue Jul 10 09:16:21 2018 -0700 >> # Node ID 5f7fe697b92ac0145674a6c96aad0f787b4bae32 >> # Parent d71314cdccf1993ccdb05cddb16a5491f0bf723e >> ncurses: make host-ncurses use host terminfo >> Host GDB suffers a serious problem: pressing backspace (or ^W ^U or any other >> "delete" key) results in a plain space being printed instead, making the >> command prompt almost completely unusable. >> That's because it's using host-ncurses, which embeds a path for the terminfo >> database into the library itself. That path ends up being something like >> /home/hollisb/buildroot.git/output/host/share/terminfo, which obviously doesn't >> generally exist other hosts. ('relocate-sdk.sh' cannot and does not edit >> binaries like libncurses.so.6, so doesn't resolve this problem.) >> /usr/share/terminfo is a far better path to use, since it almost certainly >> exists on the host. Theoretically, it could be from a different ncurses version >> with incompatible terminfo database format, but this doesn't seem to be a >> problem in practice. (Future patches could address the theoretical problem if >> it actually appears in real life.) >> This change allows buildroot's host gdb, which uses ncurses 6.x, to work on >> RHEL5, RHEL6, and RHEL7, which all provide terminfo from ncurses 5.x. >> Signed-off-by: Hollis Blanchard <hollis_blanchard@mentor.com> > Committed to 2018.02.x and 2018.05.x, thanks. Hmm, this triggers an interesting issue with tic :/ ** Building terminfo database, please wait... Running sh ./shlib tic to install /usr/share/terminfo ... You may see messages regarding extended capabilities, e.g., AX. These are extended terminal capabilities which are compiled using tic -x If you have ncurses 4.2 applications, you should read the INSTALL document, and install the terminfo without the -x option. "terminfo.tmp", line 21272, terminal 'v3220': /home/peko/.terminfo: permission denied (errno 30) What happens here is that tic doesn't have write access to /usr/share/terminfo (as we are not root), so instead it writes the db to ~/.terminfo. We in general don't want buildroot to touch any files outside the buildroot output directory (and $TMPDIR), but it normally isn't enforced/checked by the autobuilders. For this specific setup with building inside a container $HOME is mounted readonly, so it really fails. The question is how to fix it. The logical solution would be to set TERMINFO to get it to put the database somewhere else, but that doesn't work because run_tic.sh overwrites it: # don't use user's TERMINFO variable TERMINFO=${DESTDIR}$ticdir ; export TERMINFO The only fix I can think of is: HOST_NCURSES_MAKE_ENV += HOME=$(HOST_DIR) But that isn't very nice. Any other ideas? -- Bye, Peter Korsgaard ^ permalink raw reply [flat|nested] 9+ messages in thread
* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-08-08 14:10 ` Peter Korsgaard @ 2018-08-08 20:37 ` Arnout Vandecappelle 2018-08-09 0:19 ` Hollis Blanchard 2018-08-09 14:28 ` Peter Korsgaard 0 siblings, 2 replies; 9+ messages in thread From: Arnout Vandecappelle @ 2018-08-08 20:37 UTC (permalink / raw) To: buildroot On 08-08-18 16:10, Peter Korsgaard wrote: >>>>>> "Peter" == Peter Korsgaard <peter@korsgaard.com> writes: > > Hi, > > >> # HG changeset patch > >> # User Hollis Blanchard <hollis_blanchard@mentor.com> > >> # Date 1531239381 25200 > >> # Tue Jul 10 09:16:21 2018 -0700 > >> # Node ID 5f7fe697b92ac0145674a6c96aad0f787b4bae32 > >> # Parent d71314cdccf1993ccdb05cddb16a5491f0bf723e > >> ncurses: make host-ncurses use host terminfo > > >> Host GDB suffers a serious problem: pressing backspace (or ^W ^U or any other > >> "delete" key) results in a plain space being printed instead, making the > >> command prompt almost completely unusable. > > >> That's because it's using host-ncurses, which embeds a path for the terminfo > >> database into the library itself. That path ends up being something like > >> /home/hollisb/buildroot.git/output/host/share/terminfo, which obviously doesn't > >> generally exist other hosts. ('relocate-sdk.sh' cannot and does not edit > >> binaries like libncurses.so.6, so doesn't resolve this problem.) > > >> /usr/share/terminfo is a far better path to use, since it almost certainly > >> exists on the host. Theoretically, it could be from a different ncurses version > >> with incompatible terminfo database format, but this doesn't seem to be a > >> problem in practice. (Future patches could address the theoretical problem if > >> it actually appears in real life.) > > >> This change allows buildroot's host gdb, which uses ncurses 6.x, to work on > >> RHEL5, RHEL6, and RHEL7, which all provide terminfo from ncurses 5.x. > > >> Signed-off-by: Hollis Blanchard <hollis_blanchard@mentor.com> > > > Committed to 2018.02.x and 2018.05.x, thanks. > > Hmm, this triggers an interesting issue with tic :/ > > ** Building terminfo database, please wait... > Running sh ./shlib tic to install /usr/share/terminfo ... > > You may see messages regarding extended capabilities, e.g., AX. > These are extended terminal capabilities which are compiled > using > tic -x > If you have ncurses 4.2 applications, you should read the INSTALL > document, and install the terminfo without the -x option. > > "terminfo.tmp", line 21272, terminal 'v3220': /home/peko/.terminfo: permission denied (errno 30) > > What happens here is that tic doesn't have write access to > /usr/share/terminfo (as we are not root), so instead it writes the db to > ~/.terminfo. > > We in general don't want buildroot to touch any files outside the > buildroot output directory (and $TMPDIR), but it normally isn't > enforced/checked by the autobuilders. For this specific setup with > building inside a container $HOME is mounted readonly, so it really > fails. Actually, sounds like a good idea to have an autobuilder that does exactly this: nothing writeable outside of OUTPUT_DIR. > > The question is how to fix it. The logical solution would be to set > TERMINFO to get it to put the database somewhere else, but that doesn't > work because run_tic.sh overwrites it: > > # don't use user's TERMINFO variable > TERMINFO=${DESTDIR}$ticdir ; export TERMINFO ^^^^^^^^^^ So, set DESTDIR? Or actually, why is this script called at all? The whole point of Hollis's patch was to use the system's terminfo, so why should we generate the terminfo at all? In other words, can't we just pass --disable-db-install ? Regards, Arnout > > The only fix I can think of is: > > HOST_NCURSES_MAKE_ENV += HOME=$(HOST_DIR) > > But that isn't very nice. Any other ideas? > -- Arnout Vandecappelle arnout at mind be Senior Embedded Software Architect +32-16-286500 Essensium/Mind http://www.mind.be G.Geenslaan 9, 3001 Leuven, Belgium BE 872 984 063 RPR Leuven LinkedIn profile: http://www.linkedin.com/in/arnoutvandecappelle GPG fingerprint: 7493 020B C7E3 8618 8DEC 222C 82EB F404 F9AC 0DDF ^ permalink raw reply [flat|nested] 9+ messages in thread
* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-08-08 20:37 ` Arnout Vandecappelle @ 2018-08-09 0:19 ` Hollis Blanchard 2018-08-09 14:28 ` Peter Korsgaard 1 sibling, 0 replies; 9+ messages in thread From: Hollis Blanchard @ 2018-08-09 0:19 UTC (permalink / raw) To: buildroot On 08/08/2018 01:37 PM, Arnout Vandecappelle wrote: > On 08-08-18 16:10, Peter Korsgaard wrote: >> The question is how to fix it. The logical solution would be to set >> TERMINFO to get it to put the database somewhere else, but that doesn't >> work because run_tic.sh overwrites it: >> >> # don't use user's TERMINFO variable >> TERMINFO=${DESTDIR}$ticdir ; export TERMINFO > ^^^^^^^^^^ > So, set DESTDIR? > > Or actually, why is this script called at all? The whole point of Hollis's > patch was to use the system's terminfo, so why should we generate the terminfo > at all? In other words, can't we just pass --disable-db-install ? I agree that we don't want to generate terminfo in the /host/ ncurses. I can confirm that adding --disable-db-install fixes the build behavior that I also see (building host-ncurses writes to my ~/.terminfo). I can't imagine a problem, but I just haven't yet been able to rebuild a full toolchain with --disable-db-install. Hollis Blanchard Mentor Graphics Emulation Division -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.busybox.net/pipermail/buildroot/attachments/20180808/bc8c4ea2/attachment.html> ^ permalink raw reply [flat|nested] 9+ messages in thread
* [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo 2018-08-08 20:37 ` Arnout Vandecappelle 2018-08-09 0:19 ` Hollis Blanchard @ 2018-08-09 14:28 ` Peter Korsgaard 1 sibling, 0 replies; 9+ messages in thread From: Peter Korsgaard @ 2018-08-09 14:28 UTC (permalink / raw) To: buildroot >>>>> "Arnout" == Arnout Vandecappelle <arnout@mind.be> writes: Hi, >> We in general don't want buildroot to touch any files outside the >> buildroot output directory (and $TMPDIR), but it normally isn't >> enforced/checked by the autobuilders. For this specific setup with >> building inside a container $HOME is mounted readonly, so it really >> fails. > Actually, sounds like a good idea to have an autobuilder that does exactly > this: nothing writeable outside of OUTPUT_DIR. Indeed. I will try to find (time and cpu) cycles to setup such a builder. >> >> The question is how to fix it. The logical solution would be to set >> TERMINFO to get it to put the database somewhere else, but that doesn't >> work because run_tic.sh overwrites it: >> >> # don't use user's TERMINFO variable >> TERMINFO=${DESTDIR}$ticdir ; export TERMINFO > ^^^^^^^^^^ > So, set DESTDIR? That isn't really handy as DESTDIR is used in a bunch of other places and this is built as part of make install. > Or actually, why is this script called at all? The whole point of Hollis's > patch was to use the system's terminfo, so why should we generate the terminfo > at all? In other words, can't we just pass --disable-db-install ? Ahh, I hadn't noticed that option. That indeed works, I'll send a patch - Thanks! -- Bye, Peter Korsgaard ^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2018-08-09 14:28 UTC | newest] Thread overview: 9+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2018-07-10 16:46 [Buildroot] [PATCH] ncurses: make host-ncurses use host terminfo Hollis Blanchard 2018-07-10 19:52 ` Arnout Vandecappelle 2018-07-17 14:40 ` Thomas Petazzoni 2018-07-17 16:53 ` Hollis Blanchard 2018-07-19 21:38 ` Peter Korsgaard 2018-08-08 14:10 ` Peter Korsgaard 2018-08-08 20:37 ` Arnout Vandecappelle 2018-08-09 0:19 ` Hollis Blanchard 2018-08-09 14:28 ` Peter Korsgaard
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.