On 9/24/21 7:53 AM, Douglas Anderson wrote:
Apparently some compilers [1] cannot handle doing math on dereferenced
string constants at compile time. This has led to reports [2] of
compile errors like:

   In file included from drivers/gpu/drm/drm_edid.c:42:0:
   ./include/drm/drm_edid.h:525:2: error: initializer element is not constant
     ((((u32)((vend)[0]) - '@') & 0x1f) << 26 | \

Go back to the syntax I used in v4 of the patch series [3] that added
this code instead of what landed (v5). This syntax is slightly uglier
but should be much more compatible with varied compilers.

[1] https://gcc.gnu.org/bugzilla/show_bug.cgi?id=69960#c18
[2] https://lore.kernel.org/r/874kaabdt5....@intel.com/
[3] 
https://lore.kernel.org/r/20210909135838.v4.4.I6103ce2b16e5e5a842b14c7022a034712b434609@changeid/

Fixes: d9f91a10c3e8 ("drm/edid: Allow querying/working with the panel ID from the 
EDID")
Reported-by: Stanislav Lisovskiy <stanislav.lisovs...@intel.com>
Reported-by: Srikanth Myakam <smya...@microsoft.com>
Signed-off-by: Douglas Anderson <diand...@chromium.org>
---

  drivers/gpu/drm/drm_edid.c        | 121 +++++++++++++++---------------
  drivers/gpu/drm/panel/panel-edp.c |  23 +++---
  include/drm/drm_edid.h            |  14 ++--
  3 files changed, 81 insertions(+), 77 deletions(-)


Works for me. Thanks.

Acked-by: Randy Dunlap <rdun...@infradead.org> # build-tested


--
~Randy

Reply via email to