Re: [PATCH 1/2 v2] drm/pl111: Support the Versatile Express

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, Apr 8, 2018 at 3:16 AM, Eric Anholt <eric@xxxxxxxxxx> wrote:
> Linus Walleij <linus.walleij@xxxxxxxxxx> writes:

>> -     void *regs;
>> +     void __iomem *clcd_memory;
>
> This doesn't seem to be used anywhere.

Ah development artifact, I'll get rid of it.

>> +int pl111_vexpress_clcd_init(struct device *dev,
>> +                          struct pl111_drm_dev_private *priv,
>> +                          struct regmap *map)
>> +{
>> +     struct device_node *memory;
>> +     u32 val;
>> +     int ret;
>> +
>> +     /*
>> +      * The CLCD on the motherboard has a special memory region and
>> +      * does not make use of CMA. We differentiate between the different
>> +      * CLCD controllers using this memory region phandle.
>> +      */
>> +     memory = of_parse_phandle(dev->of_node, "memory-region", 0);
>> +     if (!memory) {
>> +             if (motherboard_muxed) {
>> +                     dev_info(dev, "motherboard CLCD muxed in\n");
>> +                     dev_info(dev, "daughterboard takes precedence\n");
>> +                     dev_info(dev, "motherboard CLCD will not be muxed out\n");
>> +             }
>> +             dev_info(dev,
>> +                      "DVI muxed to daughterboard 1 (core tile) CLCD\n");
>> +             val = VEXPRESS_FPGAMUX_DAUGHTERBOARD_1;
>> +             daughterboard_muxed = true;
>> +     } else {
>> +             priv->clcd_memory = of_iomap(memory, 0);
>> +             if (!priv->clcd_memory)
>> +                     dev_err(dev, "could not remap CLCD memory\n");
>> +             /* Fall through and try to use CMA */
>> +             if (daughterboard_muxed) {
>> +                     dev_info(dev, "daughterboard takes precedence\n");
>> +                     dev_info(dev, "motherboard CLCD will not be muxed out\n");
>> +                     return -ENODEV;
>> +             }
>> +             dev_info(dev, "DVI muxed to motherboard CLCD\n");
>> +             val = VEXPRESS_FPGAMUX_MOTHERBOARD;
>> +             motherboard_muxed = true;
>> +     }
>
> I'm confused by global bools here.  It seems like we're trying to
> coordinate between the instantiation of multiple CLCDs here, to set up
> the mux appropriately.  Does it make sense to do things that way, if
> probe order is unreliable?

Hm I guess I should parse the graph and see what is connected instead,
and bail out if we have two CLCDs and are not the desired one.

I'll go and poke at it.

Yours,
Linus Walleij
_______________________________________________
dri-devel mailing list
dri-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/dri-devel




[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux