Commit Graph

8565 Commits

Author SHA1 Message Date
Thiago Macieira 15e4fc5dae Qt3DCore: update AVX2 code to mean x86-64-v3
qsimd_p.h doesn't like when you compile with just -mavx2. I guess no one
is using these flags except me, and I already set the full arch in
CFLAGS.

Qt 6.4 calls x86-64-v3 "arch haswell". Will be fixed in 6.5.

Drive-by remove the AVX512 bits that weren't in use.

Pick-to: 6.4
Change-Id: I76216ced393445a4ae2dfffd172a4f5684351514
Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
Reviewed-by: Mike Krus <mike.krus@kdab.com>
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2023-01-19 19:18:51 -08:00
Qt Submodule Update Bot da01832718 Update dependencies on 'dev' in qt/qt3d
Change-Id: I941a5ee87373bfe81d587dfeff370fbd56fe1a45
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2023-01-17 21:22:59 +00:00
Qt Submodule Update Bot cdab20c5ac Update dependencies on 'dev' in qt/qt3d
Change-Id: I5ad664d011a4b66702cc882ade4e1509fcdc7443
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2023-01-12 21:11:24 +00:00
Inho Lee d6a9ed5039 Fix the input qualifier of the fragment shader for GLSL1.10
FS's input qualifier is different with VS's in GLSL1.10.
If prototypes has 'headerSnippetsFrag', it will be applied for FS
instead of 'headerSnippets'.

Fixes: QTBUG-99019
Pick-to: 6.5 6.4 6.2
Change-Id: I588d3f78d4ba895a9a90b20a87b92a6da9ffee18
Reviewed-by: Janne Koskinen <janne.p.koskinen@qt.io>
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2023-01-10 15:36:44 +01:00
Edward Welbourne 35501c837d Compare size() to unsigned numeric literals
The STL containers used in some types return size_t as their size(),
which gets signed/unsigned comparison warnings. Use unsigned literals
for the constants to compare against.

Change-Id: I91887a1dbd3eb95655c86add2e9f589f0c970def
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2023-01-10 13:01:43 +01:00
Qt Submodule Update Bot 953aa4c426 Update dependencies on 'dev' in qt/qt3d
Change-Id: Idacd832cfbd544fa196153ad3f04032c79df0c80
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2023-01-09 21:26:56 +00:00
Qt Submodule Update Bot 12f4225134 Update dependencies on 'dev' in qt/qt3d
Change-Id: I1decf751c6ea7272c0134509b36da3bac07c7a10
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2023-01-05 02:41:17 +00:00
Qt Submodule Update Bot 404630bca9 Update dependencies on 'dev' in qt/qt3d
Change-Id: I0b45f308031d6143a088066558f241f08fe19011
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2023-01-03 07:13:13 +00:00
Alexey Edelev f17f3e388c Remove QT_USE_SYNCQT_CPP
Option has not effect anymore.

Pick-to: 6.5
Change-Id: Id4c720bf3c64b91bb55d922dba093eb63b4b095c
Reviewed-by: Kai Köhne <kai.koehne@qt.io>
2023-01-02 18:38:38 +01:00
Aurélien Brooke f1c520e5a9 RHI SubmissionContext: remove unused members
Change-Id: I193e646fbc1b33e112bed58059ec536c46064bc9
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-21 17:31:37 +01:00
Aurélien Brooke 0c692e4af3 Assimp importer: ensure loop variable has enough width
loop variable has narrower type 'ushort' (aka 'unsigned short') than
iteration's upper bound 'unsigned int' [bugprone-too-small-loop-
variable]

Change-Id: Id6ab16316f9eb40e47d8494bf70621792284a7b4
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-21 17:31:37 +01:00
Aurélien Brooke 5dd5a6b4b8 Remove unused forward declarations
Change-Id: I008781fa63d253c4f1a7201d911da87f451d797f
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-21 17:31:36 +01:00
Aurélien Brooke c4eb655886 OpenGLVertexArrayObject: fix bugprone erase() call
openglvertexarrayobject.cpp:117:5: this call will remove at most one
item even when multiple items should be removed [bugprone-inaccurate-
erase]

Change-Id: Ife88facc1cad159658c08180548fe365eaeb1714
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-21 17:31:36 +01:00
Aurélien Brooke b291ef7442 Remove qsizetype to int narrowing conversions
Change the variable type from int to qsizetype when receiving qsizetype
values.

Change-Id: I2adf71e1d2f26b1452fee28890c0f68300f54224
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-21 17:31:36 +01:00
Qt Submodule Update Bot 1acc6c9ce4 Update dependencies on 'dev' in qt/qt3d
Change-Id: I7901a744aeceba8ea7037f9c018c954f0e58766b
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-12-21 14:04:13 +00:00
Ville Voutilainen 0f1c949489 Skip tst_raycasting on QNX
Task-number: QTBUG-107694
Change-Id: I4028dc107427c955342903239d4d80674e7109e4
Pick-to: 6.5 6.4
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-19 22:12:50 +02:00
Paul Lemire e2aac33d04 Scene3DItem: fix screen flickering when using OnDemand
When using OnDemand, we detect whether Qt3D actually needs to render or
not. Based on that we set a flag on the Scene3DRenderer to tell it whether
it should render or not.

The subtlety lies in the fact that depending on that flag value, we will
still call Qt3D render but not at the same moment. We need to call render
to unlock the Qt3D render loop for next frame.
Therefore when we should skip a frame, we call render in
Scene3DRender::beforeSynchronize (updatePaintNode) and return early
while in the other case beforeSynchronize doesn't call render and it gets
called later in beforeRenderPassRecording. We know that the render call
in the skip frame case won't render anything.

To work correctly, we must obviously set the skip frame flag before
beforeSynchronize / beforeRenderPassRecording is called which
wasn't the case. This therefore resulted in random screen flashing as we
would end up having beforeSynchronize rely on the skip frame value for the
previous frame. This means we would end up issuing a render call in
beforeSynchronize using assuming it wouldn't render anything when it actually
did (no FBO would be bound and Qt3D would render straight to the window
...)

Also update the number of frames to render before skipping to 3 to match
Qt 5.15 and ensure we have something visible for the first time
Scene3D is launched.

Pick-to: 6.4 6.5
Change-Id: Icc34b62a0af2ff44232b39c694a4702488a890a2
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-19 11:01:51 +01:00
Aurélien Brooke 6b6465032f RHI: fix the leak of QRhiResourceUpdateBatch
There are 2 ways to dispose of a QRhiResourceUpdateBatch obtained with
QRhi::nextResourceUpdateBatch():
1) Either give it to beginPass/endPass/beginComputePass/endComputePass
so it is sent to the RHI backend and then automatically released;
2) or call QRhiResourceUpdateBatch::release() if the resource update
is not used for any pass.

The Qt3D RHI renderer was never disposing of the
QRhiResourceUpdateBatch, and could end up exhausting all the 64 batches
available in the RHI: "Resource update batch pool exhausted (max is
64)", in addition to consuming a lot of RAM if the buffers or textures
are large.

To fix this, ensure the QRhiResourceUpdateBatch'es we allocate are always
released: when requesting a new one, send the previous one to
endPass/endComputePass (1), and when destroying
the SubmissionContext, release the one we will not use (2).

Pick-to: 6.4 6.5
Change-Id: Ic3fb145b11a8e615c83745f560f019e6c4ee37f7
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-19 08:50:22 +01:00
Aurélien Brooke b15f62e323 Fix incorrect usages of std::make_move_iterator
In several places, std::make_move_iterator was used to move from a const
vector, which is not possible and fell back to copy.

Use the existing Qt3DCore::moveAtEnd utility to ensure a move operation
is actually happening.
* When readability permits, pass directly a return value as second
parameter;
* Otherwise, std::move from a mutable vector.

Change-Id: I56c8925bbdeab95257d0a7fa89cffcda53fd6451
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-19 08:50:15 +01:00
Aurélien Brooke 43a7aad707 .clang-format: remove column limit
Qt3D has many long lines.

Change-Id: I9bcbbed0b7bb214028877b370f415e6604800563
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-19 08:50:12 +01:00
Paul Lemire 33ccbe004d Fix scene3d-loader manual test
Pick-to: 6.4 6.5
Change-Id: Ifb42900deb4c9d15cded9d2486fdc8a06fbfe6bf
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-19 06:38:22 +01:00
Paul Lemire ff59b0dc9e Add manual tests to check the use of multiple QQuickWidgets
Pick-to: 6.4 6.5
Change-Id: Ib0a9ccaeb543f91da76e479f23bc59e868fbd2c7
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-19 06:38:19 +01:00
Paul Lemire 675bb0d092 quickwidget-switch: make it work in a single screen setup
Pick-to: 6.4 6.5
Change-Id: I5f17169c106a70c38bcc29cc7758b2bb4b9ee793
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-19 06:38:15 +01:00
Paul Lemire aee00ddfb3 Fix compilation of manual tests
- Disable the examples that use QtMultimedia as they haven't been ported
  to QtMultimedia from Qt6
- QTextureDataUpdate forward header doesn't seem to be generated
- Add QuickWidgets in the find_package call so that we can later check
  if it is actually available

Pick-to: 6.4 6.5
Change-Id: I98d000e839dd0cb0aad862b66bfe8b9725a13744
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-19 06:38:11 +01:00
Paul Lemire df4665a61f qtexturedataupdate.h: fix namespace declaration for syncqt to work
syncqt doesn't find the class name if the namespace line doesn't end
with {.

Pick-to: 6.4 6.5
Change-Id: Icf30464ed0ecb9ce84d6c62c04edfc5d374ed26f
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-19 06:38:06 +01:00
Aurélien Brooke be8b6796c1 LoadSceneJob: don't risk to leak the loaded subtree
There is a risk that the front-end QSceneLoader node has been destroyed
by the time the LoadSceneJob completes. The postFrame() would then do
nothing, and the m_sceneSubtree pointer will be forgotten, leaking the
whole tree. This can happen in real life when loading very large scenes.

To ensure that we cannot leak the scene tree, use strict pointer
ownership with std::unique_ptr.

Pick-to: 6.4 6.5
Change-Id: Ie2281bc178fc8793bab967a13ea8d30aa46268a0
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-17 08:15:03 +01:00
Martin Andersson bffdaabaa5 Handle nullptr returned from the shader manager
Sometimes the shader manager returns a nullptr when fetching the shader from a handle, so the return value needs to be checked before it is accessed.

Pick-to: 6.5 6.4 5.15
Change-Id: Ia021cd8f22ceb2626a7a2734b7e346fbcc8e0301
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-16 09:54:21 +00:00
Jani Heikkinen 2280f17ad2 Bump version to 6.6.0
Change-Id: I2a256de2433578a445f6d6f2e64cfabeec572f31
Reviewed-by: Jani Heikkinen <jani.heikkinen@qt.io>
2022-12-16 06:21:03 +02:00
Qt Submodule Update Bot d9c8c99c97 Update dependencies on 'dev' in qt/qt3d
Change-Id: I068d964d3a498aa568304ef4295dfca01de8686c
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-12-16 04:21:02 +00:00
Marc Mutz 90fb8a94b4 tst_pickboundingvolumejob: fix signed/unsigned mismatch
Amends fd7536a6e4.

Pick-to: 6.5 6.4 6.2
Change-Id: Ib2aed78b798ea163125593319f65b123bcc4f895
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-15 14:21:17 +01:00
Marc Mutz dfcd9f8b5a tst_renderviews: fix signed/unsigned mismatch
Amends f672753556.

Pick-to: 6.5 6.4 6.2
Change-Id: I5c3e99a033cead91a03ab468b4c44b687422baac
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-15 14:21:12 +01:00
Marc Mutz cc81a2f1c2 tst_filtercompatibletechniquejob: fix signed/unsigned mismatch
Amends 9147522576.

Pick-to: 6.5 6.4 6.2
Change-Id: I0320fb3b5e44e10e6ee106bbcb79322323cc3d12
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-12-15 14:21:06 +01:00
Aurélien Brooke 643d7889cc RHI renderer: fix crash in Renderer::sendShaderChangesToFrontend()
The Shaders or the QShaderProgramBuilders may not exist in the managers
anymore by the time we arrive in
Renderer::sendShaderChangesToFrontend(). This happens when Qt3D shuts
down.

To fix this, check the returned values by the managers.

This is similar to the existing patch for the OpenGL renderer:
Ia021cd8f22ceb2626a7a2734b7e346fbcc8e0301

Pick-to: 6.4
Change-Id: I322bf2524016c1f98433891ad230b65272fabbdd
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-15 08:24:18 +01:00
Aurélien Brooke 1fe1c5a375 RHIResourceManagers: fix the leak of RHIShader
The Renderer seems to already take care of deleting the abandoned
shaders thanks to the APIShaderManager::purge() method. However, when
Qt3D is shut down, there remain active RHIShaders in the
RHIShaderManager::m_apiShaders, that nobody deletes.

To fix this, in the RHIResourceManagers, delete the remaining RHIShaders
as we do with the other RHI resources.

Pick-to: 6.4
Change-Id: Iccc5470831eb7df0e120db6864fae425005c6919
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-15 08:24:08 +01:00
Aurélien Brooke 63a9c3e314 Scene3DItem: fix assert when changing window
In Scene3DItem::updatePaintNode(), in the Render thread, we try to set
the parent of the aspect engine being deleted to nullptr. This was
triggering an assert in QCoreApplication::sendEvent(), since the aspect
engine lives in a different thread, the Main thread.

Don't trigger this assert by avoiding to send ChildAdded/ChildRemoved
events when reparenting the aspect manager, thanks to the
QQml_setParent_noEvent utility.

Pick-to: 6.4
Change-Id: Ic816701ee65654f7b18b4998c54feb4840af0a14
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-15 08:23:58 +01:00
Christian Riggenbach 23a0432451 check bounding volumes for validity in concurrent reduction step
The multithreaded job doesn't check the visited bounding volumes for
validity before adding them to the list to process further. This leads
to crashes, namely nullptr-dereferences.

Fixes: QTBUG-108405
Pick-to: 6.4
Change-Id: I16a7c008c7ac4f04be40bdbba05d8c745c1c825e
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-15 08:23:48 +01:00
Aurélien Brooke 56267ef68b Load sceneparser plugins only when processing the first LoadSceneJob
Sceneparser plugins are not loaded anymore until a QSceneLoader is added
to the tree, which improves Qt3D startup time. Note: the load is now
done in the QAspectEngine "Main" thread instead of the QRenderAspect
"Render" thread.

Fixes: QTBUG-59468
Change-Id: I45482ba06acf4dbdf7d4ce2b1a4e06d5a09c6de9
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-15 08:23:13 +01:00
Aurélien Brooke 559b4980c7 Add .clang-format with module-specific rules
Change-Id: Ia3d22f5e00ddc5b249910f6825988d126a0c980f
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-15 08:23:09 +01:00
Mike Krus 4e728a2d32 Disable qresourcemanager test on QEMU
It's flaky ...

Task-number: QTBUG-107693
Change-Id: I67cbb5ef8800f5c29e33ae17241b04b3af0ed067
Pick-to: 6.4
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
2022-12-13 07:41:54 +00:00
Qt Submodule Update Bot 00cf929edb Update dependencies on 'dev' in qt/qt3d
Change-Id: Id06318bfa759e14a16a988b7424660fb2709d873
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-12-12 13:39:41 +00:00
Qt Submodule Update Bot 39c70dee74 Update dependencies on 'dev' in qt/qt3d
Change-Id: Iaa4793e4b7b5ac4c00faa55aa82b97cd3e20a040
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-12-09 03:40:32 +00:00
Liang Qi d270d8639d cmake: make qt3d-vulkan feature depends on vulkan in QtGui
Fixes: QTBUG-109203
Pick-to: 6.4 6.2
Change-Id: Ib707a6d09cf95e9eb819205660bb185fba398705
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
2022-12-07 15:00:43 +01:00
Kai Köhne f3f55a6aa8 Doc: Fix paths for Files property in qt_attribution.json files
qtattributionsscanner expects file paths to be separated by a space.

Pick-to: 6.2 6.4
Change-Id: I983870ea403983f2fc32bf0d986e76235d74e497
Reviewed-by: Jörg Bornemann <joerg.bornemann@qt.io>
2022-12-07 08:42:13 +01:00
Marc Mutz 72df2d5c06 Mark the module free of qAsConst()
Change-Id: I914ccc09297ac6283d7cf24d5afc96ebdaf294d0
Reviewed-by: Fabian Kosmale <fabian.kosmale@qt.io>
2022-12-07 00:55:47 +01:00
Qt Submodule Update Bot dd09311e12 Update dependencies on 'dev' in qt/qt3d
Change-Id: I72a81bf30af86ab2e405fc0092ff48a2a98a6034
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-12-05 23:34:16 +00:00
Aurélien Brooke abbe8ffb21 Fix "Assigning instead of Comparing" in tst_QResourceManager
Fix "Assigning instead of Comparing" in
tst_QResourceManager::heavyDutyMultiThreadedAccess()

Task-number: QTBUG-107693
Pick-to: 6.4
Change-Id: I018bf83dc7a3cc9d6faa654a73b2d460c3e4498a
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-11-30 16:42:01 +01:00
Qt Submodule Update Bot 0bfdee7e20 Update dependencies on 'dev' in qt/qt3d
Change-Id: Idf9bb93e10d4769af0713004862ac6253dffac76
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-11-30 06:13:39 +00:00
Tasuku Suzuki ca499bf7f0 RHI: Fix memory leak in RenderCommand
allocated in Renderer::setBindingAndShaderResourcesForCommand

Pick-to: 6.4
Task-number: QTBUG-106972
Change-Id: I4d0a64f1fbb0e9037b1e4c930f91e1b55412f180
Reviewed-by: Mike Krus <mike.krus@kdab.com>
2022-11-29 10:22:00 +09:00
Qt Submodule Update Bot ddca6eb0e9 Update dependencies on 'dev' in qt/qt3d
Change-Id: I7809594164b38cac034c276c8a19b54c243f5617
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-11-27 02:30:20 +00:00
Qt Submodule Update Bot 305cf790a3 Update dependencies on 'dev' in qt/qt3d
Change-Id: Iac35a536e58f719f6ef76988480f7c8fc58aa5b1
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2022-11-26 04:05:14 +00:00