Thread (40 messages) 40 messages, 7 authors, 2017-04-03

Re: [PATCH 3/4] mmc: sdhci-of-esdhc: fix host version for T4240-R1.0-R2.0

From: Scott Wood <hidden>
Date: 2016-06-11 02:00:31
Also in: linux-arm-kernel, linux-clk, linux-devicetree, linux-i2c, linux-iommu, linux-mmc, linuxppc-dev, lkml

On Thu, 2016-06-02 at 10:52 +0200, Arnd Bergmann wrote:
On Wednesday, June 1, 2016 8:11:14 PM CEST Scott Wood wrote:
quoted
quoted
+#define T4240_HOST_VER ((VENDOR_V_23 << SDHCI_VENDOR_VER_SHIFT) |
SDHCI_SPEC_200)
+static const struct soc_device_attribute esdhc_t4240_quirk = {
+     /* T4240 revision < 0x20 uses vendor version 23, SDHCI version 200
*/
+     { .soc_id = "T4*(0x824000)", .revision = "0x[01]?",
+       .data = (void *)(uintptr_t)(T4240_HOST_VER) },
Why should this code need to care that the string begins with "T4"?  This
creates dual maintenance if that were to change.  It's also broken because
T4240 has compatible = "fsl,t4240-device-config", "fsl,qoriq-device-config
-2.0" and thus with these patches it would incorrectly show up as "P
series
(0x824000)".  The compatible string of this node was never meant to be a
key
for choosing a string to describe the system to userspace.
This is an artifact of not knowing the specific SoC name, and we can change
that by looking up the name from the SVR value in the soc_device driver.
...or we could keep it simple and just match the number.
quoted
0x824000 is a magic number which should be represented symbolically.
Sure, feel free to change the format of the soc_device string in any
name,
That's not what I was asking for...  The match should be numeric but the
knowledge of what the number is should come from a symbolic #define.
quoted
If T4240 is affected, then so are the reduced-core variants T4160 and
T4080,
but 0x824000 doesn't match them (Yangbo's patch had the same problem). 
 And
please don't respond with "0x824*"

You also didn't strip out the E bit of SVR which indicates encryption
capability and nothing else (Yangbo's patch did not have this problem
because
it used SVR_SOC_VER).
Ok, that should be easy enough to fix in the soc_device driver.
No, because the soc_device driver doesn't know whether the consumer of the ID
cares about the E bit.
quoted
What happens if the revision condition is more complicated, such as <=
0x20
with 0x21 being fine?  Multiple quirk entries where before we had as
simple
comparison?
I guess yes. I would really hope that there is no need to use this interface
pervasively, it's really just to work around the cases where there is no
way to pass the information in DT otherwise.
How does putting it in the DT work when you have multiple versions of the same
SoC, some of which have the bug and some which don't?
quoted
I fail to see how this approach is an improvement (much less one that
needs to
hold up a patchset that is fixing a problem and is not touching any
generic
code).  Why does this need to be a string?
A string is what user space gets in /sys/devices/soc/*,
It is rare that the kernel accesses information in the exact same way that
userspace does.  And once we expose this to userspace we're stuck with it, so
exporting anything other than a simple number is even less desirable.
 and we already have
code that does the same things there to work around quirks, here we just
use the same interface in a completely generic way. Note that not every
SoC family uses numbers in the same way, some have multiple subrevisions,
some have names etc.
Where is the need for a "completely generic way" for one piece of vendor
-specific code to get information that is inherently specific to that vendor,
that is supplied by code specific to that vendor?

-Scott
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help