10fae9624b
Fixes the following security issues: - CVE-2018-10754: In ncurses before 6.1.20180414, there is a NULL Pointer Dereference in the _nc_parse_entry function of tinfo/parse_entry.c. It could lead to a remote denial of service if the terminfo library code is used to process untrusted terminfo data in which a use-name is invalid syntax (REJECTED). - CVE-2018-19211: In ncurses 6.1, there is a NULL pointer dereference at function _nc_parse_entry in parse_entry.c that will lead to a denial of service attack. The product proceeds to the dereference code path even after a "dubious character `*' in name or alias field" detection. - CVE-2018-19217: In ncurses, possibly a 6.x version, there is a NULL pointer dereference at the function _nc_name_match that will lead to a denial of service attack. NOTE: the original report stated version 6.1, but the issue did not reproduce for that version according to the maintainer or a reliable third-party. - CVE-2019-17594: There is a heap-based buffer over-read in the _nc_find_entry function in tinfo/comp_hash.c in the terminfo library in ncurses before 6.1-20191012. - CVE-2019-17595: There is a heap-based buffer over-read in the fmt_entry function in tinfo/comp_hash.c in the terminfo library in ncurses before 6.1-20191012. Ncurses upstream uses a fairly special way of releasing (security) bugfixes. Approximately once a week an incremental .patch.gz is released, and once in a while these incremental patches are bundled up to a bigger patch relative to the current release in .patch.sh.bz2 format (a bzip2 compressed patch with a small shell script prepended, luckily apply-patches can handle that), and the relative patch files deleted. For details of this process, see the upstream FAQ: https://invisible-island.net/ncurses/ncurses.faq.html#applying_patches Apply the latest .patch.sh.bz2 and incremental patches up to 20200118 to fix a number of (security) issues. Notice that these patch files are NOT available on the GNU mirrors. The license file COPYING is updated with the new Copyright year (2019 -> 2020), so update the hash accordingly. While we are at it, adjust the white space in the .hash file to match sha256sum output for consistency. Signed-off-by: Peter Korsgaard <peter@korsgaard.com> [fix whitespace inconsistency after 'sha256' keyword] Signed-off-by: Thomas De Schampheleire <thomas.de_schampheleire@nokia.com> [yann.morin.1998@free.fr: fix license hash for (C) year] Signed-off-by: Yann E. MORIN <yann.morin.1998@free.fr>
200 lines
5.6 KiB
Makefile
200 lines
5.6 KiB
Makefile
################################################################################
|
|
#
|
|
# ncurses
|
|
#
|
|
################################################################################
|
|
|
|
NCURSES_VERSION = 6.1
|
|
NCURSES_SITE = $(BR2_GNU_MIRROR)/ncurses
|
|
NCURSES_INSTALL_STAGING = YES
|
|
NCURSES_DEPENDENCIES = host-ncurses
|
|
NCURSES_LICENSE = MIT with advertising clause
|
|
NCURSES_LICENSE_FILES = COPYING
|
|
NCURSES_CONFIG_SCRIPTS = ncurses$(NCURSES_LIB_SUFFIX)6-config
|
|
NCURSES_PATCH = \
|
|
$(addprefix https://invisible-mirror.net/archives/ncurses/$(NCURSES_VERSION)/, \
|
|
ncurses-6.1-20190609-patch.sh.bz2 \
|
|
ncurses-6.1-20190615.patch.gz \
|
|
ncurses-6.1-20190623.patch.gz \
|
|
ncurses-6.1-20190630.patch.gz \
|
|
ncurses-6.1-20190706.patch.gz \
|
|
ncurses-6.1-20190713.patch.gz \
|
|
ncurses-6.1-20190720.patch.gz \
|
|
ncurses-6.1-20190727.patch.gz \
|
|
ncurses-6.1-20190728.patch.gz \
|
|
ncurses-6.1-20190803.patch.gz \
|
|
ncurses-6.1-20190810.patch.gz \
|
|
ncurses-6.1-20190817.patch.gz \
|
|
ncurses-6.1-20190824.patch.gz \
|
|
ncurses-6.1-20190831.patch.gz \
|
|
ncurses-6.1-20190907.patch.gz \
|
|
ncurses-6.1-20190914.patch.gz \
|
|
ncurses-6.1-20190921.patch.gz \
|
|
ncurses-6.1-20190928.patch.gz \
|
|
ncurses-6.1-20191005.patch.gz \
|
|
ncurses-6.1-20191012.patch.gz \
|
|
ncurses-6.1-20191015.patch.gz \
|
|
ncurses-6.1-20191019.patch.gz \
|
|
ncurses-6.1-20191026.patch.gz \
|
|
ncurses-6.1-20191102.patch.gz \
|
|
ncurses-6.1-20191109.patch.gz \
|
|
ncurses-6.1-20191116.patch.gz \
|
|
ncurses-6.1-20191123.patch.gz \
|
|
ncurses-6.1-20191130.patch.gz \
|
|
ncurses-6.1-20191207.patch.gz \
|
|
ncurses-6.1-20191214.patch.gz \
|
|
ncurses-6.1-20191221.patch.gz \
|
|
ncurses-6.1-20191228.patch.gz \
|
|
ncurses-6.1-20200104.patch.gz \
|
|
ncurses-6.1-20200111.patch.gz \
|
|
ncurses-6.1-20200118.patch.gz \
|
|
)
|
|
|
|
NCURSES_CONF_OPTS = \
|
|
--without-cxx \
|
|
--without-cxx-binding \
|
|
--without-ada \
|
|
--without-tests \
|
|
--disable-big-core \
|
|
--without-profile \
|
|
--disable-rpath \
|
|
--disable-rpath-hack \
|
|
--enable-echo \
|
|
--enable-const \
|
|
--enable-overwrite \
|
|
--enable-pc-files \
|
|
--disable-stripping \
|
|
--with-pkg-config-libdir="/usr/lib/pkgconfig" \
|
|
$(if $(BR2_PACKAGE_NCURSES_TARGET_PROGS),,--without-progs) \
|
|
--without-manpages
|
|
|
|
ifeq ($(BR2_STATIC_LIBS),y)
|
|
NCURSES_CONF_OPTS += --without-shared --with-normal
|
|
else ifeq ($(BR2_SHARED_LIBS),y)
|
|
NCURSES_CONF_OPTS += --with-shared --without-normal
|
|
else ifeq ($(BR2_SHARED_STATIC_LIBS),y)
|
|
NCURSES_CONF_OPTS += --with-shared --with-normal
|
|
endif
|
|
|
|
# configure can't find the soname for libgpm when cross compiling
|
|
ifeq ($(BR2_PACKAGE_GPM),y)
|
|
NCURSES_CONF_OPTS += --with-gpm=libgpm.so.2
|
|
NCURSES_DEPENDENCIES += gpm
|
|
else
|
|
NCURSES_CONF_OPTS += --without-gpm
|
|
endif
|
|
|
|
NCURSES_TERMINFO_FILES = \
|
|
a/ansi \
|
|
d/dumb \
|
|
l/linux \
|
|
p/putty \
|
|
p/putty-256color \
|
|
p/putty-vt100 \
|
|
s/screen \
|
|
s/screen-256color \
|
|
v/vt100 \
|
|
v/vt100-putty \
|
|
v/vt102 \
|
|
v/vt200 \
|
|
v/vt220 \
|
|
x/xterm \
|
|
x/xterm+256color \
|
|
x/xterm-256color \
|
|
x/xterm-color \
|
|
x/xterm-xfree86 \
|
|
$(call qstrip,$(BR2_PACKAGE_NCURSES_ADDITIONAL_TERMINFO))
|
|
|
|
ifeq ($(BR2_PACKAGE_NCURSES_WCHAR),y)
|
|
NCURSES_CONF_OPTS += --enable-widec
|
|
NCURSES_LIB_SUFFIX = w
|
|
NCURSES_LIBS = ncurses menu panel form
|
|
|
|
define NCURSES_LINK_LIBS_STATIC
|
|
$(foreach lib,$(NCURSES_LIBS:%=lib%), \
|
|
ln -sf $(lib)$(NCURSES_LIB_SUFFIX).a $(STAGING_DIR)/usr/lib/$(lib).a
|
|
)
|
|
ln -sf libncurses$(NCURSES_LIB_SUFFIX).a \
|
|
$(STAGING_DIR)/usr/lib/libcurses.a
|
|
endef
|
|
|
|
define NCURSES_LINK_LIBS_SHARED
|
|
$(foreach lib,$(NCURSES_LIBS:%=lib%), \
|
|
ln -sf $(lib)$(NCURSES_LIB_SUFFIX).so $(STAGING_DIR)/usr/lib/$(lib).so
|
|
)
|
|
ln -sf libncurses$(NCURSES_LIB_SUFFIX).so \
|
|
$(STAGING_DIR)/usr/lib/libcurses.so
|
|
endef
|
|
|
|
define NCURSES_LINK_PC
|
|
$(foreach pc,$(NCURSES_LIBS), \
|
|
ln -sf $(pc)$(NCURSES_LIB_SUFFIX).pc \
|
|
$(STAGING_DIR)/usr/lib/pkgconfig/$(pc).pc
|
|
)
|
|
endef
|
|
|
|
NCURSES_LINK_STAGING_LIBS = \
|
|
$(if $(BR2_STATIC_LIBS)$(BR2_SHARED_STATIC_LIBS),$(call NCURSES_LINK_LIBS_STATIC);) \
|
|
$(if $(BR2_SHARED_LIBS)$(BR2_SHARED_STATIC_LIBS),$(call NCURSES_LINK_LIBS_SHARED))
|
|
|
|
NCURSES_LINK_STAGING_PC = $(call NCURSES_LINK_PC)
|
|
|
|
NCURSES_CONF_OPTS += --enable-ext-colors
|
|
|
|
NCURSES_POST_INSTALL_STAGING_HOOKS += NCURSES_LINK_STAGING_LIBS
|
|
NCURSES_POST_INSTALL_STAGING_HOOKS += NCURSES_LINK_STAGING_PC
|
|
|
|
endif # BR2_PACKAGE_NCURSES_WCHAR
|
|
|
|
ifneq ($(BR2_ENABLE_DEBUG),y)
|
|
NCURSES_CONF_OPTS += --without-debug
|
|
endif
|
|
|
|
# ncurses breaks with parallel build, but takes quite a while to
|
|
# build single threaded. Work around it similar to how Gentoo does
|
|
define NCURSES_BUILD_CMDS
|
|
$(TARGET_MAKE_ENV) $(MAKE1) -C $(@D) DESTDIR=$(STAGING_DIR) sources
|
|
rm -rf $(@D)/misc/pc-files
|
|
$(TARGET_MAKE_ENV) $(MAKE) -C $(@D) DESTDIR=$(STAGING_DIR)
|
|
endef
|
|
|
|
ifeq ($(BR2_PACKAGE_NCURSES_TARGET_PROGS),y)
|
|
define NCURSES_TARGET_SYMLINK_RESET
|
|
ln -sf tset $(TARGET_DIR)/usr/bin/reset
|
|
endef
|
|
NCURSES_POST_INSTALL_TARGET_HOOKS += NCURSES_TARGET_SYMLINK_RESET
|
|
endif
|
|
|
|
define NCURSES_TARGET_CLEANUP_TERMINFO
|
|
$(RM) -rf $(TARGET_DIR)/usr/share/terminfo $(TARGET_DIR)/usr/share/tabset
|
|
$(foreach t,$(NCURSES_TERMINFO_FILES), \
|
|
$(INSTALL) -D -m 0644 $(STAGING_DIR)/usr/share/terminfo/$(t) \
|
|
$(TARGET_DIR)/usr/share/terminfo/$(t)
|
|
)
|
|
endef
|
|
NCURSES_POST_INSTALL_TARGET_HOOKS += NCURSES_TARGET_CLEANUP_TERMINFO
|
|
|
|
#
|
|
# On systems with an older version of tic, the installation of ncurses hangs
|
|
# forever. To resolve the problem, build a static version of tic on host
|
|
# ourselves, and use that during installation.
|
|
#
|
|
define HOST_NCURSES_BUILD_CMDS
|
|
$(HOST_MAKE_ENV) $(MAKE1) -C $(@D) sources
|
|
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/progs tic
|
|
endef
|
|
|
|
HOST_NCURSES_CONF_OPTS = \
|
|
--with-shared \
|
|
--without-gpm \
|
|
--without-manpages \
|
|
--without-cxx \
|
|
--without-cxx-binding \
|
|
--without-ada \
|
|
--with-default-terminfo-dir=/usr/share/terminfo \
|
|
--disable-db-install \
|
|
--without-normal
|
|
|
|
$(eval $(autotools-package))
|
|
$(eval $(host-autotools-package))
|