mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 72e9abc3dd
			
		
	
	
		72e9abc3dd
		
	
	
	
	
		
			
			Add a helper for accessing uncore->regs instead of doing it directly. This will help display code reuse with the xe driver. Cc: Andi Shyti <andi.shyti@linux.intel.com> Signed-off-by: Jani Nikula <jani.nikula@intel.com> Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20230627095128.208071-1-jani.nikula@intel.com
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: MIT
 | |
| /*
 | |
|  * Copyright © 2021 Intel Corporation
 | |
|  */
 | |
| 
 | |
| #include <drm/drm_managed.h>
 | |
| 
 | |
| #include "i915_drv.h"
 | |
| #include "gt/intel_gt.h"
 | |
| #include "gt/intel_sa_media.h"
 | |
| 
 | |
| int intel_sa_mediagt_setup(struct intel_gt *gt, phys_addr_t phys_addr,
 | |
| 			   u32 gsi_offset)
 | |
| {
 | |
| 	struct drm_i915_private *i915 = gt->i915;
 | |
| 	struct intel_uncore *uncore;
 | |
| 
 | |
| 	uncore = drmm_kzalloc(&i915->drm, sizeof(*uncore), GFP_KERNEL);
 | |
| 	if (!uncore)
 | |
| 		return -ENOMEM;
 | |
| 
 | |
| 	uncore->gsi_offset = gsi_offset;
 | |
| 
 | |
| 	gt->irq_lock = to_gt(i915)->irq_lock;
 | |
| 	intel_gt_common_init_early(gt);
 | |
| 	intel_uncore_init_early(uncore, gt);
 | |
| 
 | |
| 	/*
 | |
| 	 * Standalone media shares the general MMIO space with the primary
 | |
| 	 * GT.  We'll re-use the primary GT's mapping.
 | |
| 	 */
 | |
| 	uncore->regs = intel_uncore_regs(&i915->uncore);
 | |
| 	if (drm_WARN_ON(&i915->drm, uncore->regs == NULL))
 | |
| 		return -EIO;
 | |
| 
 | |
| 	gt->uncore = uncore;
 | |
| 	gt->phys_addr = phys_addr;
 | |
| 
 | |
| 	/*
 | |
| 	 * For current platforms we can assume there's only a single
 | |
| 	 * media GT and cache it for quick lookup.
 | |
| 	 */
 | |
| 	drm_WARN_ON(&i915->drm, i915->media_gt);
 | |
| 	i915->media_gt = gt;
 | |
| 
 | |
| 	return 0;
 | |
| }
 |