Lines Matching defs:radeon_device
2298 struct radeon_device { struct
2299 struct device *dev;
2300 struct drm_device ddev;
2301 struct pci_dev *pdev;
2303 struct pci_controller *hose;
2305 struct radeon_agp_head *agp;
2306 struct rw_semaphore exclusive_lock;
2308 union radeon_asic_config config;
2309 enum radeon_family family;
2310 unsigned long flags;
2311 int usec_timeout;
2312 enum radeon_pll_errata pll_errata;
2313 int num_gb_pipes;
2314 int num_z_pipes;
2315 int disp_priority;
2317 uint8_t *bios;
2318 bool is_atom_bios;
2319 uint16_t bios_header_start;
2320 struct radeon_bo *stolen_vga_memory;
2322 resource_size_t rmmio_base;
2323 resource_size_t rmmio_size;
2325 spinlock_t mmio_idx_lock;
2327 spinlock_t smc_idx_lock;
2329 spinlock_t pll_idx_lock;
2331 spinlock_t mc_idx_lock;
2333 spinlock_t pcie_idx_lock;
2335 spinlock_t pciep_idx_lock;
2337 spinlock_t pif_idx_lock;
2339 spinlock_t cg_idx_lock;
2341 spinlock_t uvd_idx_lock;
2343 spinlock_t rcu_idx_lock;
2345 spinlock_t didt_idx_lock;
2347 spinlock_t end_idx_lock;
2348 void __iomem *rmmio;
2349 radeon_rreg_t mc_rreg;
2350 radeon_wreg_t mc_wreg;
2351 radeon_rreg_t pll_rreg;
2352 radeon_wreg_t pll_wreg;
2353 uint32_t pcie_reg_mask;
2354 radeon_rreg_t pciep_rreg;
2355 radeon_wreg_t pciep_wreg;
2357 void __iomem *rio_mem;
2358 resource_size_t rio_mem_size;
2359 struct radeon_clock clock;
2360 struct radeon_mc mc;
2361 struct radeon_gart gart;
2362 struct radeon_mode_info mode_info;
2363 struct radeon_scratch scratch;
2364 struct radeon_doorbell doorbell;
2365 struct radeon_mman mman;
2366 struct radeon_fence_driver fence_drv[RADEON_NUM_RINGS];
2367 wait_queue_head_t fence_queue;
2368 u64 fence_context;
2369 struct mutex ring_lock;
2370 struct radeon_ring ring[RADEON_NUM_RINGS];
2371 bool ib_pool_ready;
2372 struct radeon_sa_manager ring_tmp_bo;
2373 struct radeon_irq irq;
2374 struct radeon_asic *asic;
2375 struct radeon_gem gem;
2376 struct radeon_pm pm;
2377 struct radeon_uvd uvd;
2378 struct radeon_vce vce;
2379 uint32_t bios_scratch[RADEON_BIOS_NUM_SCRATCH];
2380 struct radeon_wb wb;
2381 struct radeon_dummy_page dummy_page;
2382 bool shutdown;
2383 bool need_swiotlb;
2384 bool accel_working;
2385 bool fastfb_working; /* IGP feature*/
2386 bool needs_reset, in_reset;
2387 struct radeon_surface_reg surface_regs[RADEON_GEM_MAX_SURFACES];
2388 const struct firmware *me_fw; /* all family ME firmware */
2389 const struct firmware *pfp_fw; /* r6/700 PFP firmware */
2390 const struct firmware *rlc_fw; /* r6/700 RLC firmware */
2391 const struct firmware *mc_fw; /* NI MC firmware */
2392 const struct firmware *ce_fw; /* SI CE firmware */
2393 const struct firmware *mec_fw; /* CIK MEC firmware */
2394 const struct firmware *mec2_fw; /* KV MEC2 firmware */
2395 const struct firmware *sdma_fw; /* CIK SDMA firmware */
2396 const struct firmware *smc_fw; /* SMC firmware */
2397 const struct firmware *uvd_fw; /* UVD firmware */
2398 const struct firmware *vce_fw; /* VCE firmware */
2399 bool new_fw;
2400 struct r600_vram_scratch vram_scratch;
2401 int msi_enabled; /* msi enabled */
2402 struct r600_ih ih; /* r6/700 interrupt ring */
2403 struct radeon_rlc rlc;
2404 struct radeon_mec mec;
2405 struct delayed_work hotplug_work;
2406 struct work_struct dp_work;
2407 struct work_struct audio_work;
2408 int num_crtc; /* number of crtcs */
2409 struct mutex dc_hw_i2c_mutex; /* display controller hw i2c mutex */
2410 bool has_uvd;
2411 bool has_vce;
2412 struct r600_audio audio; /* audio stuff */
2413 struct notifier_block acpi_nb;
2415 struct drm_file *hyperz_filp;
2416 struct drm_file *cmask_filp;
2418 struct radeon_i2c_chan *i2c_bus[RADEON_MAX_I2C_BUS];
2420 struct radeon_vm_manager vm_manager;
2444 int radeon_device_init(struct radeon_device *rdev, argument