Compare commits
	
		
			No commits in common. "c9s" and "c8" have entirely different histories.
		
	
	
		
	
		
							
								
								
									
										15
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1,12 +1,3 @@ | ||||
| *.jx | ||||
| *.src.rpm | ||||
| .build* | ||||
| /mesa-*.tar.bz2 | ||||
| /mesa-*.tar.xz | ||||
| x86_64/ | ||||
| results_mesa/ | ||||
| mesa-*/ | ||||
| /libclc-*.tar.xz | ||||
| /meson-*.tar.gz | ||||
| /spirv-llvm-translator-*.tar.gz | ||||
| /wayland-protocols-*.tar.xz | ||||
| SOURCES/dataclasses-0.8.tar.gz | ||||
| SOURCES/mesa-23.1.4.tar.xz | ||||
| SOURCES/meson-0.61.4.tar.gz | ||||
|  | ||||
							
								
								
									
										3
									
								
								.mesa.metadata
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.mesa.metadata
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| ef25d3e9e2523805baa314a4adcb915ae901740e SOURCES/dataclasses-0.8.tar.gz | ||||
| 8a48c0e1fbda2c9563ddcf95b05012ab00a8a692 SOURCES/mesa-23.1.4.tar.xz | ||||
| b0ab169abd8ec87ce773a02b2c7d6a8664b8db00 SOURCES/meson-0.61.4.tar.gz | ||||
| @ -1,111 +0,0 @@ | ||||
| From 0166a0fb86dc6c0e8903436bbc3a89bc3273ebc0 Mon Sep 17 00:00:00 2001 | ||||
| From: Viktoria Maximova <viktoria.maksimova@intel.com> | ||||
| Date: Wed, 13 Dec 2023 16:46:33 +0100 | ||||
| Subject: [PATCH] Update LongConstantCompositeINTEL to LongCompositesINTEL | ||||
|  capability after Headers change (#2258) | ||||
| 
 | ||||
| * Bump SPIRV-Headers to 1c6bb2743599e6eb6f37b2969acc0aef812e32e3 | ||||
| * replace internal SPV_INTEL_long_composites ext with the published SPV_INTEL_long_composites | ||||
| * don't rename extension for now | ||||
| This closes: https://github.com/KhronosGroup/SPIRV-LLVM-Translator/issues/2261 | ||||
| 
 | ||||
| Co-authored-by: Wlodarczyk, Bertrand <bertrand.wlodarczyk@intel.com> | ||||
| ---
 | ||||
|  include/LLVMSPIRVExtensions.inc                 | 3 ++- | ||||
|  lib/SPIRV/libSPIRV/SPIRVEntry.h                 | 2 +- | ||||
|  lib/SPIRV/libSPIRV/SPIRVNameMapEnum.h           | 2 +- | ||||
|  spirv-headers-tag.conf                          | 2 +- | ||||
|  test/SpecConstants/long-spec-const-composite.ll | 2 +- | ||||
|  test/long-constant-array.ll                     | 2 +- | ||||
|  test/long-type-struct.ll                        | 2 +- | ||||
|  7 files changed, 8 insertions(+), 7 deletions(-) | ||||
| 
 | ||||
| diff --git a/include/LLVMSPIRVExtensions.inc b/include/LLVMSPIRVExtensions.inc
 | ||||
| index 8ff15399..780faec5 100644
 | ||||
| --- a/include/LLVMSPIRVExtensions.inc
 | ||||
| +++ b/include/LLVMSPIRVExtensions.inc
 | ||||
| @@ -43,7 +43,8 @@ EXT(SPV_INTEL_variable_length_array)
 | ||||
|  EXT(SPV_INTEL_fp_fast_math_mode) | ||||
|  EXT(SPV_INTEL_fpga_cluster_attributes) | ||||
|  EXT(SPV_INTEL_loop_fuse) | ||||
| -EXT(SPV_INTEL_long_constant_composite)
 | ||||
| +EXT(SPV_INTEL_long_constant_composite) // TODO: rename to
 | ||||
| +                                       // SPV_INTEL_long_composites later
 | ||||
|  EXT(SPV_INTEL_optnone) | ||||
|  EXT(SPV_INTEL_fpga_dsp_control) | ||||
|  EXT(SPV_INTEL_memory_access_aliasing) | ||||
| diff --git a/lib/SPIRV/libSPIRV/SPIRVEntry.h b/lib/SPIRV/libSPIRV/SPIRVEntry.h
 | ||||
| index e5475a2b..5131a2a1 100644
 | ||||
| --- a/lib/SPIRV/libSPIRV/SPIRVEntry.h
 | ||||
| +++ b/lib/SPIRV/libSPIRV/SPIRVEntry.h
 | ||||
| @@ -908,7 +908,7 @@ public:
 | ||||
|    } | ||||
|   | ||||
|    SPIRVCapVec getRequiredCapability() const override { | ||||
| -    return getVec(CapabilityLongConstantCompositeINTEL);
 | ||||
| +    return getVec(CapabilityLongCompositesINTEL);
 | ||||
|    } | ||||
|   | ||||
|    std::optional<ExtensionID> getRequiredExtension() const override { | ||||
| diff --git a/lib/SPIRV/libSPIRV/SPIRVNameMapEnum.h b/lib/SPIRV/libSPIRV/SPIRVNameMapEnum.h
 | ||||
| index 6d44142d..ae2aa395 100644
 | ||||
| --- a/lib/SPIRV/libSPIRV/SPIRVNameMapEnum.h
 | ||||
| +++ b/lib/SPIRV/libSPIRV/SPIRVNameMapEnum.h
 | ||||
| @@ -618,7 +618,7 @@ template <> inline void SPIRVMap<Capability, std::string>::init() {
 | ||||
|    add(CapabilityGroupNonUniformRotateKHR, "GroupNonUniformRotateKHR"); | ||||
|    add(CapabilityAtomicFloat32AddEXT, "AtomicFloat32AddEXT"); | ||||
|    add(CapabilityAtomicFloat64AddEXT, "AtomicFloat64AddEXT"); | ||||
| -  add(CapabilityLongConstantCompositeINTEL, "LongConstantCompositeINTEL");
 | ||||
| +  add(CapabilityLongCompositesINTEL, "LongCompositesINTEL");
 | ||||
|    add(CapabilityOptNoneINTEL, "OptNoneINTEL"); | ||||
|    add(CapabilityAtomicFloat16AddEXT, "AtomicFloat16AddEXT"); | ||||
|    add(CapabilityDebugInfoModuleINTEL, "DebugInfoModuleINTEL"); | ||||
| diff --git a/spirv-headers-tag.conf b/spirv-headers-tag.conf
 | ||||
| index 37d2a266..7fae55f3 100644
 | ||||
| --- a/spirv-headers-tag.conf
 | ||||
| +++ b/spirv-headers-tag.conf
 | ||||
| @@ -1 +1 @@
 | ||||
| -9b527c0fb60124936d0906d44803bec51a0200fb
 | ||||
| +1c6bb2743599e6eb6f37b2969acc0aef812e32e3
 | ||||
| diff --git a/test/SpecConstants/long-spec-const-composite.ll b/test/SpecConstants/long-spec-const-composite.ll
 | ||||
| index 2b52b0cb..6aaf62c2 100644
 | ||||
| --- a/test/SpecConstants/long-spec-const-composite.ll
 | ||||
| +++ b/test/SpecConstants/long-spec-const-composite.ll
 | ||||
| @@ -11,7 +11,7 @@
 | ||||
|  target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024-n8:16:32:64" | ||||
|  target triple = "spir64-unknown-unknown" | ||||
|   | ||||
| -; CHECK-SPIRV: Capability LongConstantCompositeINTEL 
 | ||||
| +; CHECK-SPIRV: Capability LongCompositesINTEL
 | ||||
|  ; CHECK-SPIRV: Extension "SPV_INTEL_long_constant_composite" | ||||
|  ; CHECK-SPIRV-DAG: Decorate [[First:[0-9]+]] SpecId  0 | ||||
|  ; CHECK-SPIRV-DAG: Decorate [[Last:[0-9]+]] SpecId 65548 | ||||
| diff --git a/test/long-constant-array.ll b/test/long-constant-array.ll
 | ||||
| index 03b33771..d0b4c3b3 100644
 | ||||
| --- a/test/long-constant-array.ll
 | ||||
| +++ b/test/long-constant-array.ll
 | ||||
| @@ -9,7 +9,7 @@
 | ||||
|  ; TODO: run validator once it supports the extension | ||||
|  ; RUNx: spirv-val %t.spv | ||||
|   | ||||
| -; CHECK-SPIRV: Capability LongConstantCompositeINTEL 
 | ||||
| +; CHECK-SPIRV: Capability LongCompositesINTEL
 | ||||
|  ; CHECK-SPIRV: Extension "SPV_INTEL_long_constant_composite" | ||||
|  ; CHECK-SPIRV: TypeInt [[TInt:[0-9]+]] 8 | ||||
|  ; CHECK-SPIRV: Constant {{[0-9]+}} [[ArrSize:[0-9]+]] 78000 | ||||
| diff --git a/test/long-type-struct.ll b/test/long-type-struct.ll
 | ||||
| index 97766706..90c3a3f7 100644
 | ||||
| --- a/test/long-type-struct.ll
 | ||||
| +++ b/test/long-type-struct.ll
 | ||||
| @@ -10,7 +10,7 @@
 | ||||
|   | ||||
|  ; RUN: not llvm-spirv %t.bc -o %t.spv 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR | ||||
|   | ||||
| -; CHECK-SPIRV: Capability LongConstantCompositeINTEL 
 | ||||
| +; CHECK-SPIRV: Capability LongCompositesINTEL
 | ||||
|  ; CHECK-SPIRV: Extension "SPV_INTEL_long_constant_composite" | ||||
|  ; CHECK-SPIRV: TypeInt [[TInt:[0-9]+]] 8 | ||||
|  ; CHECK-SPIRV: TypePointer [[TIntPtr:[0-9]+]] 8 [[TInt]] | ||||
| -- 
 | ||||
| 2.45.2 | ||||
| 
 | ||||
							
								
								
									
										127
									
								
								SOURCES/0001-clover-llvm-move-to-modern-pass-manager.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								SOURCES/0001-clover-llvm-move-to-modern-pass-manager.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,127 @@ | ||||
| From 2d4fe5f229791fde52846b3f583c12508b5109d6 Mon Sep 17 00:00:00 2001 | ||||
| From: Dave Airlie <airlied@redhat.com> | ||||
| Date: Fri, 25 Aug 2023 12:43:44 +1000 | ||||
| Subject: [PATCH] clover/llvm: move to modern pass manager. | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
| 
 | ||||
| This seems like it should work, but I haven't tested it yet. | ||||
| 
 | ||||
| Tested-by: Dieter Nützel <Dieter@nuetzel-hh.de> | ||||
| Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/24879> | ||||
| ---
 | ||||
|  .../frontends/clover/llvm/invocation.cpp      | 64 +++++++++++++++---- | ||||
|  1 file changed, 51 insertions(+), 13 deletions(-) | ||||
| 
 | ||||
| diff --git a/src/gallium/frontends/clover/llvm/invocation.cpp b/src/gallium/frontends/clover/llvm/invocation.cpp
 | ||||
| index 7a50fea3323..43d26fe1abb 100644
 | ||||
| --- a/src/gallium/frontends/clover/llvm/invocation.cpp
 | ||||
| +++ b/src/gallium/frontends/clover/llvm/invocation.cpp
 | ||||
| @@ -27,13 +27,17 @@
 | ||||
|  #include <llvm/IR/DiagnosticPrinter.h> | ||||
|  #include <llvm/IR/DiagnosticInfo.h> | ||||
|  #include <llvm/IR/LLVMContext.h> | ||||
| +#include <llvm/IR/Module.h>
 | ||||
|  #include <llvm/Support/raw_ostream.h> | ||||
| -#include <llvm/Transforms/IPO/PassManagerBuilder.h>
 | ||||
| +#include <llvm/Transforms/IPO/Internalize.h>
 | ||||
|  #include <llvm-c/Target.h> | ||||
|  #ifdef HAVE_CLOVER_SPIRV | ||||
|  #include <LLVMSPIRVLib/LLVMSPIRVLib.h> | ||||
|  #endif | ||||
|   | ||||
| +#include <llvm-c/TargetMachine.h>
 | ||||
| +#include <llvm-c/Transforms/PassBuilder.h>
 | ||||
| +#include <llvm/Support/CBindingWrapping.h>
 | ||||
|  #include <clang/CodeGen/CodeGenAction.h> | ||||
|  #include <clang/Lex/PreprocessorOptions.h> | ||||
|  #include <clang/Frontend/TextDiagnosticBuffer.h> | ||||
| @@ -439,10 +443,10 @@ clover::llvm::compile_program(const std::string &source,
 | ||||
|   | ||||
|  namespace { | ||||
|     void | ||||
| -   optimize(Module &mod, unsigned optimization_level,
 | ||||
| +   optimize(Module &mod,
 | ||||
| +            const std::string& ir_target,
 | ||||
| +            unsigned optimization_level,
 | ||||
|              bool internalize_symbols) { | ||||
| -      ::llvm::legacy::PassManager pm;
 | ||||
| -
 | ||||
|        // By default, the function internalizer pass will look for a function | ||||
|        // called "main" and then mark all other functions as internal.  Marking | ||||
|        // functions as internal enables the optimizer to perform optimizations | ||||
| @@ -458,19 +462,53 @@ namespace {
 | ||||
|        if (internalize_symbols) { | ||||
|           std::vector<std::string> names = | ||||
|              map(std::mem_fn(&Function::getName), get_kernels(mod)); | ||||
| -         pm.add(::llvm::createInternalizePass(
 | ||||
| +         internalizeModule(mod,
 | ||||
|                        [=](const ::llvm::GlobalValue &gv) { | ||||
|                           return std::find(names.begin(), names.end(), | ||||
|                                            gv.getName()) != names.end(); | ||||
| -                      }));
 | ||||
| +                      });
 | ||||
|        } | ||||
|   | ||||
| -      ::llvm::PassManagerBuilder pmb;
 | ||||
| -      pmb.OptLevel = optimization_level;
 | ||||
| -      pmb.LibraryInfo = new ::llvm::TargetLibraryInfoImpl(
 | ||||
| -         ::llvm::Triple(mod.getTargetTriple()));
 | ||||
| -      pmb.populateModulePassManager(pm);
 | ||||
| -      pm.run(mod);
 | ||||
| +
 | ||||
| +      const char *opt_str = NULL;
 | ||||
| +      LLVMCodeGenOptLevel level;
 | ||||
| +      switch (optimization_level) {
 | ||||
| +      case 0:
 | ||||
| +      default:
 | ||||
| +         opt_str = "default<O0>";
 | ||||
| +         level = LLVMCodeGenLevelNone;
 | ||||
| +         break;
 | ||||
| +      case 1:
 | ||||
| +         opt_str = "default<O1>";
 | ||||
| +         level = LLVMCodeGenLevelLess;
 | ||||
| +         break;
 | ||||
| +      case 2:
 | ||||
| +         opt_str = "default<O2>";
 | ||||
| +         level = LLVMCodeGenLevelDefault;
 | ||||
| +         break;
 | ||||
| +      case 3:
 | ||||
| +         opt_str = "default<O3>";
 | ||||
| +         level = LLVMCodeGenLevelAggressive;
 | ||||
| +         break;
 | ||||
| +      }
 | ||||
| +
 | ||||
| +      const target &target = ir_target;
 | ||||
| +      LLVMTargetRef targ;
 | ||||
| +      char *err_message;
 | ||||
| +
 | ||||
| +      if (LLVMGetTargetFromTriple(target.triple.c_str(), &targ, &err_message))
 | ||||
| +         return;
 | ||||
| +      LLVMTargetMachineRef tm =
 | ||||
| +         LLVMCreateTargetMachine(targ, target.triple.c_str(),
 | ||||
| +                                 target.cpu.c_str(), "", level,
 | ||||
| +                                 LLVMRelocDefault, LLVMCodeModelDefault);
 | ||||
| +
 | ||||
| +      if (!tm)
 | ||||
| +         return;
 | ||||
| +      LLVMPassBuilderOptionsRef opts = LLVMCreatePassBuilderOptions();
 | ||||
| +      LLVMRunPasses(wrap(&mod), opt_str, tm, opts);
 | ||||
| +
 | ||||
| +      LLVMDisposeTargetMachine(tm);
 | ||||
|     } | ||||
|   | ||||
|     std::unique_ptr<Module> | ||||
| @@ -500,7 +538,7 @@ clover::llvm::link_program(const std::vector<binary> &binaries,
 | ||||
|     auto c = create_compiler_instance(dev, dev.ir_target(), options, r_log); | ||||
|     auto mod = link(*ctx, *c, binaries, r_log); | ||||
|   | ||||
| -   optimize(*mod, c->getCodeGenOpts().OptimizationLevel, !create_library);
 | ||||
| +   optimize(*mod, dev.ir_target(), c->getCodeGenOpts().OptimizationLevel, !create_library);
 | ||||
|   | ||||
|     static std::atomic_uint seq(0); | ||||
|     const std::string id = "." + mod->getModuleIdentifier() + "-" + | ||||
| -- 
 | ||||
| 2.42.0 | ||||
| 
 | ||||
| @ -0,0 +1,41 @@ | ||||
| From 9ba416cdc67073cdda9a73fe9d37304b82bdd526 Mon Sep 17 00:00:00 2001 | ||||
| From: Pierre-Eric Pelloux-Prayer <pierre-eric.pelloux-prayer@amd.com> | ||||
| Date: Fri, 12 May 2023 09:58:26 +0200 | ||||
| Subject: [PATCH] llvmpipe: only include old Transform includes when needed | ||||
| 
 | ||||
| This fixes building with recent LLVM where these 2 .h files | ||||
| were removed. | ||||
| 
 | ||||
| Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/8671 | ||||
| Acked-By: Mike Blumenkrantz <michael.blumenkrantz@gmail.com> | ||||
| Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/22980> | ||||
| ---
 | ||||
|  src/gallium/auxiliary/gallivm/lp_bld_init.c | 8 ++++---- | ||||
|  1 file changed, 4 insertions(+), 4 deletions(-) | ||||
| 
 | ||||
| diff --git a/src/gallium/auxiliary/gallivm/lp_bld_init.c b/src/gallium/auxiliary/gallivm/lp_bld_init.c
 | ||||
| index 24d082398e9..9e0d6a5f643 100644
 | ||||
| --- a/src/gallium/auxiliary/gallivm/lp_bld_init.c
 | ||||
| +++ b/src/gallium/auxiliary/gallivm/lp_bld_init.c
 | ||||
| @@ -42,14 +42,14 @@
 | ||||
|   | ||||
|  #include <llvm/Config/llvm-config.h> | ||||
|  #include <llvm-c/Analysis.h> | ||||
| -#include <llvm-c/Transforms/Scalar.h>
 | ||||
| -#if LLVM_VERSION_MAJOR >= 7
 | ||||
| -#include <llvm-c/Transforms/Utils.h>
 | ||||
| -#endif
 | ||||
|  #include <llvm-c/BitWriter.h> | ||||
|  #if GALLIVM_USE_NEW_PASS == 1 | ||||
|  #include <llvm-c/Transforms/PassBuilder.h> | ||||
|  #elif GALLIVM_HAVE_CORO == 1 | ||||
| +#include <llvm-c/Transforms/Scalar.h>
 | ||||
| +#if LLVM_VERSION_MAJOR >= 7
 | ||||
| +#include <llvm-c/Transforms/Utils.h>
 | ||||
| +#endif
 | ||||
|  #if LLVM_VERSION_MAJOR <= 8 && (DETECT_ARCH_AARCH64 || DETECT_ARCH_ARM || DETECT_ARCH_S390 || DETECT_ARCH_MIPS64) | ||||
|  #include <llvm-c/Transforms/IPO.h> | ||||
|  #endif | ||||
| -- 
 | ||||
| 2.42.0 | ||||
| 
 | ||||
| @ -0,0 +1,28 @@ | ||||
| From 460d2c46a903fed295a1528c8b6273dd6b0e0d19 Mon Sep 17 00:00:00 2001 | ||||
| From: thfrwn <11335318+rfht@users.noreply.github.com> | ||||
| Date: Fri, 9 Feb 2024 17:00:55 -0500 | ||||
| Subject: [PATCH] mesa: fix off-by-one for newblock allocation in dlist_alloc | ||||
| 
 | ||||
| Cc: mesa-stable | ||||
| Reviewed-by: Pierre-Eric Pelloux-Prayer <pierre-eric.pelloux-prayer@amd.com> | ||||
| Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27556> | ||||
| ---
 | ||||
|  src/mesa/main/dlist.c | 2 +- | ||||
|  1 file changed, 1 insertion(+), 1 deletion(-) | ||||
| 
 | ||||
| diff --git a/src/mesa/main/dlist.c b/src/mesa/main/dlist.c
 | ||||
| index b0184a24e20..9213641699a 100644
 | ||||
| --- a/src/mesa/main/dlist.c
 | ||||
| +++ b/src/mesa/main/dlist.c
 | ||||
| @@ -1220,7 +1220,7 @@ dlist_alloc(struct gl_context *ctx, OpCode opcode, GLuint bytes, bool align8)
 | ||||
|        ctx->ListState.CurrentPos++; | ||||
|     } | ||||
|   | ||||
| -   if (ctx->ListState.CurrentPos + numNodes + contNodes > BLOCK_SIZE) {
 | ||||
| +   if (ctx->ListState.CurrentPos + numNodes + contNodes >= BLOCK_SIZE) {
 | ||||
|        /* This block is full.  Allocate a new block and chain to it */ | ||||
|        Node *newblock; | ||||
|        Node *n = ctx->ListState.CurrentBlock + ctx->ListState.CurrentPos; | ||||
| -- 
 | ||||
| 2.45.2 | ||||
| 
 | ||||
| @ -0,0 +1,37 @@ | ||||
| From f7434d7576032cf97e3c74ef09912f59617a4bad Mon Sep 17 00:00:00 2001 | ||||
| From: Dave Airlie <airlied@redhat.com> | ||||
| Date: Fri, 14 Jun 2024 12:22:58 +1000 | ||||
| Subject: [PATCH] nouveau/nvc0: increase overallocation on shader bo to 2K | ||||
| 
 | ||||
| I've been seeing a bunch of read page faults at the end of the | ||||
| shader allocation, nvk uses a full page at the end to overallocate | ||||
| so align with that and see if it goes away. | ||||
| 
 | ||||
| ahulliet and skeggsb both said 2k was used. | ||||
| 
 | ||||
| Cc: mesa-stable | ||||
| Reviewed-by: Arthur Huillet <ahuillet@nvidia.com> | ||||
| Reviewed-by: Karol Herbst <kherbst@redhat.com> | ||||
| Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29722> | ||||
| ---
 | ||||
|  src/gallium/drivers/nouveau/nvc0/nvc0_screen.c | 7 ++++--- | ||||
|  1 file changed, 4 insertions(+), 3 deletions(-) | ||||
| 
 | ||||
| diff -up mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_screen.c.dma mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_screen.c
 | ||||
| --- mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_screen.c.dma	2023-07-21 22:42:42.000000000 +1000
 | ||||
| +++ mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_screen.c	2024-08-16 12:49:13.532998512 +1000
 | ||||
| @@ -886,10 +886,11 @@ nvc0_screen_resize_text_area(struct nvc0
 | ||||
|     nouveau_heap_free(&screen->lib_code); | ||||
|     nouveau_heap_destroy(&screen->text_heap); | ||||
|   | ||||
| -   /* XXX: getting a page fault at the end of the code buffer every few
 | ||||
| -    *  launches, don't use the last 256 bytes to work around them - prefetch ?
 | ||||
| +   /*
 | ||||
| +    * Shader storage needs a 2K (from NVIDIA) overallocations at the end
 | ||||
| +    * to avoid prefetch bugs.
 | ||||
|      */ | ||||
| -   nouveau_heap_init(&screen->text_heap, 0, size - 0x100);
 | ||||
| +   nouveau_heap_init(&screen->text_heap, 0, size - 0x800);
 | ||||
|   | ||||
|     /* update the code segment setup */ | ||||
|     if (screen->eng3d->oclass < GV100_3D_CLASS) { | ||||
							
								
								
									
										23
									
								
								SOURCES/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								SOURCES/Makefile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| VERSION ?= 23.1.4 | ||||
| SANITIZE ?= 1 | ||||
| 
 | ||||
| DIRNAME = mesa-${VERSION} | ||||
| 
 | ||||
| all: archive | ||||
| 
 | ||||
| clean: | ||||
| 	rm -rf $(DIRNAME)/ | ||||
| 	rm -f mesa-${VERSION}.tar.xz | ||||
| 
 | ||||
| clone: clean | ||||
| 	curl -O https://archive.mesa3d.org/mesa-${VERSION}.tar.xz | ||||
| 	tar xf mesa-${VERSION}.tar.xz | ||||
| 
 | ||||
| sanitize: clone vl_mpeg12_decoder.c vl_decoder.c | ||||
| ifdef SANITIZE | ||||
| 	cat < vl_mpeg12_decoder.c > $(DIRNAME)/src/gallium/auxiliary/vl/vl_mpeg12_decoder.c | ||||
| 	cat < vl_decoder.c > $(DIRNAME)/src/gallium/auxiliary/vl/vl_decoder.c | ||||
| endif | ||||
| 
 | ||||
| archive: clone sanitize | ||||
| 	tar caf ${DIRNAME}.tar.xz ${DIRNAME} | ||||
							
								
								
									
										12
									
								
								SOURCES/fix-py-ver.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								SOURCES/fix-py-ver.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | ||||
| diff -up mesa-23.1.4/meson.build.dma mesa-23.1.4/meson.build
 | ||||
| --- mesa-23.1.4/meson.build.dma	2023-07-28 10:15:41.807945483 +1000
 | ||||
| +++ mesa-23.1.4/meson.build	2023-07-28 10:15:46.465030794 +1000
 | ||||
| @@ -835,7 +835,7 @@ if get_option('allow-kcmp') \
 | ||||
|    pre_args += '-DALLOW_KCMP' | ||||
|  endif | ||||
|   | ||||
| -prog_python = import('python').find_installation('python3')
 | ||||
| +prog_python = import('python').find_installation('python3.6')
 | ||||
|  has_mako = run_command( | ||||
|    prog_python, '-c', | ||||
|    ''' | ||||
							
								
								
									
										13
									
								
								SOURCES/lavapipe-disable-env-var.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								SOURCES/lavapipe-disable-env-var.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | ||||
| diff -up mesa-21.3.0/src/gallium/frontends/lavapipe/lvp_device.cdma mesa-21.3.0/src/gallium/frontends/lavapipe/lvp_device.c
 | ||||
| --- mesa-21.3.0/src/gallium/frontends/lavapipe/lvp_device.cdma	2021-11-18 06:16:20.000000000 +1000
 | ||||
| +++ mesa-21.3.0/src/gallium/frontends/lavapipe/lvp_device.c	2021-11-18 07:03:17.652283186 +1000
 | ||||
| @@ -213,6 +213,9 @@ VKAPI_ATTR VkResult VKAPI_CALL lvp_Creat
 | ||||
|     if (pAllocator == NULL) | ||||
|        pAllocator = vk_default_allocator(); | ||||
|   | ||||
| +   if (!getenv("RH_SW_VULKAN"))
 | ||||
| +      return VK_ERROR_INITIALIZATION_FAILED;
 | ||||
| +
 | ||||
|     instance = vk_zalloc(pAllocator, sizeof(*instance), 8, | ||||
|                          VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE); | ||||
|     if (!instance) | ||||
							
								
								
									
										30
									
								
								SOURCES/nouveau-work-around-linear-zs-issue.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								SOURCES/nouveau-work-around-linear-zs-issue.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| diff -up mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_state_validate.c.da mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_state_validate.c
 | ||||
| --- mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_state_validate.c.da	2025-01-10 13:14:31.119630821 +1000
 | ||||
| +++ mesa-23.1.4/src/gallium/drivers/nouveau/nvc0/nvc0_state_validate.c	2025-01-10 13:15:11.917433170 +1000
 | ||||
| @@ -149,6 +149,7 @@ nvc0_validate_fb(struct nvc0_context *nv
 | ||||
|     unsigned ms_mode = NVC0_3D_MULTISAMPLE_MODE_MS1; | ||||
|     unsigned nr_cbufs = fb->nr_cbufs; | ||||
|     bool serialize = false; | ||||
| +   bool cbuf_is_linear = false;
 | ||||
|   | ||||
|     nouveau_bufctx_reset(nvc0->bufctx_3d, NVC0_BIND_3D_FB); | ||||
|   | ||||
| @@ -203,8 +204,7 @@ nvc0_validate_fb(struct nvc0_context *nv
 | ||||
|           PUSH_DATA(push, 0); | ||||
|   | ||||
|           nvc0_resource_fence(nvc0, res, NOUVEAU_BO_WR); | ||||
| -
 | ||||
| -         assert(!fb->zsbuf);
 | ||||
| +         cbuf_is_linear = true;
 | ||||
|        } | ||||
|   | ||||
|        if (res->status & NOUVEAU_BUFFER_STATUS_GPU_READING) | ||||
| @@ -216,7 +216,7 @@ nvc0_validate_fb(struct nvc0_context *nv
 | ||||
|        BCTX_REFN(nvc0->bufctx_3d, 3D_FB, res, WR); | ||||
|     } | ||||
|   | ||||
| -   if (fb->zsbuf) {
 | ||||
| +   if (fb->zsbuf && !cbuf_is_linear) {
 | ||||
|        struct nv50_miptree *mt = nv50_miptree(fb->zsbuf->texture); | ||||
|        struct nv50_surface *sf = nv50_surface(fb->zsbuf); | ||||
|        int unk = mt->base.base.target == PIPE_TEXTURE_2D; | ||||
							
								
								
									
										11
									
								
								SOURCES/radeonsi-turn-off-glthread.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								SOURCES/radeonsi-turn-off-glthread.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| diff -up mesa-22.3.3/src/gallium/drivers/radeonsi/driinfo_radeonsi.h.dma mesa-22.3.3/src/gallium/drivers/radeonsi/driinfo_radeonsi.h
 | ||||
| --- mesa-22.3.3/src/gallium/drivers/radeonsi/driinfo_radeonsi.h.dma	2023-01-25 06:17:54.993167334 +1000
 | ||||
| +++ mesa-22.3.3/src/gallium/drivers/radeonsi/driinfo_radeonsi.h	2023-01-25 06:17:57.363203425 +1000
 | ||||
| @@ -1,7 +1,6 @@
 | ||||
|  // DriConf options specific to radeonsi | ||||
|  DRI_CONF_SECTION_PERFORMANCE | ||||
|  DRI_CONF_ADAPTIVE_SYNC(true) | ||||
| -DRI_CONF_MESA_GLTHREAD(true)
 | ||||
|  DRI_CONF_SECTION_END | ||||
|   | ||||
|  DRI_CONF_SECTION_DEBUG | ||||
							
								
								
									
										20
									
								
								SOURCES/vl_decoder.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								SOURCES/vl_decoder.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | ||||
| #include "vl_decoder.h" | ||||
| bool | ||||
| vl_profile_supported(struct pipe_screen *screen, enum pipe_video_profile profile, | ||||
|                      enum pipe_video_entrypoint entrypoint) | ||||
| { | ||||
|    return false; | ||||
| } | ||||
| 
 | ||||
| int | ||||
| vl_level_supported(struct pipe_screen *screen, enum pipe_video_profile profile) | ||||
| { | ||||
|    return 0; | ||||
| } | ||||
| 
 | ||||
| struct pipe_video_codec * | ||||
| vl_create_decoder(struct pipe_context *pipe, | ||||
|                   const struct pipe_video_codec *templat) | ||||
| { | ||||
|    return NULL; | ||||
| } | ||||
							
								
								
									
										7
									
								
								SOURCES/vl_mpeg12_decoder.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								SOURCES/vl_mpeg12_decoder.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| #include "vl_mpeg12_decoder.h" | ||||
| struct pipe_video_codec * | ||||
| vl_create_mpeg12_decoder(struct pipe_context *context, | ||||
|                          const struct pipe_video_codec *templat) | ||||
| { | ||||
|     return NULL; | ||||
| } | ||||
							
								
								
									
										1438
									
								
								SPECS/mesa.spec
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1438
									
								
								SPECS/mesa.spec
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,6 +0,0 @@ | ||||
| --- !Policy | ||||
| product_versions: | ||||
|   - rhel-9 | ||||
| decision_context: osci_compose_gate | ||||
| rules: | ||||
|   - !PassingTestCaseRule {test_case_name: desktop-qe.desktop-ci.tier1-gating.functional} | ||||
							
								
								
									
										5
									
								
								sources
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								sources
									
									
									
									
									
								
							| @ -1,5 +0,0 @@ | ||||
| SHA512 (libclc-17.0.6.src.tar.xz) = 6165bfa0112fb42756cd0e83a0d3d4406985b1d6db6eed8abb3bee9a74fcc451cc88928b24231493694035c35d9bcd367aa6a4a67da631cb4ee5e7a98037fee3 | ||||
| SHA512 (mesa-24.1.0.tar.xz) = 4b7ed1940fc812ef4efb55978d3ffe3d0e2ae53d5b57a3baca10a52db2ba5852c5ee7e75c3739bd8d384c80bf1cba970a384250050f01f03bba98f255e12cec5 | ||||
| SHA512 (meson-1.3.0.tar.gz) = fbcbdd9551ad12b7be84411b96357e01c7c0c38a8e9933093d2e71ed7e12bd4278245798684d389c332eb75dd50c99310affc9acb01cf8bedd45265335083a32 | ||||
| SHA512 (spirv-llvm-translator-854179a.tar.gz) = 7b8b1f974e10bfe8b9680b5b769fa60fa438b0070d0aee7795597c79999942e44a0629035b7f5bdd0b86e742fa200f8cb9596b60f0f61c9eea919ea8b21d3d6a | ||||
| SHA512 (wayland-protocols-1.34.tar.xz) = d180eaaf87281dc7adade19070ee8308a5cb3dc2f60cff077960436ad647d3d207eb63fa0b079b7b315109654ad6e6b5e2588bfe859900e67edf8c67b1c3ad20 | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user