Skip to content

Commit

Permalink
drm/qxl: use separate offset spaces for the two slots / ttm memory ty…
Browse files Browse the repository at this point in the history
…pes.

Without that ttm offsets are not unique, they can refer to objects
in both VRAM and PRIV memory (aka main and surfaces slot).

One of those "why things didn't blow up without this" moments.
Probably offset conflicts are rare enough by pure luck.

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Acked-by: Noralf Trønnes <noralf@tronnes.org>
Link: http://patchwork.freedesktop.org/patch/msgid/20190118122020.27596-7-kraxel@redhat.com
  • Loading branch information
Gerd Hoffmann committed Jan 28, 2019
1 parent 3ebe3dd commit 96e8f15
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 4 deletions.
5 changes: 4 additions & 1 deletion drivers/gpu/drm/qxl/qxl_drv.h
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,7 @@ struct qxl_memslot {
uint64_t start_phys_addr;
uint64_t size;
uint64_t high_bits;
uint64_t gpu_offset;
};

enum {
Expand Down Expand Up @@ -312,8 +313,10 @@ qxl_bo_physical_address(struct qxl_device *qdev, struct qxl_bo *bo,
(bo->tbo.mem.mem_type == TTM_PL_VRAM)
? &qdev->main_slot : &qdev->surfaces_slot;

WARN_ON_ONCE((bo->tbo.offset & slot->gpu_offset) != slot->gpu_offset);

/* TODO - need to hold one of the locks to read tbo.offset */
return slot->high_bits | (bo->tbo.offset + offset);
return slot->high_bits | (bo->tbo.offset - slot->gpu_offset + offset);
}

/* qxl_fb.c */
Expand Down
5 changes: 3 additions & 2 deletions drivers/gpu/drm/qxl/qxl_kms.c
Original file line number Diff line number Diff line change
Expand Up @@ -83,10 +83,11 @@ static void setup_slot(struct qxl_device *qdev,
high_bits <<= (64 - (qdev->rom->slot_gen_bits + qdev->rom->slot_id_bits));
slot->high_bits = high_bits;

DRM_INFO("slot %d (%s): base 0x%08lx, size 0x%08lx\n",
DRM_INFO("slot %d (%s): base 0x%08lx, size 0x%08lx, gpu_offset 0x%lx\n",
slot->index, slot->name,
(unsigned long)slot->start_phys_addr,
(unsigned long)slot->size);
(unsigned long)slot->size,
(unsigned long)slot->gpu_offset);
}

void qxl_reinit_memslots(struct qxl_device *qdev)
Expand Down
10 changes: 9 additions & 1 deletion drivers/gpu/drm/qxl/qxl_ttm.c
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,11 @@ static int qxl_invalidate_caches(struct ttm_bo_device *bdev, uint32_t flags)
static int qxl_init_mem_type(struct ttm_bo_device *bdev, uint32_t type,
struct ttm_mem_type_manager *man)
{
struct qxl_device *qdev = qxl_get_qdev(bdev);
unsigned int gpu_offset_shift =
64 - (qdev->rom->slot_gen_bits + qdev->rom->slot_id_bits + 8);
struct qxl_memslot *slot;

switch (type) {
case TTM_PL_SYSTEM:
/* System memory */
Expand All @@ -110,8 +115,11 @@ static int qxl_init_mem_type(struct ttm_bo_device *bdev, uint32_t type,
case TTM_PL_VRAM:
case TTM_PL_PRIV:
/* "On-card" video ram */
slot = (type == TTM_PL_VRAM) ?
&qdev->main_slot : &qdev->surfaces_slot;
slot->gpu_offset = (uint64_t)type << gpu_offset_shift;
man->func = &ttm_bo_manager_func;
man->gpu_offset = 0;
man->gpu_offset = slot->gpu_offset;
man->flags = TTM_MEMTYPE_FLAG_FIXED |
TTM_MEMTYPE_FLAG_MAPPABLE;
man->available_caching = TTM_PL_MASK_CACHING;
Expand Down

0 comments on commit 96e8f15

Please sign in to comment.