[PATCH v13 5/5] uart: pl011: Add support to ZTE ZX296702 uart

Andre Przywara andre.przywara at arm.com
Mon Oct 26 07:42:23 PDT 2015


Hi,

On 26/10/15 14:07, Timur Tabi wrote:
> Andre Przywara wrote:
> 
>> Yeah, I was interested in that scenario too, because the SBSA spec
>> actually speaks of 32-bit registers and vendors may implement it
>> strictly as that. Still waiting for actual failure reports on this
>> before I wanted to push a fix, though.
> 
> What do you mean by failure reports?  Our hardware generates an SError
> if you try to access the PL011 registers with 8-bit or 16-bit reads or
> writes.

I meant that if some hardware does not work with an upstream kernel, I'd
expect some kind of failure report or a patch on the public mailing
list. I may have missed it, but I couldn't find anything on the list so far.

As mentioned earlier, I didn't want to change code without good reasons,
that's why I was waiting for people to scream.

So I just take this as a scream, then ;-)

Can you elaborate on that? Is your UART a PL011 one (using the arm,pl011
DT binding or AMBA ID registers) or are you using the SBSA subset only?
Is there some means to identify this particular UART?

>>> We have an internal patch
>>> that replaces all of the read/write routines with vendor function calls.
>>>   I would need to refactor our patch on top of yours.
>>
>> But wouldn't Jun's patch address this more easily, because it wraps
>> every call already? TBH I found this change the most interesting.
> 
> Yes, but I think it changes a lot of things unnecessarily, like the
> register names.

Which is unfortunate, but cannot be changed anymore. And as much as I
dislike this myself, I guess we cannot ignore this hardware just because
it doesn't go easily with our driver code. So instead of having just
another driver which is strikingly similar, I'd rather have this in the
one-and-only PL011 driver which is much less subject to bit-rot.

So my idea here was to split Jun's series into introducing the
readl/writel wrappers first, and adding the register address mangling on
top of that. Given that those changed register addresses seem to be a
mishap to me, we could just get away with a ZTE specific translate
function, which takes a PL011 register number and returns the actual
register offset to use. That isn't very generic, but would hide this
ugliness without spoiling the whole driver.

So both you and me could benefit from the wrapper functions already,
while Jun has some patches less to care about.

Cheers,
Andre.



More information about the linux-arm-kernel mailing list