[RFC PATCH v1 2/5] misc: tda8026: Add NXP TDA8026 PHY driver
Satish Patel
satish.patel at ti.com
Tue Jan 7 01:36:37 EST 2014
On 1/6/2014 9:00 PM, Mark Rutland wrote:
> On Mon, Jan 06, 2014 at 12:07:39PM +0000, Satish Patel wrote:
>> TDA8026 is a SmartCard PHY from NXP.
>>
>> The PHY interfaces with the main processor over the
>> I2C interface and acts as a slave device.
>>
>> The driver also exposes the phy interface
>> (defined at include/linux/sc_phy.h) for SmartCard controller.
>> Controller uses this interface to communicate with smart card
>> inserted to the phy's slot.
>>
>> Note: gpio irq is not validated as I do not have device with that.
>> I have validated interrupt with dedicated interrupt line on my device.
>>
>> Signed-off-by: Maulik Mankad <maulik at ti.com>
>> Signed-off-by: Satish Patel <satish.patel at ti.com>
>> ---
>> Documentation/devicetree/bindings/misc/tda8026.txt | 14 +
>> drivers/misc/Kconfig | 7 +
>> drivers/misc/Makefile | 1 +
>> drivers/misc/tda8026.c | 1271 ++++++++++++++++++++
>> 4 files changed, 1293 insertions(+), 0 deletions(-)
>> create mode 100644 Documentation/devicetree/bindings/misc/tda8026.txt
>> create mode 100644 drivers/misc/tda8026.c
>>
>> diff --git a/Documentation/devicetree/bindings/misc/tda8026.txt b/Documentation/devicetree/bindings/misc/tda8026.txt
>> new file mode 100644
>> index 0000000..d3083bf
>> --- /dev/null
>> +++ b/Documentation/devicetree/bindings/misc/tda8026.txt
>> @@ -0,0 +1,14 @@
>> +TDA8026 smart card slot interface
>> +
>> +Required properties:
>> +- compatible: nxp,tda8026
>
> Please quote strings:
>
> - compatible: should contain "nxp,tda8026"
ok
>
>> +- shutdown-gpio = GPIO pin mapping for SDWNN pin
>> +- reg = i2c interface address
>
> It's probably worth mentioning at the start that this is an i2c device.
>
> [...]
ok
>
>> +static int tda8026_parse_dt(struct device *dev, struct tda8026 *pdata)
>> +{
>> + struct device_node *np = dev->of_node;
>> + const struct of_device_id *match;
>> + int ret = 0;
>> +
>> + match = of_match_device(of_match_ptr(tda8026_id_table), dev);
>> + if (!match)
>> + return -EINVAL;
>
> Why do this? The of_device_id table contains one entry with no
> additional data. If you just want to see if this was probed via DT,
> dev->of_node not being NULL would tell you that.
>
agree..
> Is this going to be used without DT anywhere?
>
> [...]
>
>> + if (pdata->irq == 0) {
>> + /* look for the field irq-gpio in DT */
>> + irq_gpio = of_get_named_gpio(np, "irq-gpio", 0);
>> + if (!gpio_is_valid(irq_gpio)) {
>> + dev_err(dev, "Failed to get irq gpio,\n");
>> + return -EIO;
>> + }
>
> This is horrible. If the gpio controller can act as an irq controller
No it's not true. Let me clarify the signal flow,
Pins => GPIO => GPIO BANK => Interrupt controller => CPU/MPU
> then it should be annotated as such, with #interrupt-cells, and you
> should just describe the interrupt. The smart card controller cares
> about having an interrupt line, not a GPIO.
>
Let me quote MMC card-detect example here,
File: drivers/mmc/host/omap_hsmmc.c
Card detection is happening through GPIO (same as what this patch is
doing). Please refer to the probe sequence, you will find exactly same
thing there too.
AM437x device has a special feature for the USIM Phy, where the PHY
interrupt automatically gets hooked up to interrupt-controller and
the driver gets interrupt number from DT using #interrupt-cells, exactly
what you had mentioned.
But if same PHY gets interfaced to other SoC's over GPIO, then in order
to handle that scenario you __must__ go through gpio_to_irq().
Let me add another important point here,
You can not determine irq number for the given GPIO, as it gets
allocated dynamically based on GPIO banks supported on the device and on
the board.
> Additionally, this was not described in the binding.
>
> Thanks,
> Mark.
>
More information about the linux-arm-kernel
mailing list