Lines Matching refs:rdev

63 	struct radeon_device *rdev = dev->dev_private;  in radeon_driver_unload_kms()  local
65 if (rdev == NULL) in radeon_driver_unload_kms()
68 if (rdev->rmmio == NULL) in radeon_driver_unload_kms()
76 radeon_acpi_fini(rdev); in radeon_driver_unload_kms()
78 radeon_modeset_fini(rdev); in radeon_driver_unload_kms()
79 radeon_device_fini(rdev); in radeon_driver_unload_kms()
81 if (rdev->agp) in radeon_driver_unload_kms()
82 arch_phys_wc_del(rdev->agp->agp_mtrr); in radeon_driver_unload_kms()
83 kfree(rdev->agp); in radeon_driver_unload_kms()
84 rdev->agp = NULL; in radeon_driver_unload_kms()
87 kfree(rdev); in radeon_driver_unload_kms()
107 struct radeon_device *rdev; in radeon_driver_load_kms() local
110 rdev = kzalloc(sizeof(struct radeon_device), GFP_KERNEL); in radeon_driver_load_kms()
111 if (rdev == NULL) { in radeon_driver_load_kms()
114 dev->dev_private = (void *)rdev; in radeon_driver_load_kms()
117 rdev->hose = pdev->sysdata; in radeon_driver_load_kms()
121 rdev->agp = radeon_agp_head_init(dev); in radeon_driver_load_kms()
122 if (rdev->agp) { in radeon_driver_load_kms()
123 rdev->agp->agp_mtrr = arch_phys_wc_add( in radeon_driver_load_kms()
124 rdev->agp->agp_info.aper_base, in radeon_driver_load_kms()
125 rdev->agp->agp_info.aper_size * in radeon_driver_load_kms()
150 r = radeon_device_init(rdev, dev, pdev, flags); in radeon_driver_load_kms()
160 r = radeon_modeset_init(rdev); in radeon_driver_load_kms()
168 acpi_status = radeon_acpi_init(rdev); in radeon_driver_load_kms()
206 struct radeon_device *rdev = dev->dev_private; in radeon_set_filp_rights() local
208 mutex_lock(&rdev->gem.mutex); in radeon_set_filp_rights()
219 mutex_unlock(&rdev->gem.mutex); in radeon_set_filp_rights()
239 struct radeon_device *rdev = dev->dev_private; in radeon_info_ioctl() local
241 struct radeon_mode_info *minfo = &rdev->mode_info; in radeon_info_ioctl()
257 *value = rdev->num_gb_pipes; in radeon_info_ioctl()
260 *value = rdev->num_z_pipes; in radeon_info_ioctl()
264 if ((rdev->family >= CHIP_CEDAR) && (rdev->family <= CHIP_HEMLOCK)) in radeon_info_ioctl()
267 *value = rdev->accel_working; in radeon_info_ioctl()
274 for (i = 0, found = 0; i < rdev->num_crtc; i++) { in radeon_info_ioctl()
289 if (rdev->family == CHIP_HAWAII) { in radeon_info_ioctl()
290 if (rdev->accel_working) { in radeon_info_ioctl()
291 if (rdev->new_fw) in radeon_info_ioctl()
299 *value = rdev->accel_working; in radeon_info_ioctl()
303 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
304 *value = rdev->config.cik.tile_config; in radeon_info_ioctl()
305 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
306 *value = rdev->config.si.tile_config; in radeon_info_ioctl()
307 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
308 *value = rdev->config.cayman.tile_config; in radeon_info_ioctl()
309 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
310 *value = rdev->config.evergreen.tile_config; in radeon_info_ioctl()
311 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
312 *value = rdev->config.rv770.tile_config; in radeon_info_ioctl()
313 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
314 *value = rdev->config.r600.tile_config; in radeon_info_ioctl()
335 radeon_set_filp_rights(dev, &rdev->hyperz_filp, filp, value); in radeon_info_ioctl()
347 radeon_set_filp_rights(dev, &rdev->cmask_filp, filp, value); in radeon_info_ioctl()
351 if (rdev->asic->get_xclk) in radeon_info_ioctl()
352 *value = radeon_get_xclk(rdev) * 10; in radeon_info_ioctl()
354 *value = rdev->clock.spll.reference_freq * 10; in radeon_info_ioctl()
357 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
358 *value = rdev->config.cik.max_backends_per_se * in radeon_info_ioctl()
359 rdev->config.cik.max_shader_engines; in radeon_info_ioctl()
360 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
361 *value = rdev->config.si.max_backends_per_se * in radeon_info_ioctl()
362 rdev->config.si.max_shader_engines; in radeon_info_ioctl()
363 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
364 *value = rdev->config.cayman.max_backends_per_se * in radeon_info_ioctl()
365 rdev->config.cayman.max_shader_engines; in radeon_info_ioctl()
366 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
367 *value = rdev->config.evergreen.max_backends; in radeon_info_ioctl()
368 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
369 *value = rdev->config.rv770.max_backends; in radeon_info_ioctl()
370 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
371 *value = rdev->config.r600.max_backends; in radeon_info_ioctl()
377 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
378 *value = rdev->config.cik.max_tile_pipes; in radeon_info_ioctl()
379 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
380 *value = rdev->config.si.max_tile_pipes; in radeon_info_ioctl()
381 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
382 *value = rdev->config.cayman.max_tile_pipes; in radeon_info_ioctl()
383 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
384 *value = rdev->config.evergreen.max_tile_pipes; in radeon_info_ioctl()
385 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
386 *value = rdev->config.rv770.max_tile_pipes; in radeon_info_ioctl()
387 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
388 *value = rdev->config.r600.max_tile_pipes; in radeon_info_ioctl()
397 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
398 *value = rdev->config.cik.backend_map; in radeon_info_ioctl()
399 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
400 *value = rdev->config.si.backend_map; in radeon_info_ioctl()
401 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
402 *value = rdev->config.cayman.backend_map; in radeon_info_ioctl()
403 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
404 *value = rdev->config.evergreen.backend_map; in radeon_info_ioctl()
405 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
406 *value = rdev->config.rv770.backend_map; in radeon_info_ioctl()
407 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
408 *value = rdev->config.r600.backend_map; in radeon_info_ioctl()
415 if (rdev->family < CHIP_CAYMAN) in radeon_info_ioctl()
421 if (rdev->family < CHIP_CAYMAN) in radeon_info_ioctl()
426 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
427 *value = rdev->config.cik.max_cu_per_sh; in radeon_info_ioctl()
428 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
429 *value = rdev->config.si.max_cu_per_sh; in radeon_info_ioctl()
430 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
431 *value = rdev->config.cayman.max_pipes_per_simd; in radeon_info_ioctl()
432 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
433 *value = rdev->config.evergreen.max_pipes; in radeon_info_ioctl()
434 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
435 *value = rdev->config.rv770.max_pipes; in radeon_info_ioctl()
436 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
437 *value = rdev->config.r600.max_pipes; in radeon_info_ioctl()
443 if (rdev->family < CHIP_R600) { in radeon_info_ioctl()
449 value64 = radeon_get_gpu_clock_counter(rdev); in radeon_info_ioctl()
452 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
453 *value = rdev->config.cik.max_shader_engines; in radeon_info_ioctl()
454 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
455 *value = rdev->config.si.max_shader_engines; in radeon_info_ioctl()
456 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
457 *value = rdev->config.cayman.max_shader_engines; in radeon_info_ioctl()
458 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
459 *value = rdev->config.evergreen.num_ses; in radeon_info_ioctl()
464 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
465 *value = rdev->config.cik.max_sh_per_se; in radeon_info_ioctl()
466 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
467 *value = rdev->config.si.max_sh_per_se; in radeon_info_ioctl()
472 *value = rdev->fastfb_working; in radeon_info_ioctl()
482 *value = rdev->ring[RADEON_RING_TYPE_GFX_INDEX].ready; in radeon_info_ioctl()
485 *value = rdev->ring[R600_RING_TYPE_DMA_INDEX].ready; in radeon_info_ioctl()
486 *value |= rdev->ring[CAYMAN_RING_TYPE_DMA1_INDEX].ready; in radeon_info_ioctl()
489 *value = rdev->ring[R600_RING_TYPE_UVD_INDEX].ready; in radeon_info_ioctl()
492 *value = rdev->ring[TN_RING_TYPE_VCE1_INDEX].ready; in radeon_info_ioctl()
499 if (rdev->family >= CHIP_BONAIRE) { in radeon_info_ioctl()
500 value = rdev->config.cik.tile_mode_array; in radeon_info_ioctl()
502 } else if (rdev->family >= CHIP_TAHITI) { in radeon_info_ioctl()
503 value = rdev->config.si.tile_mode_array; in radeon_info_ioctl()
511 if (rdev->family >= CHIP_BONAIRE) { in radeon_info_ioctl()
512 value = rdev->config.cik.macrotile_mode_array; in radeon_info_ioctl()
523 if (rdev->family >= CHIP_BONAIRE) { in radeon_info_ioctl()
524 *value = rdev->config.cik.backend_enable_mask; in radeon_info_ioctl()
525 } else if (rdev->family >= CHIP_TAHITI) { in radeon_info_ioctl()
526 *value = rdev->config.si.backend_enable_mask; in radeon_info_ioctl()
533 if ((rdev->pm.pm_method == PM_METHOD_DPM) && in radeon_info_ioctl()
534 rdev->pm.dpm_enabled) in radeon_info_ioctl()
535 *value = rdev->pm.dpm.dyn_state.max_clock_voltage_on_ac.sclk * 10; in radeon_info_ioctl()
537 *value = rdev->pm.default_sclk * 10; in radeon_info_ioctl()
540 *value = rdev->vce.fw_version; in radeon_info_ioctl()
543 *value = rdev->vce.fb_version; in radeon_info_ioctl()
548 value64 = atomic64_read(&rdev->num_bytes_moved); in radeon_info_ioctl()
553 man = ttm_manager_type(&rdev->mman.bdev, TTM_PL_VRAM); in radeon_info_ioctl()
559 man = ttm_manager_type(&rdev->mman.bdev, TTM_PL_TT); in radeon_info_ioctl()
563 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
564 *value = rdev->config.cik.active_cus; in radeon_info_ioctl()
565 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
566 *value = rdev->config.si.active_cus; in radeon_info_ioctl()
567 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
568 *value = rdev->config.cayman.active_simds; in radeon_info_ioctl()
569 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
570 *value = rdev->config.evergreen.active_simds; in radeon_info_ioctl()
571 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
572 *value = rdev->config.rv770.active_simds; in radeon_info_ioctl()
573 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
574 *value = rdev->config.r600.active_simds; in radeon_info_ioctl()
580 if (rdev->asic->pm.get_temperature) in radeon_info_ioctl()
581 *value = radeon_get_temperature(rdev); in radeon_info_ioctl()
587 if (rdev->pm.dpm_enabled) in radeon_info_ioctl()
588 *value = radeon_dpm_get_current_sclk(rdev) / 100; in radeon_info_ioctl()
590 *value = rdev->pm.current_sclk / 100; in radeon_info_ioctl()
594 if (rdev->pm.dpm_enabled) in radeon_info_ioctl()
595 *value = radeon_dpm_get_current_mclk(rdev) / 100; in radeon_info_ioctl()
597 *value = rdev->pm.current_mclk / 100; in radeon_info_ioctl()
604 if (radeon_get_allowed_info_register(rdev, *value, value)) in radeon_info_ioctl()
611 *value = atomic_read(&rdev->gpu_reset_counter); in radeon_info_ioctl()
635 struct radeon_device *rdev = dev->dev_private; in radeon_driver_open_kms() local
649 if (rdev->family >= CHIP_CAYMAN) { in radeon_driver_open_kms()
657 if (rdev->accel_working) { in radeon_driver_open_kms()
659 r = radeon_vm_init(rdev, vm); in radeon_driver_open_kms()
663 r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false); in radeon_driver_open_kms()
669 vm->ib_bo_va = radeon_vm_bo_add(rdev, vm, in radeon_driver_open_kms()
670 rdev->ring_tmp_bo.bo); in radeon_driver_open_kms()
676 r = radeon_vm_bo_set_addr(rdev, vm->ib_bo_va, in radeon_driver_open_kms()
691 radeon_vm_fini(rdev, vm); in radeon_driver_open_kms()
713 struct radeon_device *rdev = dev->dev_private; in radeon_driver_postclose_kms() local
717 mutex_lock(&rdev->gem.mutex); in radeon_driver_postclose_kms()
718 if (rdev->hyperz_filp == file_priv) in radeon_driver_postclose_kms()
719 rdev->hyperz_filp = NULL; in radeon_driver_postclose_kms()
720 if (rdev->cmask_filp == file_priv) in radeon_driver_postclose_kms()
721 rdev->cmask_filp = NULL; in radeon_driver_postclose_kms()
722 mutex_unlock(&rdev->gem.mutex); in radeon_driver_postclose_kms()
724 radeon_uvd_free_handles(rdev, file_priv); in radeon_driver_postclose_kms()
725 radeon_vce_free_handles(rdev, file_priv); in radeon_driver_postclose_kms()
728 if (rdev->family >= CHIP_CAYMAN && file_priv->driver_priv) { in radeon_driver_postclose_kms()
733 if (rdev->accel_working) { in radeon_driver_postclose_kms()
734 r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false); in radeon_driver_postclose_kms()
737 radeon_vm_bo_rmv(rdev, vm->ib_bo_va); in radeon_driver_postclose_kms()
738 radeon_bo_unreserve(rdev->ring_tmp_bo.bo); in radeon_driver_postclose_kms()
740 radeon_vm_fini(rdev, vm); in radeon_driver_postclose_kms()
767 struct radeon_device *rdev = dev->dev_private; in radeon_get_vblank_counter_kms() local
769 if (pipe >= rdev->num_crtc) { in radeon_get_vblank_counter_kms()
782 if (rdev->mode_info.crtcs[pipe]) { in radeon_get_vblank_counter_kms()
787 count = radeon_get_vblank_counter(rdev, pipe); in radeon_get_vblank_counter_kms()
795 &rdev->mode_info.crtcs[pipe]->base.hwmode); in radeon_get_vblank_counter_kms()
796 } while (count != radeon_get_vblank_counter(rdev, pipe)); in radeon_get_vblank_counter_kms()
816 count = radeon_get_vblank_counter(rdev, pipe); in radeon_get_vblank_counter_kms()
835 struct radeon_device *rdev = dev->dev_private; in radeon_enable_vblank_kms() local
839 if (pipe >= rdev->num_crtc) { in radeon_enable_vblank_kms()
844 spin_lock_irqsave(&rdev->irq.lock, irqflags); in radeon_enable_vblank_kms()
845 rdev->irq.crtc_vblank_int[pipe] = true; in radeon_enable_vblank_kms()
846 r = radeon_irq_set(rdev); in radeon_enable_vblank_kms()
847 spin_unlock_irqrestore(&rdev->irq.lock, irqflags); in radeon_enable_vblank_kms()
862 struct radeon_device *rdev = dev->dev_private; in radeon_disable_vblank_kms() local
865 if (pipe >= rdev->num_crtc) { in radeon_disable_vblank_kms()
870 spin_lock_irqsave(&rdev->irq.lock, irqflags); in radeon_disable_vblank_kms()
871 rdev->irq.crtc_vblank_int[pipe] = false; in radeon_disable_vblank_kms()
872 radeon_irq_set(rdev); in radeon_disable_vblank_kms()
873 spin_unlock_irqrestore(&rdev->irq.lock, irqflags); in radeon_disable_vblank_kms()