[PATCH] drm/mgag200: Reject modes that are too big for VRAM
Paul Menzel
paulepanter at users.sourceforge.net
Tue Feb 26 15:34:56 PST 2013
Am Dienstag, den 26.02.2013, 10:55 -0500 schrieb Christopher Harvey:
> A monitor or a user could request a resolution greater than the
> available VRAM for the backing framebuffer. This change checks the
> required framebuffer size against the max VRAM size and rejects modes
> if they are too big. This change can also remove a mode request passed
> in via the video= parameter.
>
> Signed-off-by: Christopher Harvey <charvey at matrox.com>
> ---
> drivers/gpu/drm/mgag200/mgag200_mode.c | 27 +++++++++++++++++++++++++++
> 1 file changed, 27 insertions(+)
>
> diff --git a/drivers/gpu/drm/mgag200/mgag200_mode.c b/drivers/gpu/drm/mgag200/mgag200_mode.c
> index 3abf197..6b5db83 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_mode.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_mode.c
> @@ -1405,6 +1405,14 @@ static int mga_vga_get_modes(struct drm_connector *connector)
> static int mga_vga_mode_valid(struct drm_connector *connector,
> struct drm_display_mode *mode)
> {
> + struct drm_device *dev = connector->dev;
> + struct mga_device *mdev = (struct mga_device*)dev->dev_private;
> + struct mga_fbdev *mfbdev = mdev->mfbdev;
> + struct drm_fb_helper *fb_helper = &mfbdev->helper;
> + struct drm_fb_helper_connector *fb_helper_conn = NULL;
> + int bpp = 32;
> + int i = 0;
It is initialized in the for loop again.
> +
> /* FIXME: Add bandwidth and g200se limitations */
>
> if (mode->crtc_hdisplay > 2048 || mode->crtc_hsync_start > 4096 ||
> @@ -1414,6 +1422,25 @@ static int mga_vga_mode_valid(struct drm_connector *connector,
> return MODE_BAD;
> }
>
> + /* Validate the mode input by the user */
> + for (i = 0; i < fb_helper->connector_count; i++) {
> + if (fb_helper->connector_info[i]->connector == connector) {
> + /* Found the helper for this connector */
> + fb_helper_conn = fb_helper->connector_info[i];
> + if (fb_helper_conn->cmdline_mode.specified) {
> + if (fb_helper_conn->cmdline_mode.bpp_specified) {
> + bpp = fb_helper_conn->cmdline_mode.bpp;
> + }
> + }
> + }
> + }
Is such a function not used somewhere else already? Like get
user_parameters or so?
> +
> + if ((mode->hdisplay * mode->vdisplay * (bpp/8)) > mdev->mc.vram_size) {
> + if (fb_helper_conn)
> + fb_helper_conn->cmdline_mode.specified = false;
A debug message specifying that this is due to VRAM size would be
helpful I guess.
> + return MODE_BAD;
I guess that will print the requested mode so it does not need to be
specified above.
> + }
> +
> return MODE_OK;
> }
>
Thanks,
Paul
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 198 bytes
Desc: This is a digitally signed message part
URL: <http://lists.freedesktop.org/archives/dri-devel/attachments/20130227/86c1ba0f/attachment.pgp>
More information about the dri-devel
mailing list