mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-01 10:13:58 +08:00
Merge branch 'drm-next' of ../drm-2.6 into drm-next
This commit is contained in:
commit
4fe9676d1a
@ -578,19 +578,19 @@ int r100_cp_init(struct radeon_device *rdev, unsigned ring_size)
|
|||||||
indirect1_start = 16;
|
indirect1_start = 16;
|
||||||
/* cp setup */
|
/* cp setup */
|
||||||
WREG32(0x718, pre_write_timer | (pre_write_limit << 28));
|
WREG32(0x718, pre_write_timer | (pre_write_limit << 28));
|
||||||
WREG32(RADEON_CP_RB_CNTL,
|
tmp = (REG_SET(RADEON_RB_BUFSZ, rb_bufsz) |
|
||||||
#ifdef __BIG_ENDIAN
|
|
||||||
RADEON_BUF_SWAP_32BIT |
|
|
||||||
#endif
|
|
||||||
REG_SET(RADEON_RB_BUFSZ, rb_bufsz) |
|
|
||||||
REG_SET(RADEON_RB_BLKSZ, rb_blksz) |
|
REG_SET(RADEON_RB_BLKSZ, rb_blksz) |
|
||||||
REG_SET(RADEON_MAX_FETCH, max_fetch) |
|
REG_SET(RADEON_MAX_FETCH, max_fetch) |
|
||||||
RADEON_RB_NO_UPDATE);
|
RADEON_RB_NO_UPDATE);
|
||||||
|
#ifdef __BIG_ENDIAN
|
||||||
|
tmp |= RADEON_BUF_SWAP_32BIT;
|
||||||
|
#endif
|
||||||
|
WREG32(RADEON_CP_RB_CNTL, tmp);
|
||||||
|
|
||||||
/* Set ring address */
|
/* Set ring address */
|
||||||
DRM_INFO("radeon: ring at 0x%016lX\n", (unsigned long)rdev->cp.gpu_addr);
|
DRM_INFO("radeon: ring at 0x%016lX\n", (unsigned long)rdev->cp.gpu_addr);
|
||||||
WREG32(RADEON_CP_RB_BASE, rdev->cp.gpu_addr);
|
WREG32(RADEON_CP_RB_BASE, rdev->cp.gpu_addr);
|
||||||
/* Force read & write ptr to 0 */
|
/* Force read & write ptr to 0 */
|
||||||
tmp = RREG32(RADEON_CP_RB_CNTL);
|
|
||||||
WREG32(RADEON_CP_RB_CNTL, tmp | RADEON_RB_RPTR_WR_ENA);
|
WREG32(RADEON_CP_RB_CNTL, tmp | RADEON_RB_RPTR_WR_ENA);
|
||||||
WREG32(RADEON_CP_RB_RPTR_WR, 0);
|
WREG32(RADEON_CP_RB_RPTR_WR, 0);
|
||||||
WREG32(RADEON_CP_RB_WPTR, 0);
|
WREG32(RADEON_CP_RB_WPTR, 0);
|
||||||
|
@ -409,35 +409,29 @@ int r600_mc_init(struct radeon_device *rdev)
|
|||||||
rdev->mc.gtt_location = rdev->mc.mc_vram_size;
|
rdev->mc.gtt_location = rdev->mc.mc_vram_size;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (rdev->family == CHIP_RS780 || rdev->family == CHIP_RS880) {
|
rdev->mc.gtt_size = radeon_gart_size * 1024 * 1024;
|
||||||
rdev->mc.vram_location = (RREG32(MC_VM_FB_LOCATION) &
|
rdev->mc.vram_location = (RREG32(MC_VM_FB_LOCATION) &
|
||||||
0xFFFF) << 24;
|
0xFFFF) << 24;
|
||||||
rdev->mc.gtt_size = radeon_gart_size * 1024 * 1024;
|
tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size;
|
||||||
tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size;
|
if ((0xFFFFFFFFUL - tmp) >= rdev->mc.gtt_size) {
|
||||||
if ((0xFFFFFFFFUL - tmp) >= rdev->mc.gtt_size) {
|
/* Enough place after vram */
|
||||||
/* Enough place after vram */
|
rdev->mc.gtt_location = tmp;
|
||||||
rdev->mc.gtt_location = tmp;
|
} else if (rdev->mc.vram_location >= rdev->mc.gtt_size) {
|
||||||
} else if (rdev->mc.vram_location >= rdev->mc.gtt_size) {
|
/* Enough place before vram */
|
||||||
/* Enough place before vram */
|
rdev->mc.gtt_location = 0;
|
||||||
rdev->mc.gtt_location = 0;
|
|
||||||
} else {
|
|
||||||
/* Not enough place after or before shrink
|
|
||||||
* gart size
|
|
||||||
*/
|
|
||||||
if (rdev->mc.vram_location > (0xFFFFFFFFUL - tmp)) {
|
|
||||||
rdev->mc.gtt_location = 0;
|
|
||||||
rdev->mc.gtt_size = rdev->mc.vram_location;
|
|
||||||
} else {
|
|
||||||
rdev->mc.gtt_location = tmp;
|
|
||||||
rdev->mc.gtt_size = 0xFFFFFFFFUL - tmp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
rdev->mc.gtt_location = rdev->mc.mc_vram_size;
|
|
||||||
} else {
|
} else {
|
||||||
rdev->mc.vram_location = 0x00000000UL;
|
/* Not enough place after or before shrink
|
||||||
rdev->mc.gtt_location = rdev->mc.mc_vram_size;
|
* gart size
|
||||||
rdev->mc.gtt_size = radeon_gart_size * 1024 * 1024;
|
*/
|
||||||
|
if (rdev->mc.vram_location > (0xFFFFFFFFUL - tmp)) {
|
||||||
|
rdev->mc.gtt_location = 0;
|
||||||
|
rdev->mc.gtt_size = rdev->mc.vram_location;
|
||||||
|
} else {
|
||||||
|
rdev->mc.gtt_location = tmp;
|
||||||
|
rdev->mc.gtt_size = 0xFFFFFFFFUL - tmp;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
rdev->mc.gtt_location = rdev->mc.mc_vram_size;
|
||||||
}
|
}
|
||||||
rdev->mc.vram_start = rdev->mc.vram_location;
|
rdev->mc.vram_start = rdev->mc.vram_location;
|
||||||
rdev->mc.vram_end = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
|
rdev->mc.vram_end = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
|
||||||
@ -1272,19 +1266,17 @@ int r600_cp_resume(struct radeon_device *rdev)
|
|||||||
|
|
||||||
/* Set ring buffer size */
|
/* Set ring buffer size */
|
||||||
rb_bufsz = drm_order(rdev->cp.ring_size / 8);
|
rb_bufsz = drm_order(rdev->cp.ring_size / 8);
|
||||||
|
tmp = RB_NO_UPDATE | (drm_order(RADEON_GPU_PAGE_SIZE/8) << 8) | rb_bufsz;
|
||||||
#ifdef __BIG_ENDIAN
|
#ifdef __BIG_ENDIAN
|
||||||
WREG32(CP_RB_CNTL, BUF_SWAP_32BIT | RB_NO_UPDATE |
|
tmp |= BUF_SWAP_32BIT;
|
||||||
(drm_order(RADEON_GPU_PAGE_SIZE/8) << 8) | rb_bufsz);
|
|
||||||
#else
|
|
||||||
WREG32(CP_RB_CNTL, RB_NO_UPDATE | (drm_order(RADEON_GPU_PAGE_SIZE/8) << 8) | rb_bufsz);
|
|
||||||
#endif
|
#endif
|
||||||
|
WREG32(CP_RB_CNTL, tmp);
|
||||||
WREG32(CP_SEM_WAIT_TIMER, 0x4);
|
WREG32(CP_SEM_WAIT_TIMER, 0x4);
|
||||||
|
|
||||||
/* Set the write pointer delay */
|
/* Set the write pointer delay */
|
||||||
WREG32(CP_RB_WPTR_DELAY, 0);
|
WREG32(CP_RB_WPTR_DELAY, 0);
|
||||||
|
|
||||||
/* Initialize the ring buffer's read and write pointers */
|
/* Initialize the ring buffer's read and write pointers */
|
||||||
tmp = RREG32(CP_RB_CNTL);
|
|
||||||
WREG32(CP_RB_CNTL, tmp | RB_RPTR_WR_ENA);
|
WREG32(CP_RB_CNTL, tmp | RB_RPTR_WR_ENA);
|
||||||
WREG32(CP_RB_RPTR_WR, 0);
|
WREG32(CP_RB_RPTR_WR, 0);
|
||||||
WREG32(CP_RB_WPTR, 0);
|
WREG32(CP_RB_WPTR, 0);
|
||||||
|
@ -50,19 +50,16 @@ static bool igp_read_bios_from_vram(struct radeon_device *rdev)
|
|||||||
vram_base = drm_get_resource_start(rdev->ddev, 0);
|
vram_base = drm_get_resource_start(rdev->ddev, 0);
|
||||||
bios = ioremap(vram_base, size);
|
bios = ioremap(vram_base, size);
|
||||||
if (!bios) {
|
if (!bios) {
|
||||||
DRM_ERROR("Unable to mmap vram\n");
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (size == 0 || bios[0] != 0x55 || bios[1] != 0xaa) {
|
if (size == 0 || bios[0] != 0x55 || bios[1] != 0xaa) {
|
||||||
iounmap(bios);
|
iounmap(bios);
|
||||||
DRM_ERROR("bad rom signature\n");
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
rdev->bios = kmalloc(size, GFP_KERNEL);
|
rdev->bios = kmalloc(size, GFP_KERNEL);
|
||||||
if (rdev->bios == NULL) {
|
if (rdev->bios == NULL) {
|
||||||
iounmap(bios);
|
iounmap(bios);
|
||||||
DRM_ERROR("kmalloc failed\n");
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
memcpy(rdev->bios, bios, size);
|
memcpy(rdev->bios, bios, size);
|
||||||
|
@ -295,6 +295,12 @@ static int radeon_move_vram_ram(struct ttm_buffer_object *bo,
|
|||||||
if (unlikely(r)) {
|
if (unlikely(r)) {
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
r = ttm_tt_set_placement_caching(bo->ttm, tmp_mem.placement);
|
||||||
|
if (unlikely(r)) {
|
||||||
|
goto out_cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
r = ttm_tt_bind(bo->ttm, &tmp_mem);
|
r = ttm_tt_bind(bo->ttm, &tmp_mem);
|
||||||
if (unlikely(r)) {
|
if (unlikely(r)) {
|
||||||
goto out_cleanup;
|
goto out_cleanup;
|
||||||
|
@ -137,6 +137,8 @@ int rv515_mc_wait_for_idle(struct radeon_device *rdev)
|
|||||||
|
|
||||||
void rv515_vga_render_disable(struct radeon_device *rdev)
|
void rv515_vga_render_disable(struct radeon_device *rdev)
|
||||||
{
|
{
|
||||||
|
WREG32(R_000330_D1VGA_CONTROL, 0);
|
||||||
|
WREG32(R_000338_D2VGA_CONTROL, 0);
|
||||||
WREG32(R_000300_VGA_RENDER_CONTROL,
|
WREG32(R_000300_VGA_RENDER_CONTROL,
|
||||||
RREG32(R_000300_VGA_RENDER_CONTROL) & C_000300_VGA_VSTATUS_CNTL);
|
RREG32(R_000300_VGA_RENDER_CONTROL) & C_000300_VGA_VSTATUS_CNTL);
|
||||||
}
|
}
|
||||||
|
@ -529,11 +529,11 @@ static void rv770_gpu_init(struct radeon_device *rdev)
|
|||||||
if (rdev->family == CHIP_RV770)
|
if (rdev->family == CHIP_RV770)
|
||||||
gb_tiling_config |= BANK_TILING(1);
|
gb_tiling_config |= BANK_TILING(1);
|
||||||
else
|
else
|
||||||
gb_tiling_config |= BANK_TILING((mc_arb_ramcfg & NOOFBANK_SHIFT) >> NOOFBANK_MASK);
|
gb_tiling_config |= BANK_TILING((mc_arb_ramcfg & NOOFBANK_MASK) >> NOOFBANK_SHIFT);
|
||||||
|
|
||||||
gb_tiling_config |= GROUP_SIZE(0);
|
gb_tiling_config |= GROUP_SIZE(0);
|
||||||
|
|
||||||
if (((mc_arb_ramcfg & NOOFROWS_MASK) & NOOFROWS_SHIFT) > 3) {
|
if (((mc_arb_ramcfg & NOOFROWS_MASK) >> NOOFROWS_SHIFT) > 3) {
|
||||||
gb_tiling_config |= ROW_TILING(3);
|
gb_tiling_config |= ROW_TILING(3);
|
||||||
gb_tiling_config |= SAMPLE_SPLIT(3);
|
gb_tiling_config |= SAMPLE_SPLIT(3);
|
||||||
} else {
|
} else {
|
||||||
@ -579,14 +579,14 @@ static void rv770_gpu_init(struct radeon_device *rdev)
|
|||||||
|
|
||||||
/* set HW defaults for 3D engine */
|
/* set HW defaults for 3D engine */
|
||||||
WREG32(CP_QUEUE_THRESHOLDS, (ROQ_IB1_START(0x16) |
|
WREG32(CP_QUEUE_THRESHOLDS, (ROQ_IB1_START(0x16) |
|
||||||
ROQ_IB2_START(0x2b)));
|
ROQ_IB2_START(0x2b)));
|
||||||
|
|
||||||
WREG32(CP_MEQ_THRESHOLDS, STQ_SPLIT(0x30));
|
WREG32(CP_MEQ_THRESHOLDS, STQ_SPLIT(0x30));
|
||||||
|
|
||||||
WREG32(TA_CNTL_AUX, (DISABLE_CUBE_ANISO |
|
WREG32(TA_CNTL_AUX, (DISABLE_CUBE_ANISO |
|
||||||
SYNC_GRADIENT |
|
SYNC_GRADIENT |
|
||||||
SYNC_WALKER |
|
SYNC_WALKER |
|
||||||
SYNC_ALIGNER));
|
SYNC_ALIGNER));
|
||||||
|
|
||||||
sx_debug_1 = RREG32(SX_DEBUG_1);
|
sx_debug_1 = RREG32(SX_DEBUG_1);
|
||||||
sx_debug_1 |= ENABLE_NEW_SMX_ADDRESS;
|
sx_debug_1 |= ENABLE_NEW_SMX_ADDRESS;
|
||||||
@ -598,9 +598,9 @@ static void rv770_gpu_init(struct radeon_device *rdev)
|
|||||||
WREG32(SMX_DC_CTL0, smx_dc_ctl0);
|
WREG32(SMX_DC_CTL0, smx_dc_ctl0);
|
||||||
|
|
||||||
WREG32(SMX_EVENT_CTL, (ES_FLUSH_CTL(4) |
|
WREG32(SMX_EVENT_CTL, (ES_FLUSH_CTL(4) |
|
||||||
GS_FLUSH_CTL(4) |
|
GS_FLUSH_CTL(4) |
|
||||||
ACK_FLUSH_CTL(3) |
|
ACK_FLUSH_CTL(3) |
|
||||||
SYNC_FLUSH_CTL));
|
SYNC_FLUSH_CTL));
|
||||||
|
|
||||||
if (rdev->family == CHIP_RV770)
|
if (rdev->family == CHIP_RV770)
|
||||||
WREG32(DB_DEBUG3, DB_CLK_OFF_DELAY(0x1f));
|
WREG32(DB_DEBUG3, DB_CLK_OFF_DELAY(0x1f));
|
||||||
@ -611,12 +611,12 @@ static void rv770_gpu_init(struct radeon_device *rdev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
WREG32(SX_EXPORT_BUFFER_SIZES, (COLOR_BUFFER_SIZE((rdev->config.rv770.sx_max_export_size / 4) - 1) |
|
WREG32(SX_EXPORT_BUFFER_SIZES, (COLOR_BUFFER_SIZE((rdev->config.rv770.sx_max_export_size / 4) - 1) |
|
||||||
POSITION_BUFFER_SIZE((rdev->config.rv770.sx_max_export_pos_size / 4) - 1) |
|
POSITION_BUFFER_SIZE((rdev->config.rv770.sx_max_export_pos_size / 4) - 1) |
|
||||||
SMX_BUFFER_SIZE((rdev->config.rv770.sx_max_export_smx_size / 4) - 1)));
|
SMX_BUFFER_SIZE((rdev->config.rv770.sx_max_export_smx_size / 4) - 1)));
|
||||||
|
|
||||||
WREG32(PA_SC_FIFO_SIZE, (SC_PRIM_FIFO_SIZE(rdev->config.rv770.sc_prim_fifo_size) |
|
WREG32(PA_SC_FIFO_SIZE, (SC_PRIM_FIFO_SIZE(rdev->config.rv770.sc_prim_fifo_size) |
|
||||||
SC_HIZ_TILE_FIFO_SIZE(rdev->config.rv770.sc_hiz_tile_fifo_size) |
|
SC_HIZ_TILE_FIFO_SIZE(rdev->config.rv770.sc_hiz_tile_fifo_size) |
|
||||||
SC_EARLYZ_TILE_FIFO_SIZE(rdev->config.rv770.sc_earlyz_tile_fifo_fize)));
|
SC_EARLYZ_TILE_FIFO_SIZE(rdev->config.rv770.sc_earlyz_tile_fifo_fize)));
|
||||||
|
|
||||||
WREG32(PA_SC_MULTI_CHIP_CNTL, 0);
|
WREG32(PA_SC_MULTI_CHIP_CNTL, 0);
|
||||||
|
|
||||||
|
@ -279,6 +279,7 @@ int ttm_tt_set_placement_caching(struct ttm_tt *ttm, uint32_t placement)
|
|||||||
|
|
||||||
return ttm_tt_set_caching(ttm, state);
|
return ttm_tt_set_caching(ttm, state);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(ttm_tt_set_placement_caching);
|
||||||
|
|
||||||
static void ttm_tt_free_alloced_pages(struct ttm_tt *ttm)
|
static void ttm_tt_free_alloced_pages(struct ttm_tt *ttm)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user