[Buildroot] [PATCH 1/1] qt: add X11 support

gwenhael.goavec gwenj at trabucayre.com
Tue Jan 6 09:58:16 UTC 2015


up

On Tue, 16 Dec 2014 10:44:29 +0100
"gwenhael.goavec" <gwenj at trabucayre.com> wrote:

> On Tue, 15 Jul 2014 18:30:56 +0200
> Hadrien Boutteville <hadrien.boutteville at gmail.com> wrote:
> 
> > There are two possible configurations for Qt4 installation: standard
> > (with X11) and embedded (for framebuffer). Both configurations cannot be
> > used together for one installation and some options are specific to one
> > configuration or the other.
> > 
> > Add a choice to select the standard or the embedded installation to add
> > X11 support.
> > 
> > The integration is done in order to make maximum use of the current
> > configuration logic, for example by using the same mkspecs files.
> > 
> > Signed-off-by: Hadrien Boutteville <hadrien.boutteville at gmail.com>
> > Cc: Thomas Petazzoni <thomas.petazzoni at free-electrons.com>
> > Cc: "Yann E. MORIN" <yann.morin.1998 at free.fr>
> 
> Hi,
> Works on ARM (Armadeus APF51).
> Tested-by: Gwenhael Goavec-Merou <gwenhael.goavec-merou at trabucayre.com>
> > ---
> > 
> > For now I only tested under Qemu without all modules (successfully).
> > I will do more tests on an ARM target, but feel free to test on your
> > side ;-).
> > 
> > ---
> >  package/qt/Config.in | 46 ++++++++++++++++++++++++++++++++++++++++++++++
> >  package/qt/qt.mk     | 15 +++++++++++++++
> >  2 files changed, 61 insertions(+)
> > 
> > diff --git a/package/qt/Config.in b/package/qt/Config.in
> > index 0a21e93..abab229 100644
> > --- a/package/qt/Config.in
> > +++ b/package/qt/Config.in
> > @@ -17,6 +17,40 @@ menuconfig BR2_PACKAGE_QT
> >  
> >  if BR2_PACKAGE_QT
> >  
> > +choice
> > +	prompt "Qt installation"
> > +	help
> > +	  Selects the type of installation: standard or embedded
> > +
> > +config BR2_PACKAGE_QT_EMBEDDED
> > +	bool "Qt embedded"
> > +	help
> > +	  The embedded Qt installation targets embedded systems without X.org.
> > +	  Provides backends for framebuffer.
> > +	  If unsure, say Y.
> > +
> > +comment "Qt standard (X11) not available (need X.org)"
> > +	depends on !BR2_PACKAGE_XORG7
> > +
> > +config BR2_PACKAGE_QT_X11
> > +	bool "Qt standard (X11)"
> > +	depends on BR2_PACKAGE_XORG7
> > +	select BR2_PACKAGE_FONTCONFIG
> > +	select BR2_PACKAGE_XLIB_LIBXI
> > +	select BR2_PACKAGE_XLIB_LIBX11
> > +	select BR2_PACKAGE_XLIB_LIBXRENDER
> > +	select BR2_PACKAGE_XLIB_LIBXCURSOR
> > +	select BR2_PACKAGE_XLIB_LIBXRANDR
> > +	select BR2_PACKAGE_XLIB_LIBXEXT
> > +	select BR2_PACKAGE_XLIB_LIBXV
> > +	select BR2_PACKAGE_QT_SYSTEMFREETYPE
> > +	select BR2_PACKAGE_QT_GUI_MODULE
> > +	help
> > +	  The standard Qt installation provides X.org backend. If you don't want to
> > +	  use X.org, say N.
> > +
> > +endchoice
> > +
> >  config BR2_PACKAGE_QT_DEBUG
> >  	bool "Compile with debug support"
> >  	help
> > @@ -98,6 +132,9 @@ config BR2_PACKAGE_QT_GUI_MODULE
> >  	  video output, or you don't require Qt GUI, say n.
> >  
> >  if BR2_PACKAGE_QT_GUI_MODULE
> > +
> > +if BR2_PACKAGE_QT_EMBEDDED
> > +
> >  menu "Pixel depths"
> >  comment "Deselecting each option leads to Qt's default (8,16,32)"
> >  
> > @@ -155,6 +192,8 @@ config BR2_PACKAGE_QT_FONT_UNIFONT
> >  
> >  endmenu
> >  
> > +endif # BR2_PACKAGE_QT_EMBEDDED
> > +
> >  choice
> >  	prompt "freetype2 support"
> >  	default BR2_PACKAGE_QT_NOFREETYPE
> > @@ -163,11 +202,16 @@ choice
> >  
> >  config BR2_PACKAGE_QT_NOFREETYPE
> >  	bool "no freetype2 support"
> > +	depends on BR2_PACKAGE_QT_EMBEDDED
> >  	help
> >  	  Do not compile in Freetype2 support.
> >  
> > +comment "Qt freetype2 needs Qt embedded"
> > +	depends on BR2_PACKAGE_QT_X11
> > +
> >  config BR2_PACKAGE_QT_QTFREETYPE
> >  	bool "Qt freetype2"
> > +	depends on BR2_PACKAGE_QT_EMBEDDED
> >  	help
> >  	  Use the libfreetype bundled with Qt.
> >  
> > @@ -268,9 +312,11 @@ endchoice
> >  
> >  source "package/qt/Config.sql.in"
> >  if BR2_PACKAGE_QT_GUI_MODULE
> > +if BR2_PACKAGE_QT_EMBEDDED
> >  source "package/qt/Config.gfx.in"
> >  source "package/qt/Config.mouse.in"
> >  source "package/qt/Config.keyboard.in"
> > +endif
> >  
> >  config BR2_PACKAGE_QT_PHONON
> >  	bool "Phonon Module"
> > diff --git a/package/qt/qt.mk b/package/qt/qt.mk
> > index 6d01023..0513416 100644
> > --- a/package/qt/qt.mk
> > +++ b/package/qt/qt.mk
> > @@ -236,7 +236,20 @@ else
> >  QT_EMB_PLATFORM = generic
> >  endif
> >  
> > +ifeq ($(BR2_PACKAGE_QT_X11),y)
> > +QT_DEPENDENCIES += fontconfig xlib_libXi xlib_libX11 xlib_libXrender \
> > +                xlib_libXcursor xlib_libXrandr xlib_libXext xlib_libXv
> > +# Using pkg-config avoids us some logic to redefine and sed again mkspecs files
> > +# to add X11 include path and link options
> > +QT_CFLAGS += $(shell $(PKG_CONFIG_HOST_BINARY) --cflags x11)
> > +QT_CXXFLAGS += $(shell $(PKG_CONFIG_HOST_BINARY) --cflags x11)
> > +QT_LDFLAGS += $(shell $(PKG_CONFIG_HOST_BINARY) --libs x11 xext)
> > +QT_CONFIGURE_OPTS += -arch $(QT_EMB_PLATFORM) \
> > +		-xplatform qws/linux-$(QT_EMB_PLATFORM)-g++ -x11 -no-gtkstyle -no-sm \
> > +		-no-openvg
> > +else # if BR2_PACKAGE_QT_EMBEDDED
> >  QT_CONFIGURE_OPTS += -embedded $(QT_EMB_PLATFORM)
> > +endif
> >  
> >  ifneq ($(BR2_PACKAGE_QT_GUI_MODULE),y)
> >  QT_CONFIGURE_OPTS += -no-gui
> > @@ -652,6 +665,7 @@ define QT_INSTALL_TARGET_IMPORTS
> >  endef
> >  
> >  # Fonts installation
> > +ifeq ($(BR2_PACKAGE_QT_EMBEDDED),y)
> >  ifneq ($(QT_FONTS),)
> >  define QT_INSTALL_TARGET_FONTS
> >  	mkdir -p $(TARGET_DIR)/usr/lib/fonts
> > @@ -665,6 +679,7 @@ define QT_INSTALL_TARGET_FONTS_TTF
> >  	cp -dpf $(STAGING_DIR)/usr/lib/fonts/*.ttf $(TARGET_DIR)/usr/lib/fonts
> >  endef
> >  endif
> > +endif # BR2_PACKAGE_QT_EMBEDDED
> >  
> >  ifeq ($(BR2_PACKAGE_QT_GFX_POWERVR),y)
> >  define QT_INSTALL_TARGET_POWERVR
> > -- 
> > 2.0.1
> > 
> > _______________________________________________
> > buildroot mailing list
> > buildroot at busybox.net
> > http://lists.busybox.net/mailman/listinfo/buildroot
> _______________________________________________
> buildroot mailing list
> buildroot at busybox.net
> http://lists.busybox.net/mailman/listinfo/buildroot


More information about the buildroot mailing list