diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2010-05-10 11:59:37 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2010-05-10 14:20:42 +0200 | 
| commit | dbb6be6d5e974c42bbecd183effaa0df69e1dd8b (patch) | |
| tree | 5735cb47e70853d057a9881dd0ce44b83e88fa63 /drivers/gpu/drm/radeon/radeon_asic.h | |
| parent | 6a867a395558a7f882d041783e4cdea6744ca2bf (diff) | |
| parent | b57f95a38233a2e73b679bea4a5453a1cc2a1cc9 (diff) | |
| download | olio-linux-3.10-dbb6be6d5e974c42bbecd183effaa0df69e1dd8b.tar.xz olio-linux-3.10-dbb6be6d5e974c42bbecd183effaa0df69e1dd8b.zip  | |
Merge branch 'linus' into timers/core
Reason: Further posix_cpu_timer patches depend on mainline changes
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'drivers/gpu/drm/radeon/radeon_asic.h')
| -rw-r--r-- | drivers/gpu/drm/radeon/radeon_asic.h | 545 | 
1 files changed, 50 insertions, 495 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_asic.h b/drivers/gpu/drm/radeon/radeon_asic.h index d3a157b2bcb..a0b8280663d 100644 --- a/drivers/gpu/drm/radeon/radeon_asic.h +++ b/drivers/gpu/drm/radeon/radeon_asic.h @@ -45,10 +45,18 @@ void radeon_atom_set_clock_gating(struct radeon_device *rdev, int enable);  /*   * r100,rv100,rs100,rv200,rs200   */ -extern int r100_init(struct radeon_device *rdev); -extern void r100_fini(struct radeon_device *rdev); -extern int r100_suspend(struct radeon_device *rdev); -extern int r100_resume(struct radeon_device *rdev); +struct r100_mc_save { +	u32	GENMO_WT; +	u32	CRTC_EXT_CNTL; +	u32	CRTC_GEN_CNTL; +	u32	CRTC2_GEN_CNTL; +	u32	CUR_OFFSET; +	u32	CUR2_OFFSET; +}; +int r100_init(struct radeon_device *rdev); +void r100_fini(struct radeon_device *rdev); +int r100_suspend(struct radeon_device *rdev); +int r100_resume(struct radeon_device *rdev);  uint32_t r100_mm_rreg(struct radeon_device *rdev, uint32_t reg);  void r100_mm_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v);  void r100_vga_set_state(struct radeon_device *rdev, bool state); @@ -73,7 +81,7 @@ int r100_copy_blit(struct radeon_device *rdev,  int r100_set_surface_reg(struct radeon_device *rdev, int reg,  			 uint32_t tiling_flags, uint32_t pitch,  			 uint32_t offset, uint32_t obj_size); -int r100_clear_surface_reg(struct radeon_device *rdev, int reg); +void r100_clear_surface_reg(struct radeon_device *rdev, int reg);  void r100_bandwidth_update(struct radeon_device *rdev);  void r100_ring_ib_execute(struct radeon_device *rdev, struct radeon_ib *ib);  int r100_ring_test(struct radeon_device *rdev); @@ -82,44 +90,42 @@ void r100_hpd_fini(struct radeon_device *rdev);  bool r100_hpd_sense(struct radeon_device *rdev, enum radeon_hpd_id hpd);  void r100_hpd_set_polarity(struct radeon_device *rdev,  			   enum radeon_hpd_id hpd); - -static struct radeon_asic r100_asic = { -	.init = &r100_init, -	.fini = &r100_fini, -	.suspend = &r100_suspend, -	.resume = &r100_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r100_gpu_reset, -	.gart_tlb_flush = &r100_pci_gart_tlb_flush, -	.gart_set_page = &r100_pci_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r100_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &r100_irq_set, -	.irq_process = &r100_irq_process, -	.get_vblank_counter = &r100_get_vblank_counter, -	.fence_ring_emit = &r100_fence_ring_emit, -	.cs_parse = &r100_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = NULL, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_legacy_get_engine_clock, -	.set_engine_clock = &radeon_legacy_set_engine_clock, -	.get_memory_clock = &radeon_legacy_get_memory_clock, -	.set_memory_clock = NULL, -	.get_pcie_lanes = NULL, -	.set_pcie_lanes = NULL, -	.set_clock_gating = &radeon_legacy_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &r100_bandwidth_update, -	.hpd_init = &r100_hpd_init, -	.hpd_fini = &r100_hpd_fini, -	.hpd_sense = &r100_hpd_sense, -	.hpd_set_polarity = &r100_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; +int r100_debugfs_rbbm_init(struct radeon_device *rdev); +int r100_debugfs_cp_init(struct radeon_device *rdev); +void r100_cp_disable(struct radeon_device *rdev); +int r100_cp_init(struct radeon_device *rdev, unsigned ring_size); +void r100_cp_fini(struct radeon_device *rdev); +int r100_pci_gart_init(struct radeon_device *rdev); +void r100_pci_gart_fini(struct radeon_device *rdev); +int r100_pci_gart_enable(struct radeon_device *rdev); +void r100_pci_gart_disable(struct radeon_device *rdev); +int r100_debugfs_mc_info_init(struct radeon_device *rdev); +int r100_gui_wait_for_idle(struct radeon_device *rdev); +void r100_ib_fini(struct radeon_device *rdev); +int r100_ib_init(struct radeon_device *rdev); +void r100_irq_disable(struct radeon_device *rdev); +void r100_mc_stop(struct radeon_device *rdev, struct r100_mc_save *save); +void r100_mc_resume(struct radeon_device *rdev, struct r100_mc_save *save); +void r100_vram_init_sizes(struct radeon_device *rdev); +void r100_wb_disable(struct radeon_device *rdev); +void r100_wb_fini(struct radeon_device *rdev); +int r100_wb_init(struct radeon_device *rdev); +void r100_hdp_reset(struct radeon_device *rdev); +int r100_rb2d_reset(struct radeon_device *rdev); +int r100_cp_reset(struct radeon_device *rdev); +void r100_vga_render_disable(struct radeon_device *rdev); +int r100_cs_track_check_pkt3_indx_buffer(struct radeon_cs_parser *p, +					 struct radeon_cs_packet *pkt, +					 struct radeon_bo *robj); +int r100_cs_parse_packet0(struct radeon_cs_parser *p, +			  struct radeon_cs_packet *pkt, +			  const unsigned *auth, unsigned n, +			  radeon_packet0_check_t check); +int r100_cs_packet_parse(struct radeon_cs_parser *p, +			 struct radeon_cs_packet *pkt, +			 unsigned idx); +void r100_enable_bm(struct radeon_device *rdev); +void r100_set_common_regs(struct radeon_device *rdev);  /*   * r200,rv250,rs300,rv280 @@ -129,43 +135,6 @@ extern int r200_copy_dma(struct radeon_device *rdev,  			uint64_t dst_offset,  			unsigned num_pages,  			struct radeon_fence *fence); -static struct radeon_asic r200_asic = { -	.init = &r100_init, -	.fini = &r100_fini, -	.suspend = &r100_suspend, -	.resume = &r100_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r100_gpu_reset, -	.gart_tlb_flush = &r100_pci_gart_tlb_flush, -	.gart_set_page = &r100_pci_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r100_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &r100_irq_set, -	.irq_process = &r100_irq_process, -	.get_vblank_counter = &r100_get_vblank_counter, -	.fence_ring_emit = &r100_fence_ring_emit, -	.cs_parse = &r100_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_legacy_get_engine_clock, -	.set_engine_clock = &radeon_legacy_set_engine_clock, -	.get_memory_clock = &radeon_legacy_get_memory_clock, -	.set_memory_clock = NULL, -	.set_pcie_lanes = NULL, -	.set_clock_gating = &radeon_legacy_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &r100_bandwidth_update, -	.hpd_init = &r100_hpd_init, -	.hpd_fini = &r100_hpd_fini, -	.hpd_sense = &r100_hpd_sense, -	.hpd_set_polarity = &r100_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; -  /*   * r300,r350,rv350,rv380 @@ -186,82 +155,6 @@ extern void rv370_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v  extern void rv370_set_pcie_lanes(struct radeon_device *rdev, int lanes);  extern int rv370_get_pcie_lanes(struct radeon_device *rdev); -static struct radeon_asic r300_asic = { -	.init = &r300_init, -	.fini = &r300_fini, -	.suspend = &r300_suspend, -	.resume = &r300_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r300_gpu_reset, -	.gart_tlb_flush = &r100_pci_gart_tlb_flush, -	.gart_set_page = &r100_pci_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r300_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &r100_irq_set, -	.irq_process = &r100_irq_process, -	.get_vblank_counter = &r100_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_legacy_get_engine_clock, -	.set_engine_clock = &radeon_legacy_set_engine_clock, -	.get_memory_clock = &radeon_legacy_get_memory_clock, -	.set_memory_clock = NULL, -	.get_pcie_lanes = &rv370_get_pcie_lanes, -	.set_pcie_lanes = &rv370_set_pcie_lanes, -	.set_clock_gating = &radeon_legacy_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &r100_bandwidth_update, -	.hpd_init = &r100_hpd_init, -	.hpd_fini = &r100_hpd_fini, -	.hpd_sense = &r100_hpd_sense, -	.hpd_set_polarity = &r100_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; - - -static struct radeon_asic r300_asic_pcie = { -	.init = &r300_init, -	.fini = &r300_fini, -	.suspend = &r300_suspend, -	.resume = &r300_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r300_gpu_reset, -	.gart_tlb_flush = &rv370_pcie_gart_tlb_flush, -	.gart_set_page = &rv370_pcie_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r300_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &r100_irq_set, -	.irq_process = &r100_irq_process, -	.get_vblank_counter = &r100_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_legacy_get_engine_clock, -	.set_engine_clock = &radeon_legacy_set_engine_clock, -	.get_memory_clock = &radeon_legacy_get_memory_clock, -	.set_memory_clock = NULL, -	.set_pcie_lanes = &rv370_set_pcie_lanes, -	.set_clock_gating = &radeon_legacy_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &r100_bandwidth_update, -	.hpd_init = &r100_hpd_init, -	.hpd_fini = &r100_hpd_fini, -	.hpd_sense = &r100_hpd_sense, -	.hpd_set_polarity = &r100_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; -  /*   * r420,r423,rv410   */ @@ -269,44 +162,6 @@ extern int r420_init(struct radeon_device *rdev);  extern void r420_fini(struct radeon_device *rdev);  extern int r420_suspend(struct radeon_device *rdev);  extern int r420_resume(struct radeon_device *rdev); -static struct radeon_asic r420_asic = { -	.init = &r420_init, -	.fini = &r420_fini, -	.suspend = &r420_suspend, -	.resume = &r420_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r300_gpu_reset, -	.gart_tlb_flush = &rv370_pcie_gart_tlb_flush, -	.gart_set_page = &rv370_pcie_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r300_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &r100_irq_set, -	.irq_process = &r100_irq_process, -	.get_vblank_counter = &r100_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.get_pcie_lanes = &rv370_get_pcie_lanes, -	.set_pcie_lanes = &rv370_set_pcie_lanes, -	.set_clock_gating = &radeon_atom_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &r100_bandwidth_update, -	.hpd_init = &r100_hpd_init, -	.hpd_fini = &r100_hpd_fini, -	.hpd_sense = &r100_hpd_sense, -	.hpd_set_polarity = &r100_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; -  /*   * rs400,rs480 @@ -319,44 +174,6 @@ void rs400_gart_tlb_flush(struct radeon_device *rdev);  int rs400_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr);  uint32_t rs400_mc_rreg(struct radeon_device *rdev, uint32_t reg);  void rs400_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); -static struct radeon_asic rs400_asic = { -	.init = &rs400_init, -	.fini = &rs400_fini, -	.suspend = &rs400_suspend, -	.resume = &rs400_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r300_gpu_reset, -	.gart_tlb_flush = &rs400_gart_tlb_flush, -	.gart_set_page = &rs400_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r300_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &r100_irq_set, -	.irq_process = &r100_irq_process, -	.get_vblank_counter = &r100_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_legacy_get_engine_clock, -	.set_engine_clock = &radeon_legacy_set_engine_clock, -	.get_memory_clock = &radeon_legacy_get_memory_clock, -	.set_memory_clock = NULL, -	.get_pcie_lanes = NULL, -	.set_pcie_lanes = NULL, -	.set_clock_gating = &radeon_legacy_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &r100_bandwidth_update, -	.hpd_init = &r100_hpd_init, -	.hpd_fini = &r100_hpd_fini, -	.hpd_sense = &r100_hpd_sense, -	.hpd_set_polarity = &r100_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; -  /*   * rs600. @@ -379,45 +196,6 @@ bool rs600_hpd_sense(struct radeon_device *rdev, enum radeon_hpd_id hpd);  void rs600_hpd_set_polarity(struct radeon_device *rdev,  			    enum radeon_hpd_id hpd); -static struct radeon_asic rs600_asic = { -	.init = &rs600_init, -	.fini = &rs600_fini, -	.suspend = &rs600_suspend, -	.resume = &rs600_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r300_gpu_reset, -	.gart_tlb_flush = &rs600_gart_tlb_flush, -	.gart_set_page = &rs600_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r300_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &rs600_irq_set, -	.irq_process = &rs600_irq_process, -	.get_vblank_counter = &rs600_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.get_pcie_lanes = NULL, -	.set_pcie_lanes = NULL, -	.set_clock_gating = &radeon_atom_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &rs600_bandwidth_update, -	.hpd_init = &rs600_hpd_init, -	.hpd_fini = &rs600_hpd_fini, -	.hpd_sense = &rs600_hpd_sense, -	.hpd_set_polarity = &rs600_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; - -  /*   * rs690,rs740   */ @@ -428,44 +206,6 @@ int rs690_suspend(struct radeon_device *rdev);  uint32_t rs690_mc_rreg(struct radeon_device *rdev, uint32_t reg);  void rs690_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v);  void rs690_bandwidth_update(struct radeon_device *rdev); -static struct radeon_asic rs690_asic = { -	.init = &rs690_init, -	.fini = &rs690_fini, -	.suspend = &rs690_suspend, -	.resume = &rs690_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &r300_gpu_reset, -	.gart_tlb_flush = &rs400_gart_tlb_flush, -	.gart_set_page = &rs400_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &r300_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &rs600_irq_set, -	.irq_process = &rs600_irq_process, -	.get_vblank_counter = &rs600_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r200_copy_dma, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.get_pcie_lanes = NULL, -	.set_pcie_lanes = NULL, -	.set_clock_gating = &radeon_atom_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &rs690_bandwidth_update, -	.hpd_init = &rs600_hpd_init, -	.hpd_fini = &rs600_hpd_fini, -	.hpd_sense = &rs600_hpd_sense, -	.hpd_set_polarity = &rs600_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; -  /*   * rv515 @@ -481,87 +221,12 @@ void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v);  void rv515_bandwidth_update(struct radeon_device *rdev);  int rv515_resume(struct radeon_device *rdev);  int rv515_suspend(struct radeon_device *rdev); -static struct radeon_asic rv515_asic = { -	.init = &rv515_init, -	.fini = &rv515_fini, -	.suspend = &rv515_suspend, -	.resume = &rv515_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &rv515_gpu_reset, -	.gart_tlb_flush = &rv370_pcie_gart_tlb_flush, -	.gart_set_page = &rv370_pcie_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &rv515_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &rs600_irq_set, -	.irq_process = &rs600_irq_process, -	.get_vblank_counter = &rs600_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.get_pcie_lanes = &rv370_get_pcie_lanes, -	.set_pcie_lanes = &rv370_set_pcie_lanes, -	.set_clock_gating = &radeon_atom_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &rv515_bandwidth_update, -	.hpd_init = &rs600_hpd_init, -	.hpd_fini = &rs600_hpd_fini, -	.hpd_sense = &rs600_hpd_sense, -	.hpd_set_polarity = &rs600_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -}; -  /*   * r520,rv530,rv560,rv570,r580   */  int r520_init(struct radeon_device *rdev);  int r520_resume(struct radeon_device *rdev); -static struct radeon_asic r520_asic = { -	.init = &r520_init, -	.fini = &rv515_fini, -	.suspend = &rv515_suspend, -	.resume = &r520_resume, -	.vga_set_state = &r100_vga_set_state, -	.gpu_reset = &rv515_gpu_reset, -	.gart_tlb_flush = &rv370_pcie_gart_tlb_flush, -	.gart_set_page = &rv370_pcie_gart_set_page, -	.cp_commit = &r100_cp_commit, -	.ring_start = &rv515_ring_start, -	.ring_test = &r100_ring_test, -	.ring_ib_execute = &r100_ring_ib_execute, -	.irq_set = &rs600_irq_set, -	.irq_process = &rs600_irq_process, -	.get_vblank_counter = &rs600_get_vblank_counter, -	.fence_ring_emit = &r300_fence_ring_emit, -	.cs_parse = &r300_cs_parse, -	.copy_blit = &r100_copy_blit, -	.copy_dma = &r200_copy_dma, -	.copy = &r100_copy_blit, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.get_pcie_lanes = &rv370_get_pcie_lanes, -	.set_pcie_lanes = &rv370_set_pcie_lanes, -	.set_clock_gating = &radeon_atom_set_clock_gating, -	.set_surface_reg = r100_set_surface_reg, -	.clear_surface_reg = r100_clear_surface_reg, -	.bandwidth_update = &rv515_bandwidth_update, -	.hpd_init = &rs600_hpd_init, -	.hpd_fini = &rs600_hpd_fini, -	.hpd_sense = &rs600_hpd_sense, -	.hpd_set_polarity = &rs600_hpd_set_polarity, -	.ioctl_wait_idle = NULL, -};  /*   * r600,rv610,rv630,rv620,rv635,rv670,rs780,rs880 @@ -591,7 +256,7 @@ int r600_gpu_reset(struct radeon_device *rdev);  int r600_set_surface_reg(struct radeon_device *rdev, int reg,  			 uint32_t tiling_flags, uint32_t pitch,  			 uint32_t offset, uint32_t obj_size); -int r600_clear_surface_reg(struct radeon_device *rdev, int reg); +void r600_clear_surface_reg(struct radeon_device *rdev, int reg);  void r600_ring_ib_execute(struct radeon_device *rdev, struct radeon_ib *ib);  int r600_ring_test(struct radeon_device *rdev);  int r600_copy_blit(struct radeon_device *rdev, @@ -604,43 +269,6 @@ void r600_hpd_set_polarity(struct radeon_device *rdev,  			   enum radeon_hpd_id hpd);  extern void r600_ioctl_wait_idle(struct radeon_device *rdev, struct radeon_bo *bo); -static struct radeon_asic r600_asic = { -	.init = &r600_init, -	.fini = &r600_fini, -	.suspend = &r600_suspend, -	.resume = &r600_resume, -	.cp_commit = &r600_cp_commit, -	.vga_set_state = &r600_vga_set_state, -	.gpu_reset = &r600_gpu_reset, -	.gart_tlb_flush = &r600_pcie_gart_tlb_flush, -	.gart_set_page = &rs600_gart_set_page, -	.ring_test = &r600_ring_test, -	.ring_ib_execute = &r600_ring_ib_execute, -	.irq_set = &r600_irq_set, -	.irq_process = &r600_irq_process, -	.get_vblank_counter = &rs600_get_vblank_counter, -	.fence_ring_emit = &r600_fence_ring_emit, -	.cs_parse = &r600_cs_parse, -	.copy_blit = &r600_copy_blit, -	.copy_dma = &r600_copy_blit, -	.copy = &r600_copy_blit, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.get_pcie_lanes = &rv370_get_pcie_lanes, -	.set_pcie_lanes = NULL, -	.set_clock_gating = NULL, -	.set_surface_reg = r600_set_surface_reg, -	.clear_surface_reg = r600_clear_surface_reg, -	.bandwidth_update = &rv515_bandwidth_update, -	.hpd_init = &r600_hpd_init, -	.hpd_fini = &r600_hpd_fini, -	.hpd_sense = &r600_hpd_sense, -	.hpd_set_polarity = &r600_hpd_set_polarity, -	.ioctl_wait_idle = r600_ioctl_wait_idle, -}; -  /*   * rv770,rv730,rv710,rv740   */ @@ -650,43 +278,6 @@ int rv770_suspend(struct radeon_device *rdev);  int rv770_resume(struct radeon_device *rdev);  int rv770_gpu_reset(struct radeon_device *rdev); -static struct radeon_asic rv770_asic = { -	.init = &rv770_init, -	.fini = &rv770_fini, -	.suspend = &rv770_suspend, -	.resume = &rv770_resume, -	.cp_commit = &r600_cp_commit, -	.gpu_reset = &rv770_gpu_reset, -	.vga_set_state = &r600_vga_set_state, -	.gart_tlb_flush = &r600_pcie_gart_tlb_flush, -	.gart_set_page = &rs600_gart_set_page, -	.ring_test = &r600_ring_test, -	.ring_ib_execute = &r600_ring_ib_execute, -	.irq_set = &r600_irq_set, -	.irq_process = &r600_irq_process, -	.get_vblank_counter = &rs600_get_vblank_counter, -	.fence_ring_emit = &r600_fence_ring_emit, -	.cs_parse = &r600_cs_parse, -	.copy_blit = &r600_copy_blit, -	.copy_dma = &r600_copy_blit, -	.copy = &r600_copy_blit, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.get_pcie_lanes = &rv370_get_pcie_lanes, -	.set_pcie_lanes = NULL, -	.set_clock_gating = &radeon_atom_set_clock_gating, -	.set_surface_reg = r600_set_surface_reg, -	.clear_surface_reg = r600_clear_surface_reg, -	.bandwidth_update = &rv515_bandwidth_update, -	.hpd_init = &r600_hpd_init, -	.hpd_fini = &r600_hpd_fini, -	.hpd_sense = &r600_hpd_sense, -	.hpd_set_polarity = &r600_hpd_set_polarity, -	.ioctl_wait_idle = r600_ioctl_wait_idle, -}; -  /*   * evergreen   */ @@ -701,40 +292,4 @@ void evergreen_hpd_fini(struct radeon_device *rdev);  bool evergreen_hpd_sense(struct radeon_device *rdev, enum radeon_hpd_id hpd);  void evergreen_hpd_set_polarity(struct radeon_device *rdev,  				enum radeon_hpd_id hpd); - -static struct radeon_asic evergreen_asic = { -	.init = &evergreen_init, -	.fini = &evergreen_fini, -	.suspend = &evergreen_suspend, -	.resume = &evergreen_resume, -	.cp_commit = NULL, -	.gpu_reset = &evergreen_gpu_reset, -	.vga_set_state = &r600_vga_set_state, -	.gart_tlb_flush = &r600_pcie_gart_tlb_flush, -	.gart_set_page = &rs600_gart_set_page, -	.ring_test = NULL, -	.ring_ib_execute = NULL, -	.irq_set = NULL, -	.irq_process = NULL, -	.get_vblank_counter = NULL, -	.fence_ring_emit = NULL, -	.cs_parse = NULL, -	.copy_blit = NULL, -	.copy_dma = NULL, -	.copy = NULL, -	.get_engine_clock = &radeon_atom_get_engine_clock, -	.set_engine_clock = &radeon_atom_set_engine_clock, -	.get_memory_clock = &radeon_atom_get_memory_clock, -	.set_memory_clock = &radeon_atom_set_memory_clock, -	.set_pcie_lanes = NULL, -	.set_clock_gating = NULL, -	.set_surface_reg = r600_set_surface_reg, -	.clear_surface_reg = r600_clear_surface_reg, -	.bandwidth_update = &evergreen_bandwidth_update, -	.hpd_init = &evergreen_hpd_init, -	.hpd_fini = &evergreen_hpd_fini, -	.hpd_sense = &evergreen_hpd_sense, -	.hpd_set_polarity = &evergreen_hpd_set_polarity, -}; -  #endif  |