diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu.h')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu.h | 221 | 
1 files changed, 41 insertions, 180 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h index ff7bf1a9f967..103635ab784c 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h @@ -68,13 +68,16 @@  #include "gpu_scheduler.h"  #include "amdgpu_virt.h" +#include "amdgpu_gart.h"  /*   * Modules parameters.   */  extern int amdgpu_modeset;  extern int amdgpu_vram_limit; +extern int amdgpu_vis_vram_limit;  extern int amdgpu_gart_size; +extern int amdgpu_gtt_size;  extern int amdgpu_moverate;  extern int amdgpu_benchmarking;  extern int amdgpu_testing; @@ -93,6 +96,7 @@ extern int amdgpu_bapm;  extern int amdgpu_deep_color;  extern int amdgpu_vm_size;  extern int amdgpu_vm_block_size; +extern int amdgpu_vm_fragment_size;  extern int amdgpu_vm_fault_stop;  extern int amdgpu_vm_debug;  extern int amdgpu_vm_update_mode; @@ -104,6 +108,7 @@ extern unsigned amdgpu_pcie_gen_cap;  extern unsigned amdgpu_pcie_lane_cap;  extern unsigned amdgpu_cg_mask;  extern unsigned amdgpu_pg_mask; +extern unsigned amdgpu_sdma_phase_quantum;  extern char *amdgpu_disable_cu;  extern char *amdgpu_virtual_display;  extern unsigned amdgpu_pp_feature_mask; @@ -369,78 +374,10 @@ struct amdgpu_clock {  };  /* - * BO. + * GEM.   */ -struct amdgpu_bo_list_entry { -	struct amdgpu_bo		*robj; -	struct ttm_validate_buffer	tv; -	struct amdgpu_bo_va		*bo_va; -	uint32_t			priority; -	struct page			**user_pages; -	int				user_invalidated; -}; - -struct amdgpu_bo_va_mapping { -	struct list_head		list; -	struct rb_node			rb; -	uint64_t			start; -	uint64_t			last; -	uint64_t			__subtree_last; -	uint64_t			offset; -	uint64_t			flags; -}; - -/* bo virtual addresses in a specific vm */ -struct amdgpu_bo_va { -	/* protected by bo being reserved */ -	struct list_head		bo_list; -	struct dma_fence	        *last_pt_update; -	unsigned			ref_count; - -	/* protected by vm mutex and spinlock */ -	struct list_head		vm_status; - -	/* mappings for this bo_va */ -	struct list_head		invalids; -	struct list_head		valids; - -	/* constant after initialization */ -	struct amdgpu_vm		*vm; -	struct amdgpu_bo		*bo; -};  #define AMDGPU_GEM_DOMAIN_MAX		0x3 - -struct amdgpu_bo { -	/* Protected by tbo.reserved */ -	u32				prefered_domains; -	u32				allowed_domains; -	struct ttm_place		placements[AMDGPU_GEM_DOMAIN_MAX + 1]; -	struct ttm_placement		placement; -	struct ttm_buffer_object	tbo; -	struct ttm_bo_kmap_obj		kmap; -	u64				flags; -	unsigned			pin_count; -	void				*kptr; -	u64				tiling_flags; -	u64				metadata_flags; -	void				*metadata; -	u32				metadata_size; -	unsigned			prime_shared_count; -	/* list of all virtual address to which this bo -	 * is associated to -	 */ -	struct list_head		va; -	/* Constant after initialization */ -	struct drm_gem_object		gem_base; -	struct amdgpu_bo		*parent; -	struct amdgpu_bo		*shadow; - -	struct ttm_bo_kmap_obj		dma_buf_vmap; -	struct amdgpu_mn		*mn; -	struct list_head		mn_list; -	struct list_head		shadow_list; -};  #define gem_to_amdgpu_bo(gobj) container_of((gobj), struct amdgpu_bo, gem_base)  void amdgpu_gem_object_free(struct drm_gem_object *obj); @@ -532,49 +469,6 @@ int amdgpu_fence_slab_init(void);  void amdgpu_fence_slab_fini(void);  /* - * GART structures, functions & helpers - */ -struct amdgpu_mc; - -#define AMDGPU_GPU_PAGE_SIZE 4096 -#define AMDGPU_GPU_PAGE_MASK (AMDGPU_GPU_PAGE_SIZE - 1) -#define AMDGPU_GPU_PAGE_SHIFT 12 -#define AMDGPU_GPU_PAGE_ALIGN(a) (((a) + AMDGPU_GPU_PAGE_MASK) & ~AMDGPU_GPU_PAGE_MASK) - -struct amdgpu_gart { -	dma_addr_t			table_addr; -	struct amdgpu_bo		*robj; -	void				*ptr; -	unsigned			num_gpu_pages; -	unsigned			num_cpu_pages; -	unsigned			table_size; -#ifdef CONFIG_DRM_AMDGPU_GART_DEBUGFS -	struct page			**pages; -#endif -	bool				ready; - -	/* Asic default pte flags */ -	uint64_t			gart_pte_flags; - -	const struct amdgpu_gart_funcs *gart_funcs; -}; - -int amdgpu_gart_table_ram_alloc(struct amdgpu_device *adev); -void amdgpu_gart_table_ram_free(struct amdgpu_device *adev); -int amdgpu_gart_table_vram_alloc(struct amdgpu_device *adev); -void amdgpu_gart_table_vram_free(struct amdgpu_device *adev); -int amdgpu_gart_table_vram_pin(struct amdgpu_device *adev); -void amdgpu_gart_table_vram_unpin(struct amdgpu_device *adev); -int amdgpu_gart_init(struct amdgpu_device *adev); -void amdgpu_gart_fini(struct amdgpu_device *adev); -int amdgpu_gart_unbind(struct amdgpu_device *adev, uint64_t offset, -			int pages); -int amdgpu_gart_bind(struct amdgpu_device *adev, uint64_t offset, -		     int pages, struct page **pagelist, -		     dma_addr_t *dma_addr, uint64_t flags); -int amdgpu_ttm_recover_gart(struct amdgpu_device *adev); - -/*   * VMHUB structures, functions & helpers   */  struct amdgpu_vmhub { @@ -598,22 +492,20 @@ struct amdgpu_mc {  	 * about vram size near mc fb location */  	u64			mc_vram_size;  	u64			visible_vram_size; -	u64			gtt_size; -	u64			gtt_start; -	u64			gtt_end; +	u64			gart_size; +	u64			gart_start; +	u64			gart_end;  	u64			vram_start;  	u64			vram_end;  	unsigned		vram_width;  	u64			real_vram_size;  	int			vram_mtrr; -	u64                     gtt_base_align;  	u64                     mc_mask;  	const struct firmware   *fw;	/* MC firmware */  	uint32_t                fw_version;  	struct amdgpu_irq_src	vm_fault;  	uint32_t		vram_type;  	uint32_t                srbm_soft_reset; -	struct amdgpu_mode_mc_save save;  	bool			prt_warning;  	uint64_t		stolen_size;  	/* apertures */ @@ -719,15 +611,15 @@ typedef enum _AMDGPU_DOORBELL64_ASSIGNMENT  	/* overlap the doorbell assignment with VCN as they are  mutually exclusive  	 * VCE engine's doorbell is 32 bit and two VCE ring share one QWORD  	 */ -	AMDGPU_DOORBELL64_RING0_1                 = 0xF8, -	AMDGPU_DOORBELL64_RING2_3                 = 0xF9, -	AMDGPU_DOORBELL64_RING4_5                 = 0xFA, -	AMDGPU_DOORBELL64_RING6_7                 = 0xFB, +	AMDGPU_DOORBELL64_UVD_RING0_1             = 0xF8, +	AMDGPU_DOORBELL64_UVD_RING2_3             = 0xF9, +	AMDGPU_DOORBELL64_UVD_RING4_5             = 0xFA, +	AMDGPU_DOORBELL64_UVD_RING6_7             = 0xFB, -	AMDGPU_DOORBELL64_UVD_RING0_1             = 0xFC, -	AMDGPU_DOORBELL64_UVD_RING2_3             = 0xFD, -	AMDGPU_DOORBELL64_UVD_RING4_5             = 0xFE, -	AMDGPU_DOORBELL64_UVD_RING6_7             = 0xFF, +	AMDGPU_DOORBELL64_VCE_RING0_1             = 0xFC, +	AMDGPU_DOORBELL64_VCE_RING2_3             = 0xFD, +	AMDGPU_DOORBELL64_VCE_RING4_5             = 0xFE, +	AMDGPU_DOORBELL64_VCE_RING6_7             = 0xFF,  	AMDGPU_DOORBELL64_MAX_ASSIGNMENT          = 0xFF,  	AMDGPU_DOORBELL64_INVALID                 = 0xFFFF @@ -857,6 +749,7 @@ void amdgpu_ctx_mgr_fini(struct amdgpu_ctx_mgr *mgr);  struct amdgpu_fpriv {  	struct amdgpu_vm	vm;  	struct amdgpu_bo_va	*prt_va; +	struct amdgpu_bo_va	*csa_va;  	struct mutex		bo_list_lock;  	struct idr		bo_list_handles;  	struct amdgpu_ctx_mgr	ctx_mgr; @@ -866,6 +759,14 @@ struct amdgpu_fpriv {  /*   * residency list   */ +struct amdgpu_bo_list_entry { +	struct amdgpu_bo		*robj; +	struct ttm_validate_buffer	tv; +	struct amdgpu_bo_va		*bo_va; +	uint32_t			priority; +	struct page			**user_pages; +	int				user_invalidated; +};  struct amdgpu_bo_list {  	struct mutex lock; @@ -1159,7 +1060,9 @@ struct amdgpu_cs_parser {  	struct list_head		validated;  	struct dma_fence		*fence;  	uint64_t			bytes_moved_threshold; +	uint64_t			bytes_moved_vis_threshold;  	uint64_t			bytes_moved; +	uint64_t			bytes_moved_vis;  	struct amdgpu_bo_list_entry	*evictable;  	/* user fence */ @@ -1230,8 +1133,6 @@ struct amdgpu_wb {  int amdgpu_wb_get(struct amdgpu_device *adev, u32 *wb);  void amdgpu_wb_free(struct amdgpu_device *adev, u32 wb); -int amdgpu_wb_get_64bit(struct amdgpu_device *adev, u32 *wb); -void amdgpu_wb_free_64bit(struct amdgpu_device *adev, u32 wb);  void amdgpu_get_pcie_info(struct amdgpu_device *adev); @@ -1525,7 +1426,7 @@ struct amdgpu_device {  	bool				is_atom_fw;  	uint8_t				*bios;  	uint32_t			bios_size; -	struct amdgpu_bo		*stollen_vga_memory; +	struct amdgpu_bo		*stolen_vga_memory;  	uint32_t			bios_scratch_reg_offset;  	uint32_t			bios_scratch[AMDGPU_BIOS_NUM_SCRATCH]; @@ -1557,6 +1458,10 @@ struct amdgpu_device {  	spinlock_t gc_cac_idx_lock;  	amdgpu_rreg_t			gc_cac_rreg;  	amdgpu_wreg_t			gc_cac_wreg; +	/* protects concurrent se_cac register access */ +	spinlock_t se_cac_idx_lock; +	amdgpu_rreg_t			se_cac_rreg; +	amdgpu_wreg_t			se_cac_wreg;  	/* protects concurrent ENDPOINT (audio) register access */  	spinlock_t audio_endpt_idx_lock;  	amdgpu_block_rreg_t		audio_endpt_rreg; @@ -1579,9 +1484,6 @@ struct amdgpu_device {  	struct amdgpu_mman		mman;  	struct amdgpu_vram_scratch	vram_scratch;  	struct amdgpu_wb		wb; -	atomic64_t			vram_usage; -	atomic64_t			vram_vis_usage; -	atomic64_t			gtt_usage;  	atomic64_t			num_bytes_moved;  	atomic64_t			num_evictions;  	atomic64_t			num_vram_cpu_page_faults; @@ -1593,6 +1495,7 @@ struct amdgpu_device {  		spinlock_t		lock;  		s64			last_update_us;  		s64			accum_us; /* accumulated microseconds */ +		s64			accum_us_vis; /* for visible VRAM */  		u32			log2_max_MBps;  	} mm_stats; @@ -1687,6 +1590,8 @@ struct amdgpu_device {  	bool has_hw_reset;  	u8				reset_magic[AMDGPU_RESET_MAGIC_NUM]; +	/* record last mm index being written through WREG32*/ +	unsigned long last_mm_index;  };  static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_bo_device *bdev) @@ -1742,6 +1647,8 @@ void amdgpu_mm_wdoorbell64(struct amdgpu_device *adev, u32 index, u64 v);  #define WREG32_DIDT(reg, v) adev->didt_wreg(adev, (reg), (v))  #define RREG32_GC_CAC(reg) adev->gc_cac_rreg(adev, (reg))  #define WREG32_GC_CAC(reg, v) adev->gc_cac_wreg(adev, (reg), (v)) +#define RREG32_SE_CAC(reg) adev->se_cac_rreg(adev, (reg)) +#define WREG32_SE_CAC(reg, v) adev->se_cac_wreg(adev, (reg), (v))  #define RREG32_AUDIO_ENDPT(block, reg) adev->audio_endpt_rreg(adev, (block), (reg))  #define WREG32_AUDIO_ENDPT(block, reg, v) adev->audio_endpt_wreg(adev, (block), (reg), (v))  #define WREG32_P(reg, val, mask)				\ @@ -1792,50 +1699,6 @@ void amdgpu_mm_wdoorbell64(struct amdgpu_device *adev, u32 index, u64 v);  #define RBIOS16(i) (RBIOS8(i) | (RBIOS8((i)+1) << 8))  #define RBIOS32(i) ((RBIOS16(i)) | (RBIOS16((i)+2) << 16)) -/* - * RING helpers. - */ -static inline void amdgpu_ring_write(struct amdgpu_ring *ring, uint32_t v) -{ -	if (ring->count_dw <= 0) -		DRM_ERROR("amdgpu: writing more dwords to the ring than expected!\n"); -	ring->ring[ring->wptr++ & ring->buf_mask] = v; -	ring->wptr &= ring->ptr_mask; -	ring->count_dw--; -} - -static inline void amdgpu_ring_write_multiple(struct amdgpu_ring *ring, void *src, int count_dw) -{ -	unsigned occupied, chunk1, chunk2; -	void *dst; - -	if (unlikely(ring->count_dw < count_dw)) { -		DRM_ERROR("amdgpu: writing more dwords to the ring than expected!\n"); -		return; -	} - -	occupied = ring->wptr & ring->buf_mask; -	dst = (void *)&ring->ring[occupied]; -	chunk1 = ring->buf_mask + 1 - occupied; -	chunk1 = (chunk1 >= count_dw) ? count_dw: chunk1; -	chunk2 = count_dw - chunk1; -	chunk1 <<= 2; -	chunk2 <<= 2; - -	if (chunk1) -		memcpy(dst, src, chunk1); - -	if (chunk2) { -		src += chunk1; -		dst = (void *)ring->ring; -		memcpy(dst, src, chunk2); -	} - -	ring->wptr += count_dw; -	ring->wptr &= ring->ptr_mask; -	ring->count_dw -= count_dw; -} -  static inline struct amdgpu_sdma_instance *  amdgpu_get_sdma_instance(struct amdgpu_ring *ring)  { @@ -1898,7 +1761,6 @@ amdgpu_get_sdma_instance(struct amdgpu_ring *ring)  #define amdgpu_ih_get_wptr(adev) (adev)->irq.ih_funcs->get_wptr((adev))  #define amdgpu_ih_decode_iv(adev, iv) (adev)->irq.ih_funcs->decode_iv((adev), (iv))  #define amdgpu_ih_set_rptr(adev) (adev)->irq.ih_funcs->set_rptr((adev)) -#define amdgpu_display_set_vga_render_state(adev, r) (adev)->mode_info.funcs->set_vga_render_state((adev), (r))  #define amdgpu_display_vblank_get_counter(adev, crtc) (adev)->mode_info.funcs->vblank_get_counter((adev), (crtc))  #define amdgpu_display_vblank_wait(adev, crtc) (adev)->mode_info.funcs->vblank_wait((adev), (crtc))  #define amdgpu_display_backlight_set_level(adev, e, l) (adev)->mode_info.funcs->backlight_set_level((e), (l)) @@ -1911,8 +1773,6 @@ amdgpu_get_sdma_instance(struct amdgpu_ring *ring)  #define amdgpu_display_page_flip_get_scanoutpos(adev, crtc, vbl, pos) (adev)->mode_info.funcs->page_flip_get_scanoutpos((adev), (crtc), (vbl), (pos))  #define amdgpu_display_add_encoder(adev, e, s, c) (adev)->mode_info.funcs->add_encoder((adev), (e), (s), (c))  #define amdgpu_display_add_connector(adev, ci, sd, ct, ib, coi, h, r) (adev)->mode_info.funcs->add_connector((adev), (ci), (sd), (ct), (ib), (coi), (h), (r)) -#define amdgpu_display_stop_mc_access(adev, s) (adev)->mode_info.funcs->stop_mc_access((adev), (s)) -#define amdgpu_display_resume_mc_access(adev, s) (adev)->mode_info.funcs->resume_mc_access((adev), (s))  #define amdgpu_emit_copy_buffer(adev, ib, s, d, b) (adev)->mman.buffer_funcs->emit_copy_buffer((ib),  (s), (d), (b))  #define amdgpu_emit_fill_buffer(adev, ib, s, d, b) (adev)->mman.buffer_funcs->emit_fill_buffer((ib), (s), (d), (b))  #define amdgpu_gfx_get_gpu_clock_counter(adev) (adev)->gfx.funcs->get_gpu_clock_counter((adev)) @@ -1927,7 +1787,8 @@ void amdgpu_pci_config_reset(struct amdgpu_device *adev);  bool amdgpu_need_post(struct amdgpu_device *adev);  void amdgpu_update_display_priority(struct amdgpu_device *adev); -void amdgpu_cs_report_moved_bytes(struct amdgpu_device *adev, u64 num_bytes); +void amdgpu_cs_report_moved_bytes(struct amdgpu_device *adev, u64 num_bytes, +				  u64 num_vis_bytes);  void amdgpu_ttm_placement_from_domain(struct amdgpu_bo *abo, u32 domain);  bool amdgpu_ttm_bo_is_amdgpu_bo(struct ttm_buffer_object *bo);  int amdgpu_ttm_tt_get_user_pages(struct ttm_tt *ttm, struct page **pages); @@ -1943,7 +1804,7 @@ bool amdgpu_ttm_tt_is_readonly(struct ttm_tt *ttm);  uint64_t amdgpu_ttm_tt_pte_flags(struct amdgpu_device *adev, struct ttm_tt *ttm,  				 struct ttm_mem_reg *mem);  void amdgpu_vram_location(struct amdgpu_device *adev, struct amdgpu_mc *mc, u64 base); -void amdgpu_gtt_location(struct amdgpu_device *adev, struct amdgpu_mc *mc); +void amdgpu_gart_location(struct amdgpu_device *adev, struct amdgpu_mc *mc);  void amdgpu_ttm_set_active_vram_size(struct amdgpu_device *adev, u64 size);  int amdgpu_ttm_init(struct amdgpu_device *adev);  void amdgpu_ttm_fini(struct amdgpu_device *adev); |