Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp7154965ybi; Mon, 8 Jul 2019 15:45:33 -0700 (PDT) X-Google-Smtp-Source: APXvYqyEAjpQTkTsIh9c14vIjnDADadhK75G79KmYCcK3dSyT5+10Kw5itnFnKAwqAB0y+a8hPGS X-Received: by 2002:a63:5045:: with SMTP id q5mr25994318pgl.380.1562625933735; Mon, 08 Jul 2019 15:45:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562625933; cv=none; d=google.com; s=arc-20160816; b=uSr+ss727RUe0IbzreOEijXB8+VTjnaOdatnppbGfsZDW1TNpvGReofe5agxhcI1Xq Dn31vOba/aG+XajoFk3G4k/6JsMOPgOfyBJODOwza5klg92Nj7sNy/FHZSTaqpVeTkpj IJ4Ja7Q7jdLJQyBRXDgTuqUPVvOv+znT2cc4gAKnn2cMHiCx9QxbNjH05vJ/g1V+h0pM cNecRyFEBY05lqD00JlUBcP3G9qSihvvD1hLUgNu948PkuBRdeTpi44KKZ2no6ZXjmSp +6C6wzOJLHTJ858mW1m8PqAXquPdCvGUkOhoyYTM058xF/NrhyziAvBSsnnOmaLdwm2r +vmg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=VvGCD+bxIp7fP+9atqFhItEKrSYK1tWl3xzYXGOqd5s=; b=OicN2OUq5QcBsYiCdkrJiYEabEZ8nusIdNUgp/Q15Mk4FfWFKSFdoo+hZx8ah+Guj+ Nmh/pQ6i+i9/JLwZp+KkuAnNBoeStbYRJLwZk3jMGcG01BF6cBGnEVhk0TzfZKpIDzcQ 75ah3AgDDtwTIeaRoaegTWYBQVd7gspQuCBLfkm+LB6lxbuPM0emis5hV3a44NLSEugd 9r5GDfVn8e0JAAPdxb9dVa82XoiLnBKYr9ZfsM7u+4rYFnsV+x+v84gY4SUm8GHaI4sG KYuC4iOCsuZtyDY+Ii03gyD/MlqrDgIrfhXvgqMUbQ4XMapdRtvc0OTkP/ljAxvCUyiD Vu1Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k193si19439956pge.330.2019.07.08.15.45.19; Mon, 08 Jul 2019 15:45:33 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404055AbfGHRuQ (ORCPT + 99 others); Mon, 8 Jul 2019 13:50:16 -0400 Received: from asavdk4.altibox.net ([109.247.116.15]:41184 "EHLO asavdk4.altibox.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730936AbfGHRuP (ORCPT ); Mon, 8 Jul 2019 13:50:15 -0400 Received: from ravnborg.org (unknown [158.248.194.18]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by asavdk4.altibox.net (Postfix) with ESMTPS id 6F4BD80636; Mon, 8 Jul 2019 19:50:09 +0200 (CEST) Date: Mon, 8 Jul 2019 19:50:08 +0200 From: Sam Ravnborg To: Doug Anderson Cc: Thierry Reding , Heiko Stuebner , Sean Paul , devicetree@vger.kernel.org, Rob Herring , David Airlie , Jeffy Chen , dri-devel , LKML , "open list:ARM/Rockchip SoC..." , Boris Brezillon , Laurent Pinchart , Enric =?iso-8859-1?Q?Balletb=F2?= , =?iso-8859-1?Q?St=E9phane?= Marchesin , Ezequiel Garcia , Matthias Kaehlcke Subject: Re: [PATCH v5 2/7] drm/panel: simple: Add ability to override typical timing Message-ID: <20190708175007.GA3511@ravnborg.org> References: <20190401171724.215780-1-dianders@chromium.org> <20190401171724.215780-3-dianders@chromium.org> <20190630202246.GB15102@ravnborg.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) X-CMAE-Score: 0 X-CMAE-Analysis: v=2.3 cv=VcLZwmh9 c=1 sm=1 tr=0 a=UWs3HLbX/2nnQ3s7vZ42gw==:117 a=UWs3HLbX/2nnQ3s7vZ42gw==:17 a=jpOVt7BSZ2e4Z31A5e1TngXxSK0=:19 a=kj9zAlcOel0A:10 a=7gkXJVJtAAAA:8 a=AWgJsaMlI6ysr0MxQJMA:9 a=0846P8UFn4bgp1PN:21 a=puqGkp3IltQWEqwz:21 a=CjuIK1q_8ugA:10 a=E9Po1WZjFZOl8hwRPBS3:22 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Dough. On Mon, Jul 01, 2019 at 09:39:24AM -0700, Doug Anderson wrote: > Hi, > > On Sun, Jun 30, 2019 at 1:22 PM Sam Ravnborg wrote: > > > > > @@ -91,6 +92,8 @@ struct panel_simple { > > > struct i2c_adapter *ddc; > > > > > > struct gpio_desc *enable_gpio; > > > + > > > + struct drm_display_mode override_mode; > > I fail to see where this poiter is assigned. > > In panel_simple_parse_override_mode(). Specifically: > > drm_display_mode_from_videomode(&vm, &panel->override_mode); The above code-snippet is only called in the panel has specified display timings using display_timings - it is not called when display_mode is used. So override_mode is only assigned in some cases and not all cases. This needs to be fixed so we do not reference override_mode unless it is set. > > > > @@ -152,6 +162,44 @@ static int panel_simple_get_fixed_modes(struct panel_simple *panel) > > > num++; > > > } > > > > > > + return num; > > > +} > > > + > > > +static int panel_simple_get_non_edid_modes(struct panel_simple *panel) > > > +{ > > > + struct drm_connector *connector = panel->base.connector; > > > + struct drm_device *drm = panel->base.drm; > > > + struct drm_display_mode *mode; > > > + bool has_override = panel->override_mode.type; > > This looks suspicious. > > panel->override_mode.type is an unsigned int that may have a number of > > bits set. > > So the above code implicitly convert a .type != 0 to a true. > > This can be expressed in a much more reader friendly way. > > You would suggest that I add a boolean field to a structure to > indicate whether an override mode is present? A simple bool has_override = panel->override_mode.type != 0; would do the trick here. Then there is no hidden conversion from int to a bool. But as override_mode can be NULL something more needs to be done. Sam