Lines Matching refs:rdev

58 	struct radeon_device *rdev = dev->dev_private;  in radeon_driver_unload_kms()  local
60 if (rdev == NULL) in radeon_driver_unload_kms()
63 if (rdev->rmmio == NULL) in radeon_driver_unload_kms()
68 radeon_kfd_device_fini(rdev); in radeon_driver_unload_kms()
70 radeon_acpi_fini(rdev); in radeon_driver_unload_kms()
72 radeon_modeset_fini(rdev); in radeon_driver_unload_kms()
73 radeon_device_fini(rdev); in radeon_driver_unload_kms()
76 kfree(rdev); in radeon_driver_unload_kms()
96 struct radeon_device *rdev; in radeon_driver_load_kms() local
99 rdev = kzalloc(sizeof(struct radeon_device), GFP_KERNEL); in radeon_driver_load_kms()
100 if (rdev == NULL) { in radeon_driver_load_kms()
103 dev->dev_private = (void *)rdev; in radeon_driver_load_kms()
125 r = radeon_device_init(rdev, dev, dev->pdev, flags); in radeon_driver_load_kms()
135 r = radeon_modeset_init(rdev); in radeon_driver_load_kms()
143 acpi_status = radeon_acpi_init(rdev); in radeon_driver_load_kms()
149 radeon_kfd_device_probe(rdev); in radeon_driver_load_kms()
150 radeon_kfd_device_init(rdev); in radeon_driver_load_kms()
184 struct radeon_device *rdev = dev->dev_private; in radeon_set_filp_rights() local
186 mutex_lock(&rdev->gem.mutex); in radeon_set_filp_rights()
197 mutex_unlock(&rdev->gem.mutex); in radeon_set_filp_rights()
217 struct radeon_device *rdev = dev->dev_private; in radeon_info_ioctl() local
219 struct radeon_mode_info *minfo = &rdev->mode_info; in radeon_info_ioctl()
234 *value = rdev->num_gb_pipes; in radeon_info_ioctl()
237 *value = rdev->num_z_pipes; in radeon_info_ioctl()
241 if ((rdev->family >= CHIP_CEDAR) && (rdev->family <= CHIP_HEMLOCK)) in radeon_info_ioctl()
244 *value = rdev->accel_working; in radeon_info_ioctl()
251 for (i = 0, found = 0; i < rdev->num_crtc; i++) { in radeon_info_ioctl()
266 if (rdev->family == CHIP_HAWAII) { in radeon_info_ioctl()
267 if (rdev->accel_working) { in radeon_info_ioctl()
268 if (rdev->new_fw) in radeon_info_ioctl()
276 *value = rdev->accel_working; in radeon_info_ioctl()
280 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
281 *value = rdev->config.cik.tile_config; in radeon_info_ioctl()
282 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
283 *value = rdev->config.si.tile_config; in radeon_info_ioctl()
284 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
285 *value = rdev->config.cayman.tile_config; in radeon_info_ioctl()
286 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
287 *value = rdev->config.evergreen.tile_config; in radeon_info_ioctl()
288 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
289 *value = rdev->config.rv770.tile_config; in radeon_info_ioctl()
290 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
291 *value = rdev->config.r600.tile_config; in radeon_info_ioctl()
312 radeon_set_filp_rights(dev, &rdev->hyperz_filp, filp, value); in radeon_info_ioctl()
324 radeon_set_filp_rights(dev, &rdev->cmask_filp, filp, value); in radeon_info_ioctl()
328 if (rdev->asic->get_xclk) in radeon_info_ioctl()
329 *value = radeon_get_xclk(rdev) * 10; in radeon_info_ioctl()
331 *value = rdev->clock.spll.reference_freq * 10; in radeon_info_ioctl()
334 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
335 *value = rdev->config.cik.max_backends_per_se * in radeon_info_ioctl()
336 rdev->config.cik.max_shader_engines; in radeon_info_ioctl()
337 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
338 *value = rdev->config.si.max_backends_per_se * in radeon_info_ioctl()
339 rdev->config.si.max_shader_engines; in radeon_info_ioctl()
340 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
341 *value = rdev->config.cayman.max_backends_per_se * in radeon_info_ioctl()
342 rdev->config.cayman.max_shader_engines; in radeon_info_ioctl()
343 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
344 *value = rdev->config.evergreen.max_backends; in radeon_info_ioctl()
345 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
346 *value = rdev->config.rv770.max_backends; in radeon_info_ioctl()
347 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
348 *value = rdev->config.r600.max_backends; in radeon_info_ioctl()
354 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
355 *value = rdev->config.cik.max_tile_pipes; in radeon_info_ioctl()
356 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
357 *value = rdev->config.si.max_tile_pipes; in radeon_info_ioctl()
358 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
359 *value = rdev->config.cayman.max_tile_pipes; in radeon_info_ioctl()
360 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
361 *value = rdev->config.evergreen.max_tile_pipes; in radeon_info_ioctl()
362 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
363 *value = rdev->config.rv770.max_tile_pipes; in radeon_info_ioctl()
364 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
365 *value = rdev->config.r600.max_tile_pipes; in radeon_info_ioctl()
374 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
375 *value = rdev->config.cik.backend_map; in radeon_info_ioctl()
376 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
377 *value = rdev->config.si.backend_map; in radeon_info_ioctl()
378 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
379 *value = rdev->config.cayman.backend_map; in radeon_info_ioctl()
380 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
381 *value = rdev->config.evergreen.backend_map; in radeon_info_ioctl()
382 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
383 *value = rdev->config.rv770.backend_map; in radeon_info_ioctl()
384 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
385 *value = rdev->config.r600.backend_map; in radeon_info_ioctl()
392 if (rdev->family < CHIP_CAYMAN) in radeon_info_ioctl()
398 if (rdev->family < CHIP_CAYMAN) in radeon_info_ioctl()
403 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
404 *value = rdev->config.cik.max_cu_per_sh; in radeon_info_ioctl()
405 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
406 *value = rdev->config.si.max_cu_per_sh; in radeon_info_ioctl()
407 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
408 *value = rdev->config.cayman.max_pipes_per_simd; in radeon_info_ioctl()
409 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
410 *value = rdev->config.evergreen.max_pipes; in radeon_info_ioctl()
411 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
412 *value = rdev->config.rv770.max_pipes; in radeon_info_ioctl()
413 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
414 *value = rdev->config.r600.max_pipes; in radeon_info_ioctl()
420 if (rdev->family < CHIP_R600) { in radeon_info_ioctl()
426 value64 = radeon_get_gpu_clock_counter(rdev); in radeon_info_ioctl()
429 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
430 *value = rdev->config.cik.max_shader_engines; in radeon_info_ioctl()
431 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
432 *value = rdev->config.si.max_shader_engines; in radeon_info_ioctl()
433 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
434 *value = rdev->config.cayman.max_shader_engines; in radeon_info_ioctl()
435 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
436 *value = rdev->config.evergreen.num_ses; in radeon_info_ioctl()
441 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
442 *value = rdev->config.cik.max_sh_per_se; in radeon_info_ioctl()
443 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
444 *value = rdev->config.si.max_sh_per_se; in radeon_info_ioctl()
449 *value = rdev->fastfb_working; in radeon_info_ioctl()
459 *value = rdev->ring[RADEON_RING_TYPE_GFX_INDEX].ready; in radeon_info_ioctl()
462 *value = rdev->ring[R600_RING_TYPE_DMA_INDEX].ready; in radeon_info_ioctl()
463 *value |= rdev->ring[CAYMAN_RING_TYPE_DMA1_INDEX].ready; in radeon_info_ioctl()
466 *value = rdev->ring[R600_RING_TYPE_UVD_INDEX].ready; in radeon_info_ioctl()
469 *value = rdev->ring[TN_RING_TYPE_VCE1_INDEX].ready; in radeon_info_ioctl()
476 if (rdev->family >= CHIP_BONAIRE) { in radeon_info_ioctl()
477 value = rdev->config.cik.tile_mode_array; in radeon_info_ioctl()
479 } else if (rdev->family >= CHIP_TAHITI) { in radeon_info_ioctl()
480 value = rdev->config.si.tile_mode_array; in radeon_info_ioctl()
488 if (rdev->family >= CHIP_BONAIRE) { in radeon_info_ioctl()
489 value = rdev->config.cik.macrotile_mode_array; in radeon_info_ioctl()
500 if (rdev->family >= CHIP_BONAIRE) { in radeon_info_ioctl()
501 *value = rdev->config.cik.backend_enable_mask; in radeon_info_ioctl()
502 } else if (rdev->family >= CHIP_TAHITI) { in radeon_info_ioctl()
503 *value = rdev->config.si.backend_enable_mask; in radeon_info_ioctl()
509 if ((rdev->pm.pm_method == PM_METHOD_DPM) && in radeon_info_ioctl()
510 rdev->pm.dpm_enabled) in radeon_info_ioctl()
511 *value = rdev->pm.dpm.dyn_state.max_clock_voltage_on_ac.sclk * 10; in radeon_info_ioctl()
513 *value = rdev->pm.default_sclk * 10; in radeon_info_ioctl()
516 *value = rdev->vce.fw_version; in radeon_info_ioctl()
519 *value = rdev->vce.fb_version; in radeon_info_ioctl()
524 value64 = atomic64_read(&rdev->num_bytes_moved); in radeon_info_ioctl()
529 value64 = atomic64_read(&rdev->vram_usage); in radeon_info_ioctl()
534 value64 = atomic64_read(&rdev->gtt_usage); in radeon_info_ioctl()
537 if (rdev->family >= CHIP_BONAIRE) in radeon_info_ioctl()
538 *value = rdev->config.cik.active_cus; in radeon_info_ioctl()
539 else if (rdev->family >= CHIP_TAHITI) in radeon_info_ioctl()
540 *value = rdev->config.si.active_cus; in radeon_info_ioctl()
541 else if (rdev->family >= CHIP_CAYMAN) in radeon_info_ioctl()
542 *value = rdev->config.cayman.active_simds; in radeon_info_ioctl()
543 else if (rdev->family >= CHIP_CEDAR) in radeon_info_ioctl()
544 *value = rdev->config.evergreen.active_simds; in radeon_info_ioctl()
545 else if (rdev->family >= CHIP_RV770) in radeon_info_ioctl()
546 *value = rdev->config.rv770.active_simds; in radeon_info_ioctl()
547 else if (rdev->family >= CHIP_R600) in radeon_info_ioctl()
548 *value = rdev->config.r600.active_simds; in radeon_info_ioctl()
554 if (rdev->asic->pm.get_temperature) in radeon_info_ioctl()
555 *value = radeon_get_temperature(rdev); in radeon_info_ioctl()
561 if (rdev->pm.dpm_enabled) in radeon_info_ioctl()
562 *value = radeon_dpm_get_current_sclk(rdev) / 100; in radeon_info_ioctl()
564 *value = rdev->pm.current_sclk / 100; in radeon_info_ioctl()
568 if (rdev->pm.dpm_enabled) in radeon_info_ioctl()
569 *value = radeon_dpm_get_current_mclk(rdev) / 100; in radeon_info_ioctl()
571 *value = rdev->pm.current_mclk / 100; in radeon_info_ioctl()
578 if (radeon_get_allowed_info_register(rdev, *value, value)) in radeon_info_ioctl()
585 *value = atomic_read(&rdev->gpu_reset_counter); in radeon_info_ioctl()
611 struct radeon_device *rdev = dev->dev_private; in radeon_driver_lastclose_kms() local
613 radeon_fbdev_restore_mode(rdev); in radeon_driver_lastclose_kms()
628 struct radeon_device *rdev = dev->dev_private; in radeon_driver_open_kms() local
638 if (rdev->family >= CHIP_CAYMAN) { in radeon_driver_open_kms()
648 if (rdev->accel_working) { in radeon_driver_open_kms()
650 r = radeon_vm_init(rdev, vm); in radeon_driver_open_kms()
656 r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false); in radeon_driver_open_kms()
658 radeon_vm_fini(rdev, vm); in radeon_driver_open_kms()
665 vm->ib_bo_va = radeon_vm_bo_add(rdev, vm, in radeon_driver_open_kms()
666 rdev->ring_tmp_bo.bo); in radeon_driver_open_kms()
667 r = radeon_vm_bo_set_addr(rdev, vm->ib_bo_va, in radeon_driver_open_kms()
672 radeon_vm_fini(rdev, vm); in radeon_driver_open_kms()
696 struct radeon_device *rdev = dev->dev_private; in radeon_driver_postclose_kms() local
699 if (rdev->family >= CHIP_CAYMAN && file_priv->driver_priv) { in radeon_driver_postclose_kms()
704 if (rdev->accel_working) { in radeon_driver_postclose_kms()
705 r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false); in radeon_driver_postclose_kms()
708 radeon_vm_bo_rmv(rdev, vm->ib_bo_va); in radeon_driver_postclose_kms()
709 radeon_bo_unreserve(rdev->ring_tmp_bo.bo); in radeon_driver_postclose_kms()
711 radeon_vm_fini(rdev, vm); in radeon_driver_postclose_kms()
731 struct radeon_device *rdev = dev->dev_private; in radeon_driver_preclose_kms() local
733 mutex_lock(&rdev->gem.mutex); in radeon_driver_preclose_kms()
734 if (rdev->hyperz_filp == file_priv) in radeon_driver_preclose_kms()
735 rdev->hyperz_filp = NULL; in radeon_driver_preclose_kms()
736 if (rdev->cmask_filp == file_priv) in radeon_driver_preclose_kms()
737 rdev->cmask_filp = NULL; in radeon_driver_preclose_kms()
738 mutex_unlock(&rdev->gem.mutex); in radeon_driver_preclose_kms()
740 radeon_uvd_free_handles(rdev, file_priv); in radeon_driver_preclose_kms()
741 radeon_vce_free_handles(rdev, file_priv); in radeon_driver_preclose_kms()
760 struct radeon_device *rdev = dev->dev_private; in radeon_get_vblank_counter_kms() local
762 if (crtc < 0 || crtc >= rdev->num_crtc) { in radeon_get_vblank_counter_kms()
775 if (rdev->mode_info.crtcs[crtc]) { in radeon_get_vblank_counter_kms()
780 count = radeon_get_vblank_counter(rdev, crtc); in radeon_get_vblank_counter_kms()
788 &rdev->mode_info.crtcs[crtc]->base.hwmode); in radeon_get_vblank_counter_kms()
789 } while (count != radeon_get_vblank_counter(rdev, crtc)); in radeon_get_vblank_counter_kms()
809 count = radeon_get_vblank_counter(rdev, crtc); in radeon_get_vblank_counter_kms()
827 struct radeon_device *rdev = dev->dev_private; in radeon_enable_vblank_kms() local
831 if (crtc < 0 || crtc >= rdev->num_crtc) { in radeon_enable_vblank_kms()
836 spin_lock_irqsave(&rdev->irq.lock, irqflags); in radeon_enable_vblank_kms()
837 rdev->irq.crtc_vblank_int[crtc] = true; in radeon_enable_vblank_kms()
838 r = radeon_irq_set(rdev); in radeon_enable_vblank_kms()
839 spin_unlock_irqrestore(&rdev->irq.lock, irqflags); in radeon_enable_vblank_kms()
853 struct radeon_device *rdev = dev->dev_private; in radeon_disable_vblank_kms() local
856 if (crtc < 0 || crtc >= rdev->num_crtc) { in radeon_disable_vblank_kms()
861 spin_lock_irqsave(&rdev->irq.lock, irqflags); in radeon_disable_vblank_kms()
862 rdev->irq.crtc_vblank_int[crtc] = false; in radeon_disable_vblank_kms()
863 radeon_irq_set(rdev); in radeon_disable_vblank_kms()
864 spin_unlock_irqrestore(&rdev->irq.lock, irqflags); in radeon_disable_vblank_kms()
886 struct radeon_device *rdev = dev->dev_private; in radeon_get_vblank_timestamp_kms() local
894 drmcrtc = &rdev->mode_info.crtcs[crtc]->base; in radeon_get_vblank_timestamp_kms()