On Tue, 2012-05-08 at 15:28 +0530, Archit Taneja wrote: > In order to check the validity of overlay and manager info, there was a need to > use the omap_dss_device struct to get the panel resolution. The manager's > private data in APPLY now contains the manager timings. Hence, we don't need to > rely on the display resolution any more. > > Pass the manager's timings(in private data) to dss_mgr_check(). Remove the need > of passing omap_dss_device structs in the functions which check for overlay and > managers. > > Have some initial values for manager timings in apply_init(), these would ensure > that manager checks don't fail if an interface driver or a panel driver hasn't > set the manager timings yet. In what code patch were the initial values needed? Checking the validity of all the settings is a bit tricky, but currently I think, as a rule of thumb, we should accept any settings when things are disabled. So, until the interface driver sets the timings before enabling the output, all ovl/mgr settings should be allowed. And we shouldn't even write any shadow registers until the moment the output is enabled. Except settings that do not depend on anything, like, if max ovl width is 2048, it's fine to reject 2049+ width anytime. > -int dss_ovl_check(struct omap_overlay *ovl, > - struct omap_overlay_info *info, struct omap_dss_device *dssdev) > +int dss_ovl_check(struct omap_overlay *ovl, struct omap_overlay_info *info, > + const struct omap_video_timings *mgr_timings) > { > u16 outw, outh; > - u16 dw, dh; > + u16 mgr_width, mgr_height; > > - if (dssdev == NULL) > - return 0; > - > - dssdev->driver->get_resolution(dssdev, &dw, &dh); > + mgr_width = mgr_timings->x_res; > + mgr_height = mgr_timings->y_res; I think you could've just used the existing dw and dh variables, thus avoiding the need to change the rest of the function. The 'd' refers to display, which is more or less the same as mgr width. Tomi
Attachment:
signature.asc
Description: This is a digitally signed message part