The patch titled gpio max7301: check spi_setup() return code, cleanup has been removed from the -mm tree. Its filename was gpio-gpio-driver-for-max7301-spi-gpio-expander-check-spi_setup-return-code-cleanup.patch This patch was dropped because it was folded into gpio-gpio-driver-for-max7301-spi-gpio-expander.patch The current -mm tree may be found at http://userweb.kernel.org/~akpm/mmotm/ ------------------------------------------------------ Subject: gpio max7301: check spi_setup() return code, cleanup From: Guennadi Liakhovetski <g.liakhovetski@xxxxxxxxxxxxxx> Fix inaccuracies in comments, check spi_setup() return code, mask off high byte in max7301_read(). Thanks to David Brownell for the review. Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@xxxxxxxxxxxxxx> Signed-off-by: David Brownell <dbrownell@xxxxxxxxxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- drivers/gpio/max7301.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff -puN drivers/gpio/max7301.c~gpio-gpio-driver-for-max7301-spi-gpio-expander-check-spi_setup-return-code-cleanup drivers/gpio/max7301.c --- a/drivers/gpio/max7301.c~gpio-gpio-driver-for-max7301-spi-gpio-expander-check-spi_setup-return-code-cleanup +++ a/drivers/gpio/max7301.c @@ -71,7 +71,7 @@ struct max7301 { * * A write to the MAX7301 means one message with one transfer * - * Returns 0 if successfull or a negative value on error + * Returns 0 if successful or a negative value on error */ static int max7301_write(struct spi_device *spi, unsigned int reg, unsigned int val) { @@ -84,9 +84,9 @@ static int max7301_write(struct spi_devi * @spi: The SPI device * @reg: Register offset * - * A read from the MAX7301 means one message with two transfers + * A read from the MAX7301 means two transfers; here, one message each * - * Returns positive 8 bit value from device if successfull or a + * Returns positive 8 bit value from device if successful or a * negative value on error */ static int max7301_read(struct spi_device *spi, unsigned int reg) @@ -99,12 +99,13 @@ static int max7301_read(struct spi_devic if (ret) return ret; /* - * FIXME: This read should write 0x0000 (=NOOP at MAX7301 side) + * This relies on the fact, that a transfer with NULL tx_buf shifts out + * zero bytes (=NOOP for MAX7301) */ ret = spi_read(spi, (u8 *)&word, sizeof(word)); if (ret) return ret; - return word; + return word & 0xff; } static int max7301_direction_input(struct gpio_chip *chip, unsigned offset) @@ -224,7 +225,9 @@ static int __devinit max7301_probe(struc */ spi->bits_per_word = 16; - spi->master->setup(spi); + ret = spi_setup(spi); + if (ret < 0) + return ret; ts = kzalloc(sizeof(struct max7301), GFP_KERNEL); if (!ts) _ Patches currently in -mm which might be from g.liakhovetski@xxxxxxxxxxxxxx are origin.patch gpio-gpio-driver-for-max7301-spi-gpio-expander.patch gpio-gpio-driver-for-max7301-spi-gpio-expander-check-spi_setup-return-code-cleanup.patch linux-next.patch git-arm.patch git-dvb.patch gpio-sysfs-interface-updated.patch gpio-sysfs-interface-updated-update.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html