aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Brown <broonie@kernel.org>2016-05-23 07:16:45 -0400
committerMark Brown <broonie@kernel.org>2016-05-23 07:16:45 -0400
commit38acceff8f02caa8d6b7b4068bb849b619a438d6 (patch)
tree2918c09dffa2b6e130f9f6213a099fa3518b5a0d
parent2dcd0af568b0cf583645c8a317dd12e344b1c72a (diff)
parent8ba811a7d2f0f86a37bd8aaaff35ce1004633430 (diff)
Merge remote-tracking branch 'spi/topic/core' into spi-next
-rw-r--r--drivers/spi/spi.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c
index 0239b45eed92..77e6e45951f4 100644
--- a/drivers/spi/spi.c
+++ b/drivers/spi/spi.c
@@ -717,9 +717,11 @@ static int spi_map_buf(struct spi_master *master, struct device *dev,
717 if (vmalloced_buf) { 717 if (vmalloced_buf) {
718 desc_len = min_t(int, max_seg_size, PAGE_SIZE); 718 desc_len = min_t(int, max_seg_size, PAGE_SIZE);
719 sgs = DIV_ROUND_UP(len + offset_in_page(buf), desc_len); 719 sgs = DIV_ROUND_UP(len + offset_in_page(buf), desc_len);
720 } else { 720 } else if (virt_addr_valid(buf)) {
721 desc_len = min_t(int, max_seg_size, master->max_dma_len); 721 desc_len = min_t(int, max_seg_size, master->max_dma_len);
722 sgs = DIV_ROUND_UP(len, desc_len); 722 sgs = DIV_ROUND_UP(len, desc_len);
723 } else {
724 return -EINVAL;
723 } 725 }
724 726
725 ret = sg_alloc_table(sgt, sgs, GFP_KERNEL); 727 ret = sg_alloc_table(sgt, sgs, GFP_KERNEL);
@@ -933,7 +935,7 @@ static int spi_map_msg(struct spi_master *master, struct spi_message *msg)
933 * spi_transfer_one_message - Default implementation of transfer_one_message() 935 * spi_transfer_one_message - Default implementation of transfer_one_message()
934 * 936 *
935 * This is a standard implementation of transfer_one_message() for 937 * This is a standard implementation of transfer_one_message() for
936 * drivers which impelment a transfer_one() operation. It provides 938 * drivers which implement a transfer_one() operation. It provides
937 * standard handling of delays and chip select management. 939 * standard handling of delays and chip select management.
938 */ 940 */
939static int spi_transfer_one_message(struct spi_master *master, 941static int spi_transfer_one_message(struct spi_master *master,
@@ -1764,6 +1766,7 @@ struct spi_master *spi_alloc_master(struct device *dev, unsigned size)
1764 master->num_chipselect = 1; 1766 master->num_chipselect = 1;
1765 master->dev.class = &spi_master_class; 1767 master->dev.class = &spi_master_class;
1766 master->dev.parent = dev; 1768 master->dev.parent = dev;
1769 pm_suspend_ignore_children(&master->dev, true);
1767 spi_master_set_devdata(master, &master[1]); 1770 spi_master_set_devdata(master, &master[1]);
1768 1771
1769 return master; 1772 return master;