drm/radeon/kms: add radeon_asic struct for AMD Ontario fusion APUs
Signed-off-by: Alex Deucher <alexdeucher@gmail.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
parent
180074010c
commit
958261d1e8
@ -751,6 +751,49 @@ static struct radeon_asic evergreen_asic = {
|
|||||||
.pm_get_dynpm_state = &r600_pm_get_dynpm_state,
|
.pm_get_dynpm_state = &r600_pm_get_dynpm_state,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct radeon_asic sumo_asic = {
|
||||||
|
.init = &evergreen_init,
|
||||||
|
.fini = &evergreen_fini,
|
||||||
|
.suspend = &evergreen_suspend,
|
||||||
|
.resume = &evergreen_resume,
|
||||||
|
.cp_commit = &r600_cp_commit,
|
||||||
|
.gpu_is_lockup = &evergreen_gpu_is_lockup,
|
||||||
|
.asic_reset = &evergreen_asic_reset,
|
||||||
|
.vga_set_state = &r600_vga_set_state,
|
||||||
|
.gart_tlb_flush = &evergreen_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 = &evergreen_irq_set,
|
||||||
|
.irq_process = &evergreen_irq_process,
|
||||||
|
.get_vblank_counter = &evergreen_get_vblank_counter,
|
||||||
|
.fence_ring_emit = &r600_fence_ring_emit,
|
||||||
|
.cs_parse = &evergreen_cs_parse,
|
||||||
|
.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 = NULL,
|
||||||
|
.set_memory_clock = NULL,
|
||||||
|
.get_pcie_lanes = NULL,
|
||||||
|
.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,
|
||||||
|
.gui_idle = &r600_gui_idle,
|
||||||
|
.pm_misc = &evergreen_pm_misc,
|
||||||
|
.pm_prepare = &evergreen_pm_prepare,
|
||||||
|
.pm_finish = &evergreen_pm_finish,
|
||||||
|
.pm_init_profile = &rs780_pm_init_profile,
|
||||||
|
.pm_get_dynpm_state = &r600_pm_get_dynpm_state,
|
||||||
|
};
|
||||||
|
|
||||||
int radeon_asic_init(struct radeon_device *rdev)
|
int radeon_asic_init(struct radeon_device *rdev)
|
||||||
{
|
{
|
||||||
radeon_register_accessor_init(rdev);
|
radeon_register_accessor_init(rdev);
|
||||||
@ -835,6 +878,9 @@ int radeon_asic_init(struct radeon_device *rdev)
|
|||||||
case CHIP_HEMLOCK:
|
case CHIP_HEMLOCK:
|
||||||
rdev->asic = &evergreen_asic;
|
rdev->asic = &evergreen_asic;
|
||||||
break;
|
break;
|
||||||
|
case CHIP_PALM:
|
||||||
|
rdev->asic = &sumo_asic;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
/* FIXME: not supported yet */
|
/* FIXME: not supported yet */
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
Loading…
Reference in New Issue
Block a user