[PATCH 3/4] compositor-drm: Return the newly added mode in drm_output_add_mode()

Kristian Høgsberg hoegsberg at gmail.com
Thu Aug 9 11:38:50 PDT 2012


On Thu, Aug 09, 2012 at 04:45:00PM +0300, Ander Conselvan de Oliveira wrote:
> Most of the times the caller will look at the output's mode list to get
> the new mode, so just return that instead.

That looks better.

Kristian

> ---
>  src/compositor-drm.c |   42 +++++++++++++++++++-----------------------
>  1 file changed, 19 insertions(+), 23 deletions(-)
> 
> diff --git a/src/compositor-drm.c b/src/compositor-drm.c
> index 33bffae..2ec6705 100644
> --- a/src/compositor-drm.c
> +++ b/src/compositor-drm.c
> @@ -1116,7 +1116,7 @@ init_egl(struct drm_compositor *ec, struct udev_device *device)
>  	return 0;
>  }
>  
> -static int
> +static struct drm_mode *
>  drm_output_add_mode(struct drm_output *output, drmModeModeInfo *info)
>  {
>  	struct drm_mode *mode;
> @@ -1124,7 +1124,7 @@ drm_output_add_mode(struct drm_output *output, drmModeModeInfo *info)
>  
>  	mode = malloc(sizeof *mode);
>  	if (mode == NULL)
> -		return -1;
> +		return NULL;
>  
>  	mode->base.flags = 0;
>  	mode->base.width = info->hdisplay;
> @@ -1149,7 +1149,7 @@ drm_output_add_mode(struct drm_output *output, drmModeModeInfo *info)
>  
>  	wl_list_insert(output->base.mode_list.prev, &mode->base.link);
>  
> -	return 0;
> +	return mode;
>  }
>  
>  static int
> @@ -1331,13 +1331,13 @@ create_output_for_connector(struct drm_compositor *ec,
>  			    int x, int y, struct udev_device *drm_device)
>  {
>  	struct drm_output *output;
> -	struct drm_mode *drm_mode, *next;
> -	struct weston_mode *m, *preferred, *current, *configured;
> +	struct drm_mode *drm_mode, *next, *preferred, *current, *configured;
> +	struct weston_mode *m;
>  	struct drm_configured_output *o = NULL, *temp;
>  	drmModeEncoder *encoder;
>  	drmModeModeInfo crtc_mode;
>  	drmModeCrtc *crtc;
> -	int i, ret;
> +	int i;
>  	char name[32];
>  	const char *type_name;
>  
> @@ -1386,8 +1386,8 @@ create_output_for_connector(struct drm_compositor *ec,
>  	}
>  
>  	for (i = 0; i < connector->count_modes; i++) {
> -		ret = drm_output_add_mode(output, &connector->modes[i]);
> -		if (ret)
> +		drm_mode = drm_output_add_mode(output, &connector->modes[i]);
> +		if (!drm_mode)
>  			goto err_free;
>  	}
>  
> @@ -1416,41 +1416,37 @@ create_output_for_connector(struct drm_compositor *ec,
>  		if (o && o->width == drm_mode->base.width &&
>  			o->height == drm_mode->base.height &&
>  			o->config == OUTPUT_CONFIG_MODE)
> -			configured = &drm_mode->base;
> +			configured = drm_mode;
>  		if (!memcmp(&crtc_mode, &drm_mode->mode_info, sizeof crtc_mode))
> -			current = &drm_mode->base;
> +			current = drm_mode;
>  		if (drm_mode->base.flags & WL_OUTPUT_MODE_PREFERRED)
> -			preferred = &drm_mode->base;
> +			preferred = drm_mode;
>  	}
>  
>  	if (o && o->config == OUTPUT_CONFIG_MODELINE) {
> -		ret = drm_output_add_mode(output, &o->crtc_mode);
> -		if (ret)
> +		configured = drm_output_add_mode(output, &o->crtc_mode);
> +		if (!configured)
>  			goto err_free;
> -		configured = container_of(output->base.mode_list.prev,
> -				       struct weston_mode, link);
>  		current = configured;
>  	}
>  
>  	if (current == NULL && crtc_mode.clock != 0) {
> -		ret = drm_output_add_mode(output, &crtc_mode);
> -		if (ret)
> +		current = drm_output_add_mode(output, &crtc_mode);
> +		if (!current)
>  			goto err_free;
> -		current = container_of(output->base.mode_list.prev,
> -				       struct weston_mode, link);
>  	}
>  
>  	if (o && o->config == OUTPUT_CONFIG_CURRENT)
>  		configured = current;
>  
>  	if (option_current_mode && current)
> -		output->base.current = current;
> +		output->base.current = &current->base;
>  	else if (configured)
> -		output->base.current = configured;
> +		output->base.current = &configured->base;
>  	else if (preferred)
> -		output->base.current = preferred;
> +		output->base.current = &preferred->base;
>  	else if (current)
> -		output->base.current = current;
> +		output->base.current = &current->base;
>  
>  	if (output->base.current == NULL) {
>  		weston_log("no available modes for %s\n", output->name);
> -- 
> 1.7.9.5
> 
> _______________________________________________
> wayland-devel mailing list
> wayland-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/wayland-devel


More information about the wayland-devel mailing list