Backport fix for crashes in V4 JIT (#2177696)
This commit is contained in:
		
							parent
							
								
									5c46ca2ce1
								
							
						
					
					
						commit
						d0e90589c4
					
				
							
								
								
									
										44
									
								
								qt-QTBUG-111935-fix-V4-jit.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								qt-QTBUG-111935-fix-V4-jit.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,44 @@ | |||||||
|  | From e2bdde18d9758efdc6a0d7d106aad56995df1271 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Ulf Hermann <ulf.hermann@qt.io> | ||||||
|  | Date: Wed, 15 Mar 2023 08:59:43 +0100 | ||||||
|  | Subject: [PATCH] JIT: Add missing {STORE|LOAD}_ACC() to CreateCallContext | ||||||
|  | 
 | ||||||
|  | We cannot assume anything about the accumulator register after calling | ||||||
|  | PushCallContext::call(). Also add a note about not needing to re-load | ||||||
|  | the accumulator on ThrowException. | ||||||
|  | 
 | ||||||
|  | Pick-to: 6.5 6.2 5.15 | ||||||
|  | Fixes: QTBUG-111935 | ||||||
|  | Change-Id: I7196585e1d2697c215f4fe87d8d7ac9b98b622a3 | ||||||
|  | ---
 | ||||||
|  |  src/qml/jit/qv4baselinejit.cpp | 4 ++++ | ||||||
|  |  1 file changed, 4 insertions(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/src/qml/jit/qv4baselinejit.cpp b/src/qml/jit/qv4baselinejit.cpp
 | ||||||
|  | index 14e183adb8..1d65169dce 100644
 | ||||||
|  | --- a/src/qml/jit/qv4baselinejit.cpp
 | ||||||
|  | +++ b/src/qml/jit/qv4baselinejit.cpp
 | ||||||
|  | @@ -506,6 +506,8 @@ void BaselineJIT::generate_ThrowException()
 | ||||||
|  |      as->passEngineAsArg(0); | ||||||
|  |      BASELINEJIT_GENERATE_RUNTIME_CALL(ThrowException, CallResultDestination::Ignore); | ||||||
|  |      as->gotoCatchException(); | ||||||
|  | +
 | ||||||
|  | +    // LOAD_ACC(); <- not needed here since it would be unreachable.
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  void BaselineJIT::generate_GetException() { as->getException(); } | ||||||
|  | @@ -513,9 +515,11 @@ void BaselineJIT::generate_SetException() { as->setException(); }
 | ||||||
|  |   | ||||||
|  |  void BaselineJIT::generate_CreateCallContext() | ||||||
|  |  { | ||||||
|  | +    STORE_ACC();
 | ||||||
|  |      as->prepareCallWithArgCount(1); | ||||||
|  |      as->passCppFrameAsArg(0); | ||||||
|  |      BASELINEJIT_GENERATE_RUNTIME_CALL(PushCallContext, CallResultDestination::Ignore); | ||||||
|  | +    LOAD_ACC();
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  void BaselineJIT::generate_PushCatchContext(int index, int name) { as->pushCatchContext(index, name); } | ||||||
|  | -- 
 | ||||||
|  | 2.39.2 | ||||||
|  | 
 | ||||||
| @ -16,7 +16,7 @@ | |||||||
| Summary: Qt6 - QtDeclarative component | Summary: Qt6 - QtDeclarative component | ||||||
| Name:    qt6-%{qt_module} | Name:    qt6-%{qt_module} | ||||||
| Version: 6.4.2 | Version: 6.4.2 | ||||||
| Release: 4%{?dist} | Release: 5%{?dist} | ||||||
| 
 | 
 | ||||||
| License: LGPL-3.0-only OR GPL-3.0-only WITH Qt-GPL-exception-1.0 | License: LGPL-3.0-only OR GPL-3.0-only WITH Qt-GPL-exception-1.0 | ||||||
| Url:     http://www.qt.io | Url:     http://www.qt.io | ||||||
| @ -34,6 +34,9 @@ Source0: https://download.qt.io/official_releases/qt/%{majmin}/%{version}/submod | |||||||
| Source5: qv4global_p-multilib.h | Source5: qv4global_p-multilib.h | ||||||
| 
 | 
 | ||||||
| ## upstream patches | ## upstream patches | ||||||
|  | ### From: https://codereview.qt-project.org/c/qt/qtdeclarative/+/466808 | ||||||
|  | ### Cf. https://bugzilla.redhat.com/show_bug.cgi?id=2177696 | ||||||
|  | Patch0: qt-QTBUG-111935-fix-V4-jit.patch | ||||||
| 
 | 
 | ||||||
| ## upstreamable patches | ## upstreamable patches | ||||||
| 
 | 
 | ||||||
| @ -319,6 +322,9 @@ make check -k -C tests ||: | |||||||
| %endif | %endif | ||||||
| 
 | 
 | ||||||
| %changelog | %changelog | ||||||
|  | * Wed Mar 15 2023 Neal Gompa <ngompa@fedoraproject.org> - 6.4.2-5 | ||||||
|  | - Backport fix for crashes in V4 JIT (#2177696) | ||||||
|  | 
 | ||||||
| * Fri Mar 03 2023 Jan Grulich <jgrulich@redhat.com> - 6.4.2-4 | * Fri Mar 03 2023 Jan Grulich <jgrulich@redhat.com> - 6.4.2-4 | ||||||
| - Fix directory ownership | - Fix directory ownership | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user