[PATCH] radeon: fix r600/agp when vram is after AGP (v3)

Alex Deucher alexdeucher at gmail.com
Tue Apr 17 14:17:33 PDT 2012


On Tue, Apr 17, 2012 at 4:51 PM,  <j.glisse at gmail.com> wrote:
> From: Jerome Glisse <jglisse at redhat.com>
>
> If AGP is placed in the middle, the size_af is off-by-one, it results
> in VRAM being placed at 0x7fffffff instead of 0x8000000.
>
> v2: fix the vram_start setup.
> v3: also fix r7xx & newer ASIC
>
> Reported-by: russiane39 on #radeon
>
> Signed-off-by: Dave Airlie <airlied at redhat.com>
> Signed-off-by: Jerome Glisse <jglisse at redhat.com>

Reviewed-by: Alex Deucher <alexander.deucher at amd.com>

Should also go to stable.

> ---
>  drivers/gpu/drm/radeon/r600.c  |    4 ++--
>  drivers/gpu/drm/radeon/rv770.c |    4 ++--
>  2 files changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c
> index 391bd26..96e3fa3 100644
> --- a/drivers/gpu/drm/radeon/r600.c
> +++ b/drivers/gpu/drm/radeon/r600.c
> @@ -1135,7 +1135,7 @@ static void r600_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc
>        }
>        if (rdev->flags & RADEON_IS_AGP) {
>                size_bf = mc->gtt_start;
> -               size_af = 0xFFFFFFFF - mc->gtt_end + 1;
> +               size_af = 0xFFFFFFFF - mc->gtt_end;
>                if (size_bf > size_af) {
>                        if (mc->mc_vram_size > size_bf) {
>                                dev_warn(rdev->dev, "limiting VRAM\n");
> @@ -1149,7 +1149,7 @@ static void r600_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc
>                                mc->real_vram_size = size_af;
>                                mc->mc_vram_size = size_af;
>                        }
> -                       mc->vram_start = mc->gtt_end;
> +                       mc->vram_start = mc->gtt_end + 1;
>                }
>                mc->vram_end = mc->vram_start + mc->mc_vram_size - 1;
>                dev_info(rdev->dev, "VRAM: %lluM 0x%08llX - 0x%08llX (%lluM used)\n",
> diff --git a/drivers/gpu/drm/radeon/rv770.c b/drivers/gpu/drm/radeon/rv770.c
> index c62ae4b..cdab1ae 100644
> --- a/drivers/gpu/drm/radeon/rv770.c
> +++ b/drivers/gpu/drm/radeon/rv770.c
> @@ -969,7 +969,7 @@ void r700_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc)
>        }
>        if (rdev->flags & RADEON_IS_AGP) {
>                size_bf = mc->gtt_start;
> -               size_af = 0xFFFFFFFF - mc->gtt_end + 1;
> +               size_af = 0xFFFFFFFF - mc->gtt_end;
>                if (size_bf > size_af) {
>                        if (mc->mc_vram_size > size_bf) {
>                                dev_warn(rdev->dev, "limiting VRAM\n");
> @@ -983,7 +983,7 @@ void r700_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc)
>                                mc->real_vram_size = size_af;
>                                mc->mc_vram_size = size_af;
>                        }
> -                       mc->vram_start = mc->gtt_end;
> +                       mc->vram_start = mc->gtt_end + 1;
>                }
>                mc->vram_end = mc->vram_start + mc->mc_vram_size - 1;
>                dev_info(rdev->dev, "VRAM: %lluM 0x%08llX - 0x%08llX (%lluM used)\n",
> --
> 1.7.9.3
>
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel


More information about the dri-devel mailing list