提交 19f15f0e 编写于 作者: M Mark Brown

Merge branches 'spi-core' and 'spi-tegra' into spi-next

...@@ -727,8 +727,7 @@ static int tegra_slink_start_transfer_one(struct spi_device *spi, ...@@ -727,8 +727,7 @@ static int tegra_slink_start_transfer_one(struct spi_device *spi,
unsigned long command; unsigned long command;
unsigned long command2; unsigned long command2;
bits_per_word = t->bits_per_word ? t->bits_per_word : bits_per_word = t->bits_per_word;
spi->bits_per_word;
speed = t->speed_hz ? t->speed_hz : spi->max_speed_hz; speed = t->speed_hz ? t->speed_hz : spi->max_speed_hz;
if (!speed) if (!speed)
speed = tspi->spi_max_frequency; speed = tspi->spi_max_frequency;
...@@ -1110,8 +1109,8 @@ const struct tegra_slink_chip_data tegra20_spi_cdata = { ...@@ -1110,8 +1109,8 @@ const struct tegra_slink_chip_data tegra20_spi_cdata = {
}; };
static struct of_device_id tegra_slink_of_match[] __devinitconst = { static struct of_device_id tegra_slink_of_match[] __devinitconst = {
{ .compatible = "nvidia,tegra20-slink", .data = &tegra20_spi_cdata, },
{ .compatible = "nvidia,tegra30-slink", .data = &tegra30_spi_cdata, }, { .compatible = "nvidia,tegra30-slink", .data = &tegra30_spi_cdata, },
{ .compatible = "nvidia,tegra20-slink", .data = &tegra20_spi_cdata, },
{} {}
}; };
MODULE_DEVICE_TABLE(of, tegra_slink_of_match); MODULE_DEVICE_TABLE(of, tegra_slink_of_match);
......
...@@ -1156,7 +1156,7 @@ EXPORT_SYMBOL_GPL(spi_busnum_to_master); ...@@ -1156,7 +1156,7 @@ EXPORT_SYMBOL_GPL(spi_busnum_to_master);
int spi_setup(struct spi_device *spi) int spi_setup(struct spi_device *spi)
{ {
unsigned bad_bits; unsigned bad_bits;
int status; int status = 0;
/* help drivers fail *cleanly* when they need options /* help drivers fail *cleanly* when they need options
* that aren't supported with their current master * that aren't supported with their current master
...@@ -1171,7 +1171,8 @@ int spi_setup(struct spi_device *spi) ...@@ -1171,7 +1171,8 @@ int spi_setup(struct spi_device *spi)
if (!spi->bits_per_word) if (!spi->bits_per_word)
spi->bits_per_word = 8; spi->bits_per_word = 8;
status = spi->master->setup(spi); if (spi->master->setup)
status = spi->master->setup(spi);
dev_dbg(&spi->dev, "setup mode %d, %s%s%s%s" dev_dbg(&spi->dev, "setup mode %d, %s%s%s%s"
"%u bits/w, %u Hz max --> %d\n", "%u bits/w, %u Hz max --> %d\n",
...@@ -1190,6 +1191,7 @@ EXPORT_SYMBOL_GPL(spi_setup); ...@@ -1190,6 +1191,7 @@ EXPORT_SYMBOL_GPL(spi_setup);
static int __spi_async(struct spi_device *spi, struct spi_message *message) static int __spi_async(struct spi_device *spi, struct spi_message *message)
{ {
struct spi_master *master = spi->master; struct spi_master *master = spi->master;
struct spi_transfer *xfer;
/* Half-duplex links include original MicroWire, and ones with /* Half-duplex links include original MicroWire, and ones with
* only one data pin like SPI_3WIRE (switches direction) or where * only one data pin like SPI_3WIRE (switches direction) or where
...@@ -1198,7 +1200,6 @@ static int __spi_async(struct spi_device *spi, struct spi_message *message) ...@@ -1198,7 +1200,6 @@ static int __spi_async(struct spi_device *spi, struct spi_message *message)
*/ */
if ((master->flags & SPI_MASTER_HALF_DUPLEX) if ((master->flags & SPI_MASTER_HALF_DUPLEX)
|| (spi->mode & SPI_3WIRE)) { || (spi->mode & SPI_3WIRE)) {
struct spi_transfer *xfer;
unsigned flags = master->flags; unsigned flags = master->flags;
list_for_each_entry(xfer, &message->transfers, transfer_list) { list_for_each_entry(xfer, &message->transfers, transfer_list) {
...@@ -1211,6 +1212,15 @@ static int __spi_async(struct spi_device *spi, struct spi_message *message) ...@@ -1211,6 +1212,15 @@ static int __spi_async(struct spi_device *spi, struct spi_message *message)
} }
} }
/**
* Set transfer bits_per_word as spi device default if it is not
* set for this transfer.
*/
list_for_each_entry(xfer, &message->transfers, transfer_list) {
if (!xfer->bits_per_word)
xfer->bits_per_word = spi->bits_per_word;
}
message->spi = spi; message->spi = spi;
message->status = -EINPROGRESS; message->status = -EINPROGRESS;
return master->transfer(spi, message); return master->transfer(spi, message);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册