summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTopi Reinio <topi.reinio@qt.io>2018-11-05 14:44:09 +0100
committerJani Heikkinen <jani.heikkinen@qt.io>2018-11-09 09:29:50 +0000
commit7a69052a182215aa9b2584654d855d7cfbd7478c (patch)
treecbe033aca0239749bc0606b3063e26cc0f4223cb
parent347e135f188e446b6f47fe0a7eb4d0b82d42c8e9 (diff)
downloadqtdoc-7a69052a182215aa9b2584654d855d7cfbd7478c.tar.gz
Doc: Update Qt for QNX Platform Notes
- QNX SDP 7.0 as the primary supported QNX version - Add information for 64-bit architectures - Clarify instructions for fontconfig and QT_QPA_FONTDIR - Link to documentation archives for QNX SDP 6.6 info - Fix linking to QNX documentation, clean up formatting and language Task-number: QTBUG-71308 Task-number: QTBUG-64481 Change-Id: I216128efa35d55aedd3e9725b9984bec995dbdb6 Reviewed-by: Paul Wicking <paul.wicking@qt.io> Reviewed-by: Samuli Piippo <samuli.piippo@qt.io>
-rw-r--r--doc/src/platforms/qnx.qdoc375
1 files changed, 214 insertions, 161 deletions
diff --git a/doc/src/platforms/qnx.qdoc b/doc/src/platforms/qnx.qdoc
index b307ded9..cf8f739d 100644
--- a/doc/src/platforms/qnx.qdoc
+++ b/doc/src/platforms/qnx.qdoc
@@ -34,134 +34,165 @@
\section1 Supported Architectures and QNX Releases
- From the perspective of an application development platform, Qt runs on top of
- \l {http://www.qnx.com/products/neutrino-rtos/neutrino-rtos.html}{QNX Neutrino RTOS}.
- System integrators and application developers use a QNX SDP (Software Development Platform)
- which includes QNX Neutrino RTOS components for various targets and a full set of development
- tools. \l {http://www.qnx.com/}{QNX Software Systems} also provides additional packages which
- enrich the standard feature set of QNX Neutrino RTOS. Currently, those packages are:
+ From the perspective of an application development platform, Qt runs on
+ top of \l {http://www.qnx.com/products/neutrino-rtos/neutrino-rtos.html}
+ {QNX Neutrino RTOS}. System integrators and application developers use a
+ QNX SDP (Software Development Platform) which includes QNX Neutrino RTOS
+ components for various targets and a full set of development tools.
+
+ Qt 5 is currently tested and supported on QNX SDP 7.0, with support for
+ both 32-bit and 64-bit target architectures:
\list
- \li \l {http://www.qnx.com/download/group.html?programid=26072}{QNX SDK for Apps and Media 1.0}.
- \li \l {http://www.qnx.com/download/group.html?programid=26076}{QNX CAR Platform 2.1}.
+ \li \c ARMle-v7 and \c x86 (32-bit)
+ \li \c AArch64le and \c x86-64 (64-bit)
\endlist
- Qt 5 is currently tested and supported on QNX SDP 6.6 with QNX SDK for
- Apps and Media, see the section \l {Build Requirements} for more details. Supported
- architectures are ARMle-v7 and x86. Older QNX SDP releases and other architectures may also
- work, but are not subject to regular builds and testing.
+ Support for 64-bit architectures was added in QNX SDP 7.0.
+
+ \section2 Previous Releases
+
+ Older QNX SDP releases and other architectures may also work, but are not
+ subject to regular builds and testing.
- For a specific list of available boards, displays and input devices, contact QNX Software
- Systems (info@qnx.com) or KDAB (qnx-info@kdab.com). Qt on the QNX Neutrino OS is also supported
- by Qt Enterprise Embedded, \l {http://www.qt.io/contact-us/}{contact The Qt Company}
- for more details.
+ \list
+ \li \l {https://doc.qt.io/archives/qt-5.10/platform-notes-qnx.html}
+ {Qt for QNX SDP 6.6}
+ \endlist
+
+
+ For a specific list of available boards, displays and input devices, contact
+ QNX Software Systems (\l {mailto://info@qnx.com}{info@qnx.com}) or KDAB
+ (\l {mailto://qnx-info@kdab.com}{qnx-info@kdab.com}). Qt on the QNX Neutrino
+ OS is also supported by \l {Qt for Device Creation},
+ \l {https://www.qt.io/contact-us/}{contact The Qt Company} for more details.
\section1 Supported Modules
- Almost all Qt Essential \l{All Modules}{modules} and some add-ons are supported on
- the QNX Neutrino RTOS. See the \l{http://wiki.qt.io/Qt_Status_on_QNX}
- {status page on the Qt Project wiki} for details.
+ Almost all Qt Essential \l{All Modules}{modules} and some add-ons are
+ supported on the QNX Neutrino RTOS. See the
+ \l{http://wiki.qt.io/Qt_Status_on_QNX}{status page on the Qt Project wiki}
+ for details.
- If you build Qt from a released source code distribution archive, the \c{configure} tool ensures
- that the build will be made only for modules which are known to build for the target specified.
- Additionally, you can explicitly exclude unsupported or not needed modules from the build via the
+ If you build Qt from a released source code distribution archive, the
+ \c{configure} tool ensures that the build will be made only for modules
+ which are known to build for the target specified. Additionally, you can
+ explicitly exclude unsupported or not needed modules from the build via the
\c{-skip <module>} option when running the \c{configure} tool.
- If you build Qt directly from the Git repository, you should initialize the repository only with
- modules which are supported or build and install modules separately. This helps to prevent
- unexpected build problems.
+ If you build Qt directly from the Git repository, you should initialize
+ the repository only with modules which are supported or build and install
+ modules separately. This helps to prevent unexpected build problems.
\section1 Build Requirements
- Building Qt 5 requires the following packages available from the \l {http://www.qnx.com/}{QNX website}
- (an access requires registration):
+ Building Qt 5 requires the following packages available from the
+ \l {http://www.qnx.com/}{QNX website} (registration required for access
+ to downloads):
\list
- \li \l {http://www.qnx.com/download/group.html?programid=26071}{SDP 6.6} with
- \l{http://www.qnx.com/download/group.html?programid=26072}{QNX SDK for Apps and Media 1.0}. This
- combination forms the current reference platform for Qt on QNX Neutrino RTOS and should be your
- first choice.
- \li \l {http://www.qnx.com/download/group.html?programid=26071}{SDP 6.6}. Compared to the
- previous configuration, this choice does not not use
- \l{http://www.qnx.com/download/group.html?programid=26072}{QNX SDK for Apps and Media 1.0} which provides
- \c{fontconfig} and multimedia support along with other features. In this case, Qt will use the
- internal font database instead of \c{fontconfig}, and \l{Multimedia}{multimedia} will be not functional.
+ \li \l {http://blackberry.qnx.com/en/sdp7/sdp70_download}{QNX SDP 7.0}
+ with \l {http://www.qnx.com/download/group.html?programid=26808}
\endlist
- The compiler and other parts of the tool chain are provided in the SDP packages. You do not need
- any additional installations on your host PC. Still, it is advisable to ensure that you can build
- Qt on the host for the desktop target as well. See \l {Building Qt Sources} for more details.
- All supported QNX Neutrino RTOS targets are fully integrated in the makespecs provided in the Qt
- sources. You just need to specify the target name for cross-compilation when configuring a Qt build:
-
- For ARM:
-
- \code
- ./configure -xplatform qnx-armle-v7-qcc
- \endcode
-
- For x86:
-
- \code
- ./configure -xplatform qnx-x86-qcc
- \endcode
+ The compiler and other parts of the tool chain are provided in the SDP
+ packages. You do not need any additional installations on your host PC.
+ However, it is advisable to ensure that you can build Qt for the desktop
+ target on the host as well. See \l {Building Qt Sources} for more details.
+ All supported QNX Neutrino RTOS targets are fully integrated in the
+ makespecs provided in the Qt sources.
+
+ You need to specify the target name for cross-compilation when configuring
+ a Qt build:
+
+ \table
+ \header \li Architecture
+ \li Configure cross-compilation target
+ \row \li \c ARMle-v7 (32-bit)
+ \li \badcode
+ ./configure -xplatform qnx-armle-v7-qcc
+ \endcode
+ \row \li \c AArch64le (64-bit)
+ \li \badcode
+ ./configure -xplatform qnx-aarch64le-qcc
+ \endcode
+ \row \li \c x86 (32-bit)
+ \li \badcode
+ ./configure -xplatform qnx-x86-qcc
+ \endcode
+ \row \li \c x86-64 (64-bit)
+ \li \badcode
+ ./configure -xplatform qnx-x86-64-qcc
+ \endcode
+ \endtable
+
+ The \c{configure} tool runs various tests to detect capabilities of the
+ SDP and its add-ons. It sets related flags according the test results.
+ Check the configure summary on the console or in \c{./qtbase/config.summary}
+ if needed and set other flags manually as required.
+
+ Independent of the platform you are building for, consider using the
+ \c{-prefix} option with \c{configure} as well, for example,
+ \c{-prefix<Qt-install-path>}. This specifies the target folder where
+ Qt will be installed and places all build artifacts outside of the
+ source code tree.
- The \c{configure} tool runs various tests to detect capabilities of the SDP and its add-ons.
- It sets related flags according the test results. Check the configure summary on the
- console or in \c{./qtbase/config.summary} if needed and set other flags manually as required.
See \l{Qt Configure Options} for more details.
- Independent of the platform you are building for, consider using the \c{-prefix}
- option with \c{configure} as well, for example, \c{-prefix <Qt-install-path>}. This specifies the
- target folder where Qt will be installed and places all build artifacts outside of the
- source code tree.
-
\section1 Qt Runtime Target Requirements
- QNX Software Systems delivers software solutions for making embedded devices. This includes
- creation of QNX Neutrino RTOS boot images in a very flexible way. Even though QNX provides
- several reference scripts for the OS image creation, sooner or later you will need to make
- changes or you might decide to create an OS image from scratch. Qt relies on the existence of
- several third-party components and selected OS services. Due to this, QNX Neutrino RTOS
- boot images for a target device running Qt must meet a couple of requirements to ensure
- that Qt works as expected. The sections below list the crucial parts for Qt.
+ QNX Software Systems delivers software solutions for making embedded
+ devices. This includes creation of QNX Neutrino RTOS boot images in a very
+ flexible way. Even though QNX provides several reference scripts for the OS
+ image creation, sooner or later you will need to make changes or you might
+ decide to create an OS image from scratch. Qt relies on the existence of
+ several third-party components and selected OS services. Due to this, QNX
+ Neutrino RTOS boot images for a target device running Qt must meet a couple
+ of requirements to ensure that Qt works as expected. The sections below list
+ the crucial parts for Qt.
\section2 QNX Screen Graphics Subsystem
- Before any Qt application can be started, the \l {http://www.qnx.com/developers/docs/660/topic/com.qnx.doc.screen/topic/manual/cscreen_about.html}{QNX Screen Graphics Subsystem} (also called just "Screen") must be running.
- The Screen consists not only of a driver, but also includes several utilities and other services
- which are used by Qt. This includes processing of mouse and keyboard events as well. You can
- ensure that the Screen is configured and running correctly by verifying that a graphics application,
- like \c gles2-gears, can be started and runs without problems. Most of the recent sample OS build
- scripts in the SDP include sections with all components and start commands for the Screen.
- Use them as a reference.
+ Before any Qt application can be started, the
+ \l {http://www.qnx.com/developers/docs/7.0.0/#com.qnx.doc.screen/topic/manual/cscreen_about.html}
+ {QNX Screen Graphics Subsystem} (also called just "Screen") must be
+ running. The Screen consists not only of a driver, but also includes
+ several utilities and other services which are used by Qt. This includes
+ processing of mouse and keyboard events as well. You can ensure that the
+ Screen is configured and running correctly by verifying that a graphics
+ application, like \c gles2-gears, can be started and runs without problems.
+ Most of the recent sample OS build scripts in the SDP include sections with
+ all components and start commands for the Screen. Use them as a reference.
\section2 IPv6 Support
- \l {Qt Network}{Qt's networking stack} requires IPv6 support to be enabled, independent of
- whether the actual networking uses IPv4 or IPv6. That means, that \c{io-pkt-v6-hc} must be
- running, \e {not} \c{io-pkt-v4}.
+ \l {Qt Network}{Qt's networking stack} requires IPv6 support to be
+ enabled, independent of whether the actual networking uses IPv4 or IPv6.
+ That means, that \c{io-pkt-v6-hc} must be running, \e {not} \c{io-pkt-v4}.
- \section2 Random device \c{/dev/random}
+ \section2 Random Device \c{/dev/random}
- Qt requires \c{/dev/random} to be present and functional. Start it before starting any Qt
- application or during the system startup:
+ Qt requires \c{/dev/random} to be present and functional. Start it
+ before starting any Qt application or during the system startup:
- \code
+ \badcode
random -p
waitfor /dev/random
\endcode
\section2 System Logger
- QNX provides the \l {http://www.qnx.com/developers/docs/660/topic/com.qnx.doc.neutrino.utilities/topic/s/slogger2.html}{slog2}
- logging framework tailored to specifics of embedded systems. The major advantage of it is
- a much better performance than a text output to files. Qt uses this framework by default for
- any logging output going through QDebug on QNX Neutrino RTOS. The \c{slog2} service should
- be started during the system startup. The \c{slog2} also relies on the existence of the
- \c{/tmp} folder which has to be configured as well, for example:
-
- \code
+ QNX provides the
+ \l {http://www.qnx.com/developers/docs/7.0.0/#com.qnx.doc.neutrino.utilities/topic/s/slogger2.html}
+ {slog2} logging framework tailored to specifics of embedded systems. The
+ major advantage of it is a much better performance than a text output to
+ files. Qt uses this framework by default for any logging output going
+ through QDebug on QNX Neutrino RTOS. The \c{slog2} service should be
+ started during the system startup. The \c{slog2} also relies on the
+ existence of the \c{/tmp} folder which has to be configured as well, for
+ example:
+
+ \badcode
[type=link] /tmp=/dev/shmem
display_msg "Starting slogger2..."
slogger2 -U1001:1000 &
@@ -170,71 +201,80 @@
\section2 Environment Variables
- There is a set of environment variables you should set when starting a Qt application. Most
- of them are actually not specific to QNX Neutrino RTOS. They are still mentioned here, since
- knowing them just saves a lot of time in case of problems.
+ There is a set of environment variables you should set when starting a Qt
+ application. Most of them are actually not specific to QNX Neutrino RTOS.
+ They are still mentioned here, since knowing them just saves a lot of
+ time in case of problems.
\section3 Qt Runtime Location
- If you did not build Qt with RPATH enabled, you can place the Qt runtime components in any
- folder in the file system. The following environment variables should point to valid locations
- assuming that the Qt installation is located in \c{<Qt-install-path>}:
+ If you did not build Qt with RPATH enabled, you can place the Qt runtime
+ components in any folder in the file system. The following environment
+ variables should point to valid locations assuming that the Qt installation
+ is located in \c{<Qt-install-path>}:
\list
\li \c{LD_LIBRARY_PATH} should contain the path to the Qt libraries
- in \c{<Qt-install-path>/lib}
- \li \c{QT_PLUGIN_PATH} defines where the Qt plug-ins are located. It should be set
- to \c{<Qt-install-path>/plugins}
- \li \c{QML2_IMPORT_PATH} defines where the Qt Quick 2 plug-ins are located. It should be set
- to \c{<Qt-install-path>/qml}
- \li \c{QML_IMPORT_PATH} is required only when using the Qt Quick 1 compatibility module.
- It should be set to \c{<Qt-install-path>/imports}
- \li If Qt does not use fontconfig, you have to specify the path to the fonts provided in
- Qt and set \c{QT_QPA_FONTDIR} to \c{<Qt-install-path>/lib/fonts}
+ in \c{<Qt-install-path>/lib}
+ \li \c{QT_PLUGIN_PATH} defines where the Qt plug-ins are located.
+ It should be set to \c{<Qt-install-path>/plugins}
+ \li \c{QML2_IMPORT_PATH} defines where the Qt Quick plug-ins are
+ located. It should be set to \c{<Qt-install-path>/qml}
+ \li If Qt does not use fontconfig, you must either provide the path
+ to the fonts with \c{QT_QPA_FONTDIR}, or place the fonts under
+ \c{<Qt-install-path>/lib/fonts} which is the default font
+ location.
\endlist
\section3 Physical Screen Size
- Qt needs information about the physical dimensions of the attached display to determine DPI
- values and thus set correct font sizes. Usually, this information is provided by the Screen.
- In some cases you may see an invalid screen size such as 0mmx0mm.
- In such a case Qt requires an environment variable \c QQNX_PHYSICAL_SCREEN_SIZE set to
- according values to get the required information. If Qt applications exit with an error
- message saying that the physical screen size couldn't be determined, set the variable like
- this before starting the Qt application:
+ Qt needs information about the physical dimensions of the attached
+ display to determine DPI values and thus set correct font sizes. Usually,
+ this information is provided by the Screen. In some cases you may see an
+ invalid screen size such as 0mmx0mm. In such a case Qt requires an
+ environment variable \c QQNX_PHYSICAL_SCREEN_SIZE set to according values to
+ get the required information. If Qt applications exit with an error message
+ saying that the physical screen size couldn't be determined, set the
+ variable like this before starting the Qt application:
- \code
+ \badcode
export QQNX_PHYSICAL_SCREEN_SIZE=150,100
\endcode
- to inform Qt that the screen has a width of 150mm and a height of 100mm in this particular
- case. The physical screen size is measured in millimeters (mm) and should correspond the
- actual physical size of the display in the final configuration.
+ to inform Qt that the screen has a width of 150mm and a height of 100mm
+ in this particular case. The physical screen size is measured in millimeters
+ (mm) and should correspond to the actual physical size of the display in the
+ final configuration.
\section3 Troubleshooting the First Start of a Qt Application
- The only drawback of the large flexibility provided by QNX Neutrino RTOS is a risk that
- something is still different on your target than it is expect to be by Qt. This is a very
- common reason why the first Qt application on a new target fails to start. A few generic
- environment variables can help finding the root cause for problems:
+ The only drawback of the flexibility provided by QNX Neutrino RTOS
+ is a risk that the run environment is slightly different on your target
+ than what is expected by Qt. This is a common reason why a Qt application
+ on a new target fails to start. A few generic environment variables can
+ help locate the root cause for problems:
\list
- \li Setting \c{QT_DEBUG_PLUGINS} to \c{1} helps to see why the QPA plug-in cannot load.
- \li Setting \c{LD_DEBUG} to \c{1} helps to see where and how shared libraries are loaded.
- This can be used in combination with \c{QT_DEBUG_PLUGINS} when a plug-in cannot be
- loaded because it cannot load some other shared libraries.
- \li Setting \c{QT_LOGGING_TO_CONSOLE} will force sending all logging message to
- \c{stderr} instead of \c{slog2}. This is very handy to analyze application startup
- problems, since you do not need to use another tool to see the messages.
+ \li Setting \c{QT_DEBUG_PLUGINS} to \c{1} helps to see why the QPA
+ plugin cannot load.
+ \li Setting \c{LD_DEBUG} to \c{1} helps to see where and how shared
+ libraries are loaded. This can be used in combination with
+ \c{QT_DEBUG_PLUGINS} when a plugin failed to load because it
+ could not load other shared libraries.
+ \li Setting \c{QT_LOGGING_TO_CONSOLE} will force sending all logging
+ messages to \c{stderr} instead of \c{slog2}. This is useful for
+ analyzing application startup problems, as you do not need to use
+ another tool to see the messages.
\endlist
\section2 Third Party Libraries
- Make sure that your system image contains the following additional 3rd-party libraries
- which are not always included in minimal QNX Neutrino RTOS images:
+ Make sure that your system image contains the following additional
+ 3rd-party libraries which are not always included in minimal QNX Neutrino
+ RTOS images:
\list
- \li \c libfontconfig (provided in addition to a standard SDP 6.6 installation)
+ \li \c libfontconfig
\li \c libfreetype
\li \c libiconv
\li \c libicui18n
@@ -247,38 +287,47 @@
\li \c libcrypto
\endlist
- Please note that the above list is not a full list of shared libraries used by Qt on QNX Neutrino OS. Quite some shared libraries are already available in typical OS images or included by other parts of the system, e.g. by the Screen.
+ \note This is not a complete list of shared libraries used by Qt on QNX
+ Neutrino OS. Multiple shared libraries are already available in a
+ typical OS image, or included by other parts of the system, for
+ example, the \c Screen.
\section2 Accessing Environment Variables
- \c setconf and \c getconf are required to access POSIX environment variables, especially for
- the host name and time and date.
+ \c setconf and \c getconf are required to access POSIX environment
+ variables, especially for the host name and time and date.
\section1 Qt Creator Target Requirements
- A QNX Neutrino RTOS target used for development with Qt Creator should provide a few additional
- command line tools and services.
+ A QNX Neutrino RTOS target used for development with Qt Creator should
+ provide a few additional command line tools and services.
\section2 SSH
- Deployment and remote application startup relies on SSH. The SSH daemon (\c{sshd}) must
- be installed and running during the system startup. Please note that it requires
- \c{/dev/random} which was already mentioned. It also expects specific access rights to
- be set correctly to its configuration files. The latter makes it impossible starting SSH
- from a file system which does not have full access rights support, for example, FAT.
+ Deployment and remote application startup relies on SSH. The SSH daemon
+ (\c{sshd}) must be installed and running during the system startup. Please
+ note that it requires \c{/dev/random} which was already mentioned. It also
+ expects specific access rights to be set correctly to its configuration
+ files. The latter makes it impossible starting SSH from a file system which
+ does not have full access rights support, for example, FAT.
\section2 SCP and SFTP
- \c{scp} and \c{sftp} utilities are used by Qt Creator for deployment and should be
- available on the target. Additionally, \c{inetd} daemon has to be started at the system
- startup which then launches according services, including FTP when needed.
+ \c{scp} and \c{sftp} utilities are used by Qt Creator for deployment and
+ should be available on the target. Additionally, \c{inetd} daemon has to be
+ started at the system startup which then launches according services,
+ including FTP when needed.
\section2 QNX Tools for Remote Debugging
- Remote debugging requires the \c{pdebug} (\l{http://www.qnx.com/developers/docs/660/topic/com.qnx.doc.ide.userguide/topic/debug_Base_.html}{process-level debugger}) to be running on the development device. It is usually
- started by the \c{qconn} process which also provides various process information to
- Qt Creator. Generally, Qt Creator uses the same remote debugging interfaces as the QNX
- Momentics IDE provided in the SDP. See the according \l{http://www.qnx.com/developers/docs/660/topic/com.qnx.doc.ide.userguide/topic/debug_test_debug.html}{documentation} for more details.
+ Remote debugging requires the \c{pdebug}
+ (\l {http://www.qnx.com/developers/docs/7.0.0/#com.qnx.doc.neutrino.prog/topic/devel_pdebug.html}
+ {process-level debugger}) to be running on the development device. It is
+ usually started by the \c{qconn} process which also provides various process
+ information to Qt Creator. Generally, Qt Creator uses the same remote
+ debugging interfaces as the QNX Momentics IDE provided in the SDP. See the
+ related \l {http://www.qnx.com/developers/docs/7.0.0/#com.qnx.doc.ide.userguide/topic/debugging.html}
+ {QNX documentation} for more details.
\section2 Other Utilities on the Target Device
@@ -311,11 +360,11 @@
The utilities need to be in a standard location, such as \c /bin or
\c /usr/bin. Alternatively, you can use the \c {~/.ssh/environment} file
- to set variables for remote commands, such as \c PATH. In addition, you must
- set \c{enable PermitUserEnvironment} in the SSH Daemon configuration.
+ to set variables for remote commands, such as \c PATH. In addition, you
+ must set \c{enable PermitUserEnvironment} in the SSH Daemon configuration.
- Run the test when you configure a new target device in Qt Creator to verify that all
- required components are available and running.
+ Run the test when you configure a new target device in Qt Creator to verify
+ that all required components are available and running.
For more information about modifying or developing a BSP for you board, see
\l{http://www.qnx.com/developers/docs/7.0.0/index.html#com.qnx.doc.neutrino.custom_bsp/topic/about.html}
@@ -323,14 +372,18 @@
\section2 Deployment Destination Folder
- Qt Creator deploys an application to the target device before starting it remotely.
- On most embedded devices, it is just copying application binaries and related data
- files to a folder on the target device. The challenge herewith is that there is no standard
- so far how this folder is called and where it is located. Quite a few configurations use
- \c{/tmp} for this, which is often mapped to a RAM disk. This case causes a lot of confusion
- since deployed applications disappear on the next device shutdown. Another popular target is
- \c{/opt}. This folder is located in a read-only partition on many systems making deployment
- impossible. Make sure that you use a destination folder which meets your needs. You can
- set it in the \c{install.path} variable in the \c{.pro} file of your project, see
- \l{Installing Files} in the \l {QMake} documentation for more details.
+ Qt Creator deploys an application to the target device before starting
+ it remotely. On most embedded devices, it is just copying application
+ binaries and related data files to a folder on the target device. However,
+ there is no standard for how this folder is called and where it is located.
+ Quite a few configurations use \c{/tmp} for this, which is often mapped to
+ a RAM disk. This can cause some confusion as deployed applications
+ disappear on the next device shutdown.
+
+ Another popular target is \c{/opt}. This folder is located in a read-only
+ partition on many systems, making deployment impossible. Make sure that you
+ use a destination folder which meets your needs. You can set it in the
+ \c{install.path} variable in the \c{.pro} file of your project, see
+ \l [QMake] {Installing Files} in the \l {qmake} documentation for more
+ details.
*/