diff options
| author | Dave Airlie <airlied@redhat.com> | 2019-05-31 09:33:29 +1000 | 
|---|---|---|
| committer | Dave Airlie <airlied@redhat.com> | 2019-05-31 10:04:39 +1000 | 
| commit | 91c1ead6aee22d4595f50ba66070b94a4a8f84a9 (patch) | |
| tree | 066ffa1c352b6257dd37cda6a1df53159e133f2e /drivers/gpu/drm/amd/amdgpu/amdgpu.h | |
| parent | 14ee642c2ab0a3d8a1ded11fade692d8b77172b9 (diff) | |
| parent | cf401e2856b27b2deeada498eab864e2a50cf219 (diff) | |
Merge branch 'drm-next-5.3' of git://people.freedesktop.org/~agd5f/linux into drm-next
New stuff for 5.3:
- Add new thermal sensors for vega asics
- Various RAS fixes
- Add sysfs interface for memory interface utilization
- Use HMM rather than mmu notifier for user pages
- Expose xgmi topology via kfd
- SR-IOV fixes
- Fixes for manual driver reload
- Add unique identifier for vega asics
- Clean up user fence handling with UVD/VCE/VCN blocks
- Convert DC to use core bpc attribute rather than a custom one
- Add GWS support for KFD
- Vega powerplay improvements
- Add CRC support for DCE 12
- SR-IOV support for new security policy
- Various cleanups
From: Alex Deucher <alexdeucher@gmail.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190529220944.14464-1-alexander.deucher@amd.com
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu.h')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu.h | 29 | 
1 files changed, 28 insertions, 1 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h index 14398f55f602..58f8f132904d 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h @@ -118,7 +118,6 @@ extern int amdgpu_disp_priority;  extern int amdgpu_hw_i2c;  extern int amdgpu_pcie_gen2;  extern int amdgpu_msi; -extern int amdgpu_lockup_timeout;  extern int amdgpu_dpm;  extern int amdgpu_fw_load_type;  extern int amdgpu_aspm; @@ -211,6 +210,7 @@ struct amdgpu_irq_src;  struct amdgpu_fpriv;  struct amdgpu_bo_va_mapping;  struct amdgpu_atif; +struct kfd_vm_fault_info;  enum amdgpu_cp_irq {  	AMDGPU_CP_IRQ_GFX_EOP = 0, @@ -415,6 +415,7 @@ struct amdgpu_fpriv {  };  int amdgpu_file_to_fpriv(struct file *filp, struct amdgpu_fpriv **fpriv); +int amdgpu_device_get_job_timeout_settings(struct amdgpu_device *adev);  int amdgpu_ib_get(struct amdgpu_device *adev, struct amdgpu_vm *vm,  		  unsigned size, struct amdgpu_ib *ib); @@ -558,6 +559,8 @@ struct amdgpu_asic_funcs {  			       uint64_t *count1);  	/* do we need to reset the asic at init time (e.g., kexec) */  	bool (*need_reset_on_init)(struct amdgpu_device *adev); +	/* PCIe replay counter */ +	uint64_t (*get_pcie_replay_count)(struct amdgpu_device *adev);  };  /* @@ -639,6 +642,11 @@ struct nbio_hdp_flush_reg {  	u32 ref_and_mask_sdma1;  }; +struct amdgpu_mmio_remap { +	u32 reg_offset; +	resource_size_t bus_addr; +}; +  struct amdgpu_nbio_funcs {  	const struct nbio_hdp_flush_reg *hdp_flush_reg;  	u32 (*get_hdp_flush_req_offset)(struct amdgpu_device *adev); @@ -666,6 +674,7 @@ struct amdgpu_nbio_funcs {  	void (*ih_control)(struct amdgpu_device *adev);  	void (*init_registers)(struct amdgpu_device *adev);  	void (*detect_hw_virt)(struct amdgpu_device *adev); +	void (*remap_hdp_registers)(struct amdgpu_device *adev);  };  struct amdgpu_df_funcs { @@ -680,6 +689,12 @@ struct amdgpu_df_funcs {  				      u32 *flags);  	void (*enable_ecc_force_par_wr_rmw)(struct amdgpu_device *adev,  					    bool enable); +	int (*pmc_start)(struct amdgpu_device *adev, uint64_t config, +					 int is_enable); +	int (*pmc_stop)(struct amdgpu_device *adev, uint64_t config, +					 int is_disable); +	void (*pmc_get_count)(struct amdgpu_device *adev, uint64_t config, +					 uint64_t *count);  };  /* Define the HW IP blocks will be used in driver , add more if necessary */  enum amd_hw_ip_block_type { @@ -764,6 +779,7 @@ struct amdgpu_device {  	void __iomem			*rmmio;  	/* protects concurrent MM_INDEX/DATA based register access */  	spinlock_t mmio_idx_lock; +	struct amdgpu_mmio_remap        rmmio_remap;  	/* protects concurrent SMC based register access */  	spinlock_t smc_idx_lock;  	amdgpu_rreg_t			smc_rreg; @@ -936,6 +952,13 @@ struct amdgpu_device {  	struct work_struct		xgmi_reset_work;  	bool                            in_baco_reset; + +	long				gfx_timeout; +	long				sdma_timeout; +	long				video_timeout; +	long				compute_timeout; + +	uint64_t			unique_id;  };  static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_bo_device *bdev) @@ -1065,6 +1088,7 @@ int emu_soc_asic_init(struct amdgpu_device *adev);  #define amdgpu_asic_init_doorbell_index(adev) (adev)->asic_funcs->init_doorbell_index((adev))  #define amdgpu_asic_get_pcie_usage(adev, cnt0, cnt1) ((adev)->asic_funcs->get_pcie_usage((adev), (cnt0), (cnt1)))  #define amdgpu_asic_need_reset_on_init(adev) (adev)->asic_funcs->need_reset_on_init((adev)) +#define amdgpu_asic_get_pcie_replay_count(adev) ((adev)->asic_funcs->get_pcie_replay_count((adev)))  /* Common functions */  bool amdgpu_device_should_recover_gpu(struct amdgpu_device *adev); @@ -1081,6 +1105,9 @@ void amdgpu_device_program_register_sequence(struct amdgpu_device *adev,  					     const u32 array_size);  bool amdgpu_device_is_px(struct drm_device *dev); +bool amdgpu_device_is_peer_accessible(struct amdgpu_device *adev, +				      struct amdgpu_device *peer_adev); +  /* atpx handler */  #if defined(CONFIG_VGA_SWITCHEROO)  void amdgpu_register_atpx_handler(void); | 
