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@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@xxxxxx> > Signed-off-by: Satish Patel <satish.patel@xxxxxx> > --- > 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" > +- 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. [...] > +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. 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 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. Additionally, this was not described in the binding. Thanks, Mark. -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html