diff options
Diffstat (limited to 'drivers/spi')
-rw-r--r-- | drivers/spi/mpc512x_psc_spi.c | 16 | ||||
-rw-r--r-- | drivers/spi/omap_spi_100k.c | 23 | ||||
-rw-r--r-- | drivers/spi/spi.c | 225 | ||||
-rw-r--r-- | drivers/spi/spi_bitbang.c | 9 | ||||
-rw-r--r-- | drivers/spi/spi_bitbang_txrx.h | 16 | ||||
-rw-r--r-- | drivers/spi/spi_butterfly.c | 2 | ||||
-rw-r--r-- | drivers/spi/spi_gpio.c | 109 | ||||
-rw-r--r-- | drivers/spi/spi_lm70llp.c | 2 | ||||
-rw-r--r-- | drivers/spi/spi_s3c24xx_gpio.c | 8 | ||||
-rw-r--r-- | drivers/spi/spi_sh_sci.c | 8 |
10 files changed, 322 insertions, 96 deletions
diff --git a/drivers/spi/mpc512x_psc_spi.c b/drivers/spi/mpc512x_psc_spi.c index 2534b1ec3edd..c8d69fc393ab 100644 --- a/drivers/spi/mpc512x_psc_spi.c +++ b/drivers/spi/mpc512x_psc_spi.c | |||
@@ -405,9 +405,9 @@ static irqreturn_t mpc512x_psc_spi_isr(int irq, void *dev_id) | |||
405 | } | 405 | } |
406 | 406 | ||
407 | /* bus_num is used only for the case dev->platform_data == NULL */ | 407 | /* bus_num is used only for the case dev->platform_data == NULL */ |
408 | static int __init mpc512x_psc_spi_do_probe(struct device *dev, u32 regaddr, | 408 | static int __devinit mpc512x_psc_spi_do_probe(struct device *dev, u32 regaddr, |
409 | u32 size, unsigned int irq, | 409 | u32 size, unsigned int irq, |
410 | s16 bus_num) | 410 | s16 bus_num) |
411 | { | 411 | { |
412 | struct fsl_spi_platform_data *pdata = dev->platform_data; | 412 | struct fsl_spi_platform_data *pdata = dev->platform_data; |
413 | struct mpc512x_psc_spi *mps; | 413 | struct mpc512x_psc_spi *mps; |
@@ -490,7 +490,7 @@ free_master: | |||
490 | return ret; | 490 | return ret; |
491 | } | 491 | } |
492 | 492 | ||
493 | static int __exit mpc512x_psc_spi_do_remove(struct device *dev) | 493 | static int __devexit mpc512x_psc_spi_do_remove(struct device *dev) |
494 | { | 494 | { |
495 | struct spi_master *master = dev_get_drvdata(dev); | 495 | struct spi_master *master = dev_get_drvdata(dev); |
496 | struct mpc512x_psc_spi *mps = spi_master_get_devdata(master); | 496 | struct mpc512x_psc_spi *mps = spi_master_get_devdata(master); |
@@ -505,8 +505,8 @@ static int __exit mpc512x_psc_spi_do_remove(struct device *dev) | |||
505 | return 0; | 505 | return 0; |
506 | } | 506 | } |
507 | 507 | ||
508 | static int __init mpc512x_psc_spi_of_probe(struct of_device *op, | 508 | static int __devinit mpc512x_psc_spi_of_probe(struct of_device *op, |
509 | const struct of_device_id *match) | 509 | const struct of_device_id *match) |
510 | { | 510 | { |
511 | const u32 *regaddr_p; | 511 | const u32 *regaddr_p; |
512 | u64 regaddr64, size64; | 512 | u64 regaddr64, size64; |
@@ -537,7 +537,7 @@ static int __init mpc512x_psc_spi_of_probe(struct of_device *op, | |||
537 | irq_of_parse_and_map(op->dev.of_node, 0), id); | 537 | irq_of_parse_and_map(op->dev.of_node, 0), id); |
538 | } | 538 | } |
539 | 539 | ||
540 | static int __exit mpc512x_psc_spi_of_remove(struct of_device *op) | 540 | static int __devexit mpc512x_psc_spi_of_remove(struct of_device *op) |
541 | { | 541 | { |
542 | return mpc512x_psc_spi_do_remove(&op->dev); | 542 | return mpc512x_psc_spi_do_remove(&op->dev); |
543 | } | 543 | } |
@@ -551,7 +551,7 @@ MODULE_DEVICE_TABLE(of, mpc512x_psc_spi_of_match); | |||
551 | 551 | ||
552 | static struct of_platform_driver mpc512x_psc_spi_of_driver = { | 552 | static struct of_platform_driver mpc512x_psc_spi_of_driver = { |
553 | .probe = mpc512x_psc_spi_of_probe, | 553 | .probe = mpc512x_psc_spi_of_probe, |
554 | .remove = __exit_p(mpc512x_psc_spi_of_remove), | 554 | .remove = __devexit_p(mpc512x_psc_spi_of_remove), |
555 | .driver = { | 555 | .driver = { |
556 | .name = "mpc512x-psc-spi", | 556 | .name = "mpc512x-psc-spi", |
557 | .owner = THIS_MODULE, | 557 | .owner = THIS_MODULE, |
diff --git a/drivers/spi/omap_spi_100k.c b/drivers/spi/omap_spi_100k.c index 24668b30a52d..9bd1c92ad96e 100644 --- a/drivers/spi/omap_spi_100k.c +++ b/drivers/spi/omap_spi_100k.c | |||
@@ -141,7 +141,12 @@ static void spi100k_write_data(struct spi_master *master, int len, int data) | |||
141 | { | 141 | { |
142 | struct omap1_spi100k *spi100k = spi_master_get_devdata(master); | 142 | struct omap1_spi100k *spi100k = spi_master_get_devdata(master); |
143 | 143 | ||
144 | /* write 16-bit word */ | 144 | /* write 16-bit word, shifting 8-bit data if necessary */ |
145 | if (len <= 8) { | ||
146 | data <<= 8; | ||
147 | len = 16; | ||
148 | } | ||
149 | |||
145 | spi100k_enable_clock(master); | 150 | spi100k_enable_clock(master); |
146 | writew( data , spi100k->base + SPI_TX_MSB); | 151 | writew( data , spi100k->base + SPI_TX_MSB); |
147 | 152 | ||
@@ -162,6 +167,10 @@ static int spi100k_read_data(struct spi_master *master, int len) | |||
162 | int dataH,dataL; | 167 | int dataH,dataL; |
163 | struct omap1_spi100k *spi100k = spi_master_get_devdata(master); | 168 | struct omap1_spi100k *spi100k = spi_master_get_devdata(master); |
164 | 169 | ||
170 | /* Always do at least 16 bits */ | ||
171 | if (len <= 8) | ||
172 | len = 16; | ||
173 | |||
165 | spi100k_enable_clock(master); | 174 | spi100k_enable_clock(master); |
166 | writew(SPI_CTRL_SEN(0) | | 175 | writew(SPI_CTRL_SEN(0) | |
167 | SPI_CTRL_WORD_SIZE(len) | | 176 | SPI_CTRL_WORD_SIZE(len) | |
@@ -214,10 +223,6 @@ omap1_spi100k_txrx_pio(struct spi_device *spi, struct spi_transfer *xfer) | |||
214 | c = count; | 223 | c = count; |
215 | word_len = cs->word_len; | 224 | word_len = cs->word_len; |
216 | 225 | ||
217 | /* RX_ONLY mode needs dummy data in TX reg */ | ||
218 | if (xfer->tx_buf == NULL) | ||
219 | spi100k_write_data(spi->master,word_len, 0); | ||
220 | |||
221 | if (word_len <= 8) { | 226 | if (word_len <= 8) { |
222 | u8 *rx; | 227 | u8 *rx; |
223 | const u8 *tx; | 228 | const u8 *tx; |
@@ -227,9 +232,9 @@ omap1_spi100k_txrx_pio(struct spi_device *spi, struct spi_transfer *xfer) | |||
227 | do { | 232 | do { |
228 | c-=1; | 233 | c-=1; |
229 | if (xfer->tx_buf != NULL) | 234 | if (xfer->tx_buf != NULL) |
230 | spi100k_write_data(spi->master,word_len, *tx); | 235 | spi100k_write_data(spi->master, word_len, *tx++); |
231 | if (xfer->rx_buf != NULL) | 236 | if (xfer->rx_buf != NULL) |
232 | *rx = spi100k_read_data(spi->master,word_len); | 237 | *rx++ = spi100k_read_data(spi->master, word_len); |
233 | } while(c); | 238 | } while(c); |
234 | } else if (word_len <= 16) { | 239 | } else if (word_len <= 16) { |
235 | u16 *rx; | 240 | u16 *rx; |
@@ -380,10 +385,6 @@ static void omap1_spi100k_work(struct work_struct *work) | |||
380 | if (t->len) { | 385 | if (t->len) { |
381 | unsigned count; | 386 | unsigned count; |
382 | 387 | ||
383 | /* RX_ONLY mode needs dummy data in TX reg */ | ||
384 | if (t->tx_buf == NULL) | ||
385 | spi100k_write_data(spi->master, 8, 0); | ||
386 | |||
387 | count = omap1_spi100k_txrx_pio(spi, t); | 388 | count = omap1_spi100k_txrx_pio(spi, t); |
388 | m->actual_length += count; | 389 | m->actual_length += count; |
389 | 390 | ||
diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c index b3a1f9259b62..fdde7061ef58 100644 --- a/drivers/spi/spi.c +++ b/drivers/spi/spi.c | |||
@@ -527,6 +527,10 @@ int spi_register_master(struct spi_master *master) | |||
527 | dynamic = 1; | 527 | dynamic = 1; |
528 | } | 528 | } |
529 | 529 | ||
530 | spin_lock_init(&master->bus_lock_spinlock); | ||
531 | mutex_init(&master->bus_lock_mutex); | ||
532 | master->bus_lock_flag = 0; | ||
533 | |||
530 | /* register the device, then userspace will see it. | 534 | /* register the device, then userspace will see it. |
531 | * registration fails if the bus ID is in use. | 535 | * registration fails if the bus ID is in use. |
532 | */ | 536 | */ |
@@ -666,6 +670,35 @@ int spi_setup(struct spi_device *spi) | |||
666 | } | 670 | } |
667 | EXPORT_SYMBOL_GPL(spi_setup); | 671 | EXPORT_SYMBOL_GPL(spi_setup); |
668 | 672 | ||
673 | static int __spi_async(struct spi_device *spi, struct spi_message *message) | ||
674 | { | ||
675 | struct spi_master *master = spi->master; | ||
676 | |||
677 | /* Half-duplex links include original MicroWire, and ones with | ||
678 | * only one data pin like SPI_3WIRE (switches direction) or where | ||
679 | * either MOSI or MISO is missing. They can also be caused by | ||
680 | * software limitations. | ||
681 | */ | ||
682 | if ((master->flags & SPI_MASTER_HALF_DUPLEX) | ||
683 | || (spi->mode & SPI_3WIRE)) { | ||
684 | struct spi_transfer *xfer; | ||
685 | unsigned flags = master->flags; | ||
686 | |||
687 | list_for_each_entry(xfer, &message->transfers, transfer_list) { | ||
688 | if (xfer->rx_buf && xfer->tx_buf) | ||
689 | return -EINVAL; | ||
690 | if ((flags & SPI_MASTER_NO_TX) && xfer->tx_buf) | ||
691 | return -EINVAL; | ||
692 | if ((flags & SPI_MASTER_NO_RX) && xfer->rx_buf) | ||
693 | return -EINVAL; | ||
694 | } | ||
695 | } | ||
696 | |||
697 | message->spi = spi; | ||
698 | message->status = -EINPROGRESS; | ||
699 | return master->transfer(spi, message); | ||
700 | } | ||
701 | |||
669 | /** | 702 | /** |
670 | * spi_async - asynchronous SPI transfer | 703 | * spi_async - asynchronous SPI transfer |
671 | * @spi: device with which data will be exchanged | 704 | * @spi: device with which data will be exchanged |
@@ -698,33 +731,68 @@ EXPORT_SYMBOL_GPL(spi_setup); | |||
698 | int spi_async(struct spi_device *spi, struct spi_message *message) | 731 | int spi_async(struct spi_device *spi, struct spi_message *message) |
699 | { | 732 | { |
700 | struct spi_master *master = spi->master; | 733 | struct spi_master *master = spi->master; |
734 | int ret; | ||
735 | unsigned long flags; | ||
701 | 736 | ||
702 | /* Half-duplex links include original MicroWire, and ones with | 737 | spin_lock_irqsave(&master->bus_lock_spinlock, flags); |
703 | * only one data pin like SPI_3WIRE (switches direction) or where | ||
704 | * either MOSI or MISO is missing. They can also be caused by | ||
705 | * software limitations. | ||
706 | */ | ||
707 | if ((master->flags & SPI_MASTER_HALF_DUPLEX) | ||
708 | || (spi->mode & SPI_3WIRE)) { | ||
709 | struct spi_transfer *xfer; | ||
710 | unsigned flags = master->flags; | ||
711 | 738 | ||
712 | list_for_each_entry(xfer, &message->transfers, transfer_list) { | 739 | if (master->bus_lock_flag) |
713 | if (xfer->rx_buf && xfer->tx_buf) | 740 | ret = -EBUSY; |
714 | return -EINVAL; | 741 | else |
715 | if ((flags & SPI_MASTER_NO_TX) && xfer->tx_buf) | 742 | ret = __spi_async(spi, message); |
716 | return -EINVAL; | ||
717 | if ((flags & SPI_MASTER_NO_RX) && xfer->rx_buf) | ||
718 | return -EINVAL; | ||
719 | } | ||
720 | } | ||
721 | 743 | ||
722 | message->spi = spi; | 744 | spin_unlock_irqrestore(&master->bus_lock_spinlock, flags); |
723 | message->status = -EINPROGRESS; | 745 | |
724 | return master->transfer(spi, message); | 746 | return ret; |
725 | } | 747 | } |
726 | EXPORT_SYMBOL_GPL(spi_async); | 748 | EXPORT_SYMBOL_GPL(spi_async); |
727 | 749 | ||
750 | /** | ||
751 | * spi_async_locked - version of spi_async with exclusive bus usage | ||
752 | * @spi: device with which data will be exchanged | ||
753 | * @message: describes the data transfers, including completion callback | ||
754 | * Context: any (irqs may be blocked, etc) | ||
755 | * | ||
756 | * This call may be used in_irq and other contexts which can't sleep, | ||
757 | * as well as from task contexts which can sleep. | ||
758 | * | ||
759 | * The completion callback is invoked in a context which can't sleep. | ||
760 | * Before that invocation, the value of message->status is undefined. | ||
761 | * When the callback is issued, message->status holds either zero (to | ||
762 | * indicate complete success) or a negative error code. After that | ||
763 | * callback returns, the driver which issued the transfer request may | ||
764 | * deallocate the associated memory; it's no longer in use by any SPI | ||
765 | * core or controller driver code. | ||
766 | * | ||
767 | * Note that although all messages to a spi_device are handled in | ||
768 | * FIFO order, messages may go to different devices in other orders. | ||
769 | * Some device might be higher priority, or have various "hard" access | ||
770 | * time requirements, for example. | ||
771 | * | ||
772 | * On detection of any fault during the transfer, processing of | ||
773 | * the entire message is aborted, and the device is deselected. | ||
774 | * Until returning from the associated message completion callback, | ||
775 | * no other spi_message queued to that device will be processed. | ||
776 | * (This rule applies equally to all the synchronous transfer calls, | ||
777 | * which are wrappers around this core asynchronous primitive.) | ||
778 | */ | ||
779 | int spi_async_locked(struct spi_device *spi, struct spi_message *message) | ||
780 | { | ||
781 | struct spi_master *master = spi->master; | ||
782 | int ret; | ||
783 | unsigned long flags; | ||
784 | |||
785 | spin_lock_irqsave(&master->bus_lock_spinlock, flags); | ||
786 | |||
787 | ret = __spi_async(spi, message); | ||
788 | |||
789 | spin_unlock_irqrestore(&master->bus_lock_spinlock, flags); | ||
790 | |||
791 | return ret; | ||
792 | |||
793 | } | ||
794 | EXPORT_SYMBOL_GPL(spi_async_locked); | ||
795 | |||
728 | 796 | ||
729 | /*-------------------------------------------------------------------------*/ | 797 | /*-------------------------------------------------------------------------*/ |
730 | 798 | ||
@@ -738,6 +806,32 @@ static void spi_complete(void *arg) | |||
738 | complete(arg); | 806 | complete(arg); |
739 | } | 807 | } |
740 | 808 | ||
809 | static int __spi_sync(struct spi_device *spi, struct spi_message *message, | ||
810 | int bus_locked) | ||
811 | { | ||
812 | DECLARE_COMPLETION_ONSTACK(done); | ||
813 | int status; | ||
814 | struct spi_master *master = spi->master; | ||
815 | |||
816 | message->complete = spi_complete; | ||
817 | message->context = &done; | ||
818 | |||
819 | if (!bus_locked) | ||
820 | mutex_lock(&master->bus_lock_mutex); | ||
821 | |||
822 | status = spi_async_locked(spi, message); | ||
823 | |||
824 | if (!bus_locked) | ||
825 | mutex_unlock(&master->bus_lock_mutex); | ||
826 | |||
827 | if (status == 0) { | ||
828 | wait_for_completion(&done); | ||
829 | status = message->status; | ||
830 | } | ||
831 | message->context = NULL; | ||
832 | return status; | ||
833 | } | ||
834 | |||
741 | /** | 835 | /** |
742 | * spi_sync - blocking/synchronous SPI data transfers | 836 | * spi_sync - blocking/synchronous SPI data transfers |
743 | * @spi: device with which data will be exchanged | 837 | * @spi: device with which data will be exchanged |
@@ -761,21 +855,86 @@ static void spi_complete(void *arg) | |||
761 | */ | 855 | */ |
762 | int spi_sync(struct spi_device *spi, struct spi_message *message) | 856 | int spi_sync(struct spi_device *spi, struct spi_message *message) |
763 | { | 857 | { |
764 | DECLARE_COMPLETION_ONSTACK(done); | 858 | return __spi_sync(spi, message, 0); |
765 | int status; | ||
766 | |||
767 | message->complete = spi_complete; | ||
768 | message->context = &done; | ||
769 | status = spi_async(spi, message); | ||
770 | if (status == 0) { | ||
771 | wait_for_completion(&done); | ||
772 | status = message->status; | ||
773 | } | ||
774 | message->context = NULL; | ||
775 | return status; | ||
776 | } | 859 | } |
777 | EXPORT_SYMBOL_GPL(spi_sync); | 860 | EXPORT_SYMBOL_GPL(spi_sync); |
778 | 861 | ||
862 | /** | ||
863 | * spi_sync_locked - version of spi_sync with exclusive bus usage | ||
864 | * @spi: device with which data will be exchanged | ||
865 | * @message: describes the data transfers | ||
866 | * Context: can sleep | ||
867 | * | ||
868 | * This call may only be used from a context that may sleep. The sleep | ||
869 | * is non-interruptible, and has no timeout. Low-overhead controller | ||
870 | * drivers may DMA directly into and out of the message buffers. | ||
871 | * | ||
872 | * This call should be used by drivers that require exclusive access to the | ||
873 | * SPI bus. It has to be preceeded by a spi_bus_lock call. The SPI bus must | ||
874 | * be released by a spi_bus_unlock call when the exclusive access is over. | ||
875 | * | ||
876 | * It returns zero on success, else a negative error code. | ||
877 | */ | ||
878 | int spi_sync_locked(struct spi_device *spi, struct spi_message *message) | ||
879 | { | ||
880 | return __spi_sync(spi, message, 1); | ||
881 | } | ||
882 | EXPORT_SYMBOL_GPL(spi_sync_locked); | ||
883 | |||
884 | /** | ||
885 | * spi_bus_lock - obtain a lock for exclusive SPI bus usage | ||
886 | * @master: SPI bus master that should be locked for exclusive bus access | ||
887 | * Context: can sleep | ||
888 | * | ||
889 | * This call may only be used from a context that may sleep. The sleep | ||
890 | * is non-interruptible, and has no timeout. | ||
891 | * | ||
892 | * This call should be used by drivers that require exclusive access to the | ||
893 | * SPI bus. The SPI bus must be released by a spi_bus_unlock call when the | ||
894 | * exclusive access is over. Data transfer must be done by spi_sync_locked | ||
895 | * and spi_async_locked calls when the SPI bus lock is held. | ||
896 | * | ||
897 | * It returns zero on success, else a negative error code. | ||
898 | */ | ||
899 | int spi_bus_lock(struct spi_master *master) | ||
900 | { | ||
901 | unsigned long flags; | ||
902 | |||
903 | mutex_lock(&master->bus_lock_mutex); | ||
904 | |||
905 | spin_lock_irqsave(&master->bus_lock_spinlock, flags); | ||
906 | master->bus_lock_flag = 1; | ||
907 | spin_unlock_irqrestore(&master->bus_lock_spinlock, flags); | ||
908 | |||
909 | /* mutex remains locked until spi_bus_unlock is called */ | ||
910 | |||
911 | return 0; | ||
912 | } | ||
913 | EXPORT_SYMBOL_GPL(spi_bus_lock); | ||
914 | |||
915 | /** | ||
916 | * spi_bus_unlock - release the lock for exclusive SPI bus usage | ||
917 | * @master: SPI bus master that was locked for exclusive bus access | ||
918 | * Context: can sleep | ||
919 | * | ||
920 | * This call may only be used from a context that may sleep. The sleep | ||
921 | * is non-interruptible, and has no timeout. | ||
922 | * | ||
923 | * This call releases an SPI bus lock previously obtained by an spi_bus_lock | ||
924 | * call. | ||
925 | * | ||
926 | * It returns zero on success, else a negative error code. | ||
927 | */ | ||
928 | int spi_bus_unlock(struct spi_master *master) | ||
929 | { | ||
930 | master->bus_lock_flag = 0; | ||
931 | |||
932 | mutex_unlock(&master->bus_lock_mutex); | ||
933 | |||
934 | return 0; | ||
935 | } | ||
936 | EXPORT_SYMBOL_GPL(spi_bus_unlock); | ||
937 | |||
779 | /* portable code must never pass more than 32 bytes */ | 938 | /* portable code must never pass more than 32 bytes */ |
780 | #define SPI_BUFSIZ max(32,SMP_CACHE_BYTES) | 939 | #define SPI_BUFSIZ max(32,SMP_CACHE_BYTES) |
781 | 940 | ||
diff --git a/drivers/spi/spi_bitbang.c b/drivers/spi/spi_bitbang.c index 5265330a528f..8b55724d5f39 100644 --- a/drivers/spi/spi_bitbang.c +++ b/drivers/spi/spi_bitbang.c | |||
@@ -259,7 +259,6 @@ static void bitbang_work(struct work_struct *work) | |||
259 | struct spi_bitbang *bitbang = | 259 | struct spi_bitbang *bitbang = |
260 | container_of(work, struct spi_bitbang, work); | 260 | container_of(work, struct spi_bitbang, work); |
261 | unsigned long flags; | 261 | unsigned long flags; |
262 | int do_setup = -1; | ||
263 | int (*setup_transfer)(struct spi_device *, | 262 | int (*setup_transfer)(struct spi_device *, |
264 | struct spi_transfer *); | 263 | struct spi_transfer *); |
265 | 264 | ||
@@ -275,6 +274,7 @@ static void bitbang_work(struct work_struct *work) | |||
275 | unsigned tmp; | 274 | unsigned tmp; |
276 | unsigned cs_change; | 275 | unsigned cs_change; |
277 | int status; | 276 | int status; |
277 | int do_setup = -1; | ||
278 | 278 | ||
279 | m = container_of(bitbang->queue.next, struct spi_message, | 279 | m = container_of(bitbang->queue.next, struct spi_message, |
280 | queue); | 280 | queue); |
@@ -307,6 +307,8 @@ static void bitbang_work(struct work_struct *work) | |||
307 | status = setup_transfer(spi, t); | 307 | status = setup_transfer(spi, t); |
308 | if (status < 0) | 308 | if (status < 0) |
309 | break; | 309 | break; |
310 | if (do_setup == -1) | ||
311 | do_setup = 0; | ||
310 | } | 312 | } |
311 | 313 | ||
312 | /* set up default clock polarity, and activate chip; | 314 | /* set up default clock polarity, and activate chip; |
@@ -367,11 +369,6 @@ static void bitbang_work(struct work_struct *work) | |||
367 | m->status = status; | 369 | m->status = status; |
368 | m->complete(m->context); | 370 | m->complete(m->context); |
369 | 371 | ||
370 | /* restore speed and wordsize if it was overridden */ | ||
371 | if (do_setup == 1) | ||
372 | setup_transfer(spi, NULL); | ||
373 | do_setup = 0; | ||
374 | |||
375 | /* normally deactivate chipselect ... unless no error and | 372 | /* normally deactivate chipselect ... unless no error and |
376 | * cs_change has hinted that the next message will probably | 373 | * cs_change has hinted that the next message will probably |
377 | * be for this chip too. | 374 | * be for this chip too. |
diff --git a/drivers/spi/spi_bitbang_txrx.h b/drivers/spi/spi_bitbang_txrx.h index fc033bbf9180..c16bf853c3eb 100644 --- a/drivers/spi/spi_bitbang_txrx.h +++ b/drivers/spi/spi_bitbang_txrx.h | |||
@@ -44,7 +44,7 @@ | |||
44 | 44 | ||
45 | static inline u32 | 45 | static inline u32 |
46 | bitbang_txrx_be_cpha0(struct spi_device *spi, | 46 | bitbang_txrx_be_cpha0(struct spi_device *spi, |
47 | unsigned nsecs, unsigned cpol, | 47 | unsigned nsecs, unsigned cpol, unsigned flags, |
48 | u32 word, u8 bits) | 48 | u32 word, u8 bits) |
49 | { | 49 | { |
50 | /* if (cpol == 0) this is SPI_MODE_0; else this is SPI_MODE_2 */ | 50 | /* if (cpol == 0) this is SPI_MODE_0; else this is SPI_MODE_2 */ |
@@ -53,7 +53,8 @@ bitbang_txrx_be_cpha0(struct spi_device *spi, | |||
53 | for (word <<= (32 - bits); likely(bits); bits--) { | 53 | for (word <<= (32 - bits); likely(bits); bits--) { |
54 | 54 | ||
55 | /* setup MSB (to slave) on trailing edge */ | 55 | /* setup MSB (to slave) on trailing edge */ |
56 | setmosi(spi, word & (1 << 31)); | 56 | if ((flags & SPI_MASTER_NO_TX) == 0) |
57 | setmosi(spi, word & (1 << 31)); | ||
57 | spidelay(nsecs); /* T(setup) */ | 58 | spidelay(nsecs); /* T(setup) */ |
58 | 59 | ||
59 | setsck(spi, !cpol); | 60 | setsck(spi, !cpol); |
@@ -61,7 +62,8 @@ bitbang_txrx_be_cpha0(struct spi_device *spi, | |||
61 | 62 | ||
62 | /* sample MSB (from slave) on leading edge */ | 63 | /* sample MSB (from slave) on leading edge */ |
63 | word <<= 1; | 64 | word <<= 1; |
64 | word |= getmiso(spi); | 65 | if ((flags & SPI_MASTER_NO_RX) == 0) |
66 | word |= getmiso(spi); | ||
65 | setsck(spi, cpol); | 67 | setsck(spi, cpol); |
66 | } | 68 | } |
67 | return word; | 69 | return word; |
@@ -69,7 +71,7 @@ bitbang_txrx_be_cpha0(struct spi_device *spi, | |||
69 | 71 | ||
70 | static inline u32 | 72 | static inline u32 |
71 | bitbang_txrx_be_cpha1(struct spi_device *spi, | 73 | bitbang_txrx_be_cpha1(struct spi_device *spi, |
72 | unsigned nsecs, unsigned cpol, | 74 | unsigned nsecs, unsigned cpol, unsigned flags, |
73 | u32 word, u8 bits) | 75 | u32 word, u8 bits) |
74 | { | 76 | { |
75 | /* if (cpol == 0) this is SPI_MODE_1; else this is SPI_MODE_3 */ | 77 | /* if (cpol == 0) this is SPI_MODE_1; else this is SPI_MODE_3 */ |
@@ -79,7 +81,8 @@ bitbang_txrx_be_cpha1(struct spi_device *spi, | |||
79 | 81 | ||
80 | /* setup MSB (to slave) on leading edge */ | 82 | /* setup MSB (to slave) on leading edge */ |
81 | setsck(spi, !cpol); | 83 | setsck(spi, !cpol); |
82 | setmosi(spi, word & (1 << 31)); | 84 | if ((flags & SPI_MASTER_NO_TX) == 0) |
85 | setmosi(spi, word & (1 << 31)); | ||
83 | spidelay(nsecs); /* T(setup) */ | 86 | spidelay(nsecs); /* T(setup) */ |
84 | 87 | ||
85 | setsck(spi, cpol); | 88 | setsck(spi, cpol); |
@@ -87,7 +90,8 @@ bitbang_txrx_be_cpha1(struct spi_device *spi, | |||
87 | 90 | ||
88 | /* sample MSB (from slave) on trailing edge */ | 91 | /* sample MSB (from slave) on trailing edge */ |
89 | word <<= 1; | 92 | word <<= 1; |
90 | word |= getmiso(spi); | 93 | if ((flags & SPI_MASTER_NO_RX) == 0) |
94 | word |= getmiso(spi); | ||
91 | } | 95 | } |
92 | return word; | 96 | return word; |
93 | } | 97 | } |
diff --git a/drivers/spi/spi_butterfly.c b/drivers/spi/spi_butterfly.c index 8b5281281111..0d4ceba3b590 100644 --- a/drivers/spi/spi_butterfly.c +++ b/drivers/spi/spi_butterfly.c | |||
@@ -156,7 +156,7 @@ butterfly_txrx_word_mode0(struct spi_device *spi, | |||
156 | unsigned nsecs, | 156 | unsigned nsecs, |
157 | u32 word, u8 bits) | 157 | u32 word, u8 bits) |
158 | { | 158 | { |
159 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, word, bits); | 159 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, 0, word, bits); |
160 | } | 160 | } |
161 | 161 | ||
162 | /*----------------------------------------------------------------------*/ | 162 | /*----------------------------------------------------------------------*/ |
diff --git a/drivers/spi/spi_gpio.c b/drivers/spi/spi_gpio.c index 7edbd5807e0e..e24a63498acb 100644 --- a/drivers/spi/spi_gpio.c +++ b/drivers/spi/spi_gpio.c | |||
@@ -146,25 +146,63 @@ static inline int getmiso(const struct spi_device *spi) | |||
146 | static u32 spi_gpio_txrx_word_mode0(struct spi_device *spi, | 146 | static u32 spi_gpio_txrx_word_mode0(struct spi_device *spi, |
147 | unsigned nsecs, u32 word, u8 bits) | 147 | unsigned nsecs, u32 word, u8 bits) |
148 | { | 148 | { |
149 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, word, bits); | 149 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, 0, word, bits); |
150 | } | 150 | } |
151 | 151 | ||
152 | static u32 spi_gpio_txrx_word_mode1(struct spi_device *spi, | 152 | static u32 spi_gpio_txrx_word_mode1(struct spi_device *spi, |
153 | unsigned nsecs, u32 word, u8 bits) | 153 | unsigned nsecs, u32 word, u8 bits) |
154 | { | 154 | { |
155 | return bitbang_txrx_be_cpha1(spi, nsecs, 0, word, bits); | 155 | return bitbang_txrx_be_cpha1(spi, nsecs, 0, 0, word, bits); |
156 | } | 156 | } |
157 | 157 | ||
158 | static u32 spi_gpio_txrx_word_mode2(struct spi_device *spi, | 158 | static u32 spi_gpio_txrx_word_mode2(struct spi_device *spi, |
159 | unsigned nsecs, u32 word, u8 bits) | 159 | unsigned nsecs, u32 word, u8 bits) |
160 | { | 160 | { |
161 | return bitbang_txrx_be_cpha0(spi, nsecs, 1, word, bits); | 161 | return bitbang_txrx_be_cpha0(spi, nsecs, 1, 0, word, bits); |
162 | } | 162 | } |
163 | 163 | ||
164 | static u32 spi_gpio_txrx_word_mode3(struct spi_device *spi, | 164 | static u32 spi_gpio_txrx_word_mode3(struct spi_device *spi, |
165 | unsigned nsecs, u32 word, u8 bits) | 165 | unsigned nsecs, u32 word, u8 bits) |
166 | { | 166 | { |
167 | return bitbang_txrx_be_cpha1(spi, nsecs, 1, word, bits); | 167 | return bitbang_txrx_be_cpha1(spi, nsecs, 1, 0, word, bits); |
168 | } | ||
169 | |||
170 | /* | ||
171 | * These functions do not call setmosi or getmiso if respective flag | ||
172 | * (SPI_MASTER_NO_RX or SPI_MASTER_NO_TX) is set, so they are safe to | ||
173 | * call when such pin is not present or defined in the controller. | ||
174 | * A separate set of callbacks is defined to get highest possible | ||
175 | * speed in the generic case (when both MISO and MOSI lines are | ||
176 | * available), as optimiser will remove the checks when argument is | ||
177 | * constant. | ||
178 | */ | ||
179 | |||
180 | static u32 spi_gpio_spec_txrx_word_mode0(struct spi_device *spi, | ||
181 | unsigned nsecs, u32 word, u8 bits) | ||
182 | { | ||
183 | unsigned flags = spi->master->flags; | ||
184 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, flags, word, bits); | ||
185 | } | ||
186 | |||
187 | static u32 spi_gpio_spec_txrx_word_mode1(struct spi_device *spi, | ||
188 | unsigned nsecs, u32 word, u8 bits) | ||
189 | { | ||
190 | unsigned flags = spi->master->flags; | ||
191 | return bitbang_txrx_be_cpha1(spi, nsecs, 0, flags, word, bits); | ||
192 | } | ||
193 | |||
194 | static u32 spi_gpio_spec_txrx_word_mode2(struct spi_device *spi, | ||
195 | unsigned nsecs, u32 word, u8 bits) | ||
196 | { | ||
197 | unsigned flags = spi->master->flags; | ||
198 | return bitbang_txrx_be_cpha0(spi, nsecs, 1, flags, word, bits); | ||
199 | } | ||
200 | |||
201 | static u32 spi_gpio_spec_txrx_word_mode3(struct spi_device *spi, | ||
202 | unsigned nsecs, u32 word, u8 bits) | ||
203 | { | ||
204 | unsigned flags = spi->master->flags; | ||
205 | return bitbang_txrx_be_cpha1(spi, nsecs, 1, flags, word, bits); | ||
168 | } | 206 | } |
169 | 207 | ||
170 | /*----------------------------------------------------------------------*/ | 208 | /*----------------------------------------------------------------------*/ |
@@ -232,19 +270,30 @@ static int __init spi_gpio_alloc(unsigned pin, const char *label, bool is_in) | |||
232 | } | 270 | } |
233 | 271 | ||
234 | static int __init | 272 | static int __init |
235 | spi_gpio_request(struct spi_gpio_platform_data *pdata, const char *label) | 273 | spi_gpio_request(struct spi_gpio_platform_data *pdata, const char *label, |
274 | u16 *res_flags) | ||
236 | { | 275 | { |
237 | int value; | 276 | int value; |
238 | 277 | ||
239 | /* NOTE: SPI_*_GPIO symbols may reference "pdata" */ | 278 | /* NOTE: SPI_*_GPIO symbols may reference "pdata" */ |
240 | 279 | ||
241 | value = spi_gpio_alloc(SPI_MOSI_GPIO, label, false); | 280 | if (SPI_MOSI_GPIO != SPI_GPIO_NO_MOSI) { |
242 | if (value) | 281 | value = spi_gpio_alloc(SPI_MOSI_GPIO, label, false); |
243 | goto done; | 282 | if (value) |
283 | goto done; | ||
284 | } else { | ||
285 | /* HW configuration without MOSI pin */ | ||
286 | *res_flags |= SPI_MASTER_NO_TX; | ||
287 | } | ||
244 | 288 | ||
245 | value = spi_gpio_alloc(SPI_MISO_GPIO, label, true); | 289 | if (SPI_MISO_GPIO != SPI_GPIO_NO_MISO) { |
246 | if (value) | 290 | value = spi_gpio_alloc(SPI_MISO_GPIO, label, true); |
247 | goto free_mosi; | 291 | if (value) |
292 | goto free_mosi; | ||
293 | } else { | ||
294 | /* HW configuration without MISO pin */ | ||
295 | *res_flags |= SPI_MASTER_NO_RX; | ||
296 | } | ||
248 | 297 | ||
249 | value = spi_gpio_alloc(SPI_SCK_GPIO, label, false); | 298 | value = spi_gpio_alloc(SPI_SCK_GPIO, label, false); |
250 | if (value) | 299 | if (value) |
@@ -253,9 +302,11 @@ spi_gpio_request(struct spi_gpio_platform_data *pdata, const char *label) | |||
253 | goto done; | 302 | goto done; |
254 | 303 | ||
255 | free_miso: | 304 | free_miso: |
256 | gpio_free(SPI_MISO_GPIO); | 305 | if (SPI_MISO_GPIO != SPI_GPIO_NO_MISO) |
306 | gpio_free(SPI_MISO_GPIO); | ||
257 | free_mosi: | 307 | free_mosi: |
258 | gpio_free(SPI_MOSI_GPIO); | 308 | if (SPI_MOSI_GPIO != SPI_GPIO_NO_MOSI) |
309 | gpio_free(SPI_MOSI_GPIO); | ||
259 | done: | 310 | done: |
260 | return value; | 311 | return value; |
261 | } | 312 | } |
@@ -266,6 +317,7 @@ static int __init spi_gpio_probe(struct platform_device *pdev) | |||
266 | struct spi_master *master; | 317 | struct spi_master *master; |
267 | struct spi_gpio *spi_gpio; | 318 | struct spi_gpio *spi_gpio; |
268 | struct spi_gpio_platform_data *pdata; | 319 | struct spi_gpio_platform_data *pdata; |
320 | u16 master_flags = 0; | ||
269 | 321 | ||
270 | pdata = pdev->dev.platform_data; | 322 | pdata = pdev->dev.platform_data; |
271 | #ifdef GENERIC_BITBANG | 323 | #ifdef GENERIC_BITBANG |
@@ -273,7 +325,7 @@ static int __init spi_gpio_probe(struct platform_device *pdev) | |||
273 | return -ENODEV; | 325 | return -ENODEV; |
274 | #endif | 326 | #endif |
275 | 327 | ||
276 | status = spi_gpio_request(pdata, dev_name(&pdev->dev)); | 328 | status = spi_gpio_request(pdata, dev_name(&pdev->dev), &master_flags); |
277 | if (status < 0) | 329 | if (status < 0) |
278 | return status; | 330 | return status; |
279 | 331 | ||
@@ -289,6 +341,7 @@ static int __init spi_gpio_probe(struct platform_device *pdev) | |||
289 | if (pdata) | 341 | if (pdata) |
290 | spi_gpio->pdata = *pdata; | 342 | spi_gpio->pdata = *pdata; |
291 | 343 | ||
344 | master->flags = master_flags; | ||
292 | master->bus_num = pdev->id; | 345 | master->bus_num = pdev->id; |
293 | master->num_chipselect = SPI_N_CHIPSEL; | 346 | master->num_chipselect = SPI_N_CHIPSEL; |
294 | master->setup = spi_gpio_setup; | 347 | master->setup = spi_gpio_setup; |
@@ -296,10 +349,18 @@ static int __init spi_gpio_probe(struct platform_device *pdev) | |||
296 | 349 | ||
297 | spi_gpio->bitbang.master = spi_master_get(master); | 350 | spi_gpio->bitbang.master = spi_master_get(master); |
298 | spi_gpio->bitbang.chipselect = spi_gpio_chipselect; | 351 | spi_gpio->bitbang.chipselect = spi_gpio_chipselect; |
299 | spi_gpio->bitbang.txrx_word[SPI_MODE_0] = spi_gpio_txrx_word_mode0; | 352 | |
300 | spi_gpio->bitbang.txrx_word[SPI_MODE_1] = spi_gpio_txrx_word_mode1; | 353 | if ((master_flags & (SPI_MASTER_NO_RX | SPI_MASTER_NO_RX)) == 0) { |
301 | spi_gpio->bitbang.txrx_word[SPI_MODE_2] = spi_gpio_txrx_word_mode2; | 354 | spi_gpio->bitbang.txrx_word[SPI_MODE_0] = spi_gpio_txrx_word_mode0; |
302 | spi_gpio->bitbang.txrx_word[SPI_MODE_3] = spi_gpio_txrx_word_mode3; | 355 | spi_gpio->bitbang.txrx_word[SPI_MODE_1] = spi_gpio_txrx_word_mode1; |
356 | spi_gpio->bitbang.txrx_word[SPI_MODE_2] = spi_gpio_txrx_word_mode2; | ||
357 | spi_gpio->bitbang.txrx_word[SPI_MODE_3] = spi_gpio_txrx_word_mode3; | ||
358 | } else { | ||
359 | spi_gpio->bitbang.txrx_word[SPI_MODE_0] = spi_gpio_spec_txrx_word_mode0; | ||
360 | spi_gpio->bitbang.txrx_word[SPI_MODE_1] = spi_gpio_spec_txrx_word_mode1; | ||
361 | spi_gpio->bitbang.txrx_word[SPI_MODE_2] = spi_gpio_spec_txrx_word_mode2; | ||
362 | spi_gpio->bitbang.txrx_word[SPI_MODE_3] = spi_gpio_spec_txrx_word_mode3; | ||
363 | } | ||
303 | spi_gpio->bitbang.setup_transfer = spi_bitbang_setup_transfer; | 364 | spi_gpio->bitbang.setup_transfer = spi_bitbang_setup_transfer; |
304 | spi_gpio->bitbang.flags = SPI_CS_HIGH; | 365 | spi_gpio->bitbang.flags = SPI_CS_HIGH; |
305 | 366 | ||
@@ -307,8 +368,10 @@ static int __init spi_gpio_probe(struct platform_device *pdev) | |||
307 | if (status < 0) { | 368 | if (status < 0) { |
308 | spi_master_put(spi_gpio->bitbang.master); | 369 | spi_master_put(spi_gpio->bitbang.master); |
309 | gpio_free: | 370 | gpio_free: |
310 | gpio_free(SPI_MISO_GPIO); | 371 | if (SPI_MISO_GPIO != SPI_GPIO_NO_MISO) |
311 | gpio_free(SPI_MOSI_GPIO); | 372 | gpio_free(SPI_MISO_GPIO); |
373 | if (SPI_MOSI_GPIO != SPI_GPIO_NO_MOSI) | ||
374 | gpio_free(SPI_MOSI_GPIO); | ||
312 | gpio_free(SPI_SCK_GPIO); | 375 | gpio_free(SPI_SCK_GPIO); |
313 | spi_master_put(master); | 376 | spi_master_put(master); |
314 | } | 377 | } |
@@ -331,8 +394,10 @@ static int __exit spi_gpio_remove(struct platform_device *pdev) | |||
331 | 394 | ||
332 | platform_set_drvdata(pdev, NULL); | 395 | platform_set_drvdata(pdev, NULL); |
333 | 396 | ||
334 | gpio_free(SPI_MISO_GPIO); | 397 | if (SPI_MISO_GPIO != SPI_GPIO_NO_MISO) |
335 | gpio_free(SPI_MOSI_GPIO); | 398 | gpio_free(SPI_MISO_GPIO); |
399 | if (SPI_MOSI_GPIO != SPI_GPIO_NO_MOSI) | ||
400 | gpio_free(SPI_MOSI_GPIO); | ||
336 | gpio_free(SPI_SCK_GPIO); | 401 | gpio_free(SPI_SCK_GPIO); |
337 | 402 | ||
338 | return status; | 403 | return status; |
diff --git a/drivers/spi/spi_lm70llp.c b/drivers/spi/spi_lm70llp.c index 86fb7b5993db..7746a41ab6d6 100644 --- a/drivers/spi/spi_lm70llp.c +++ b/drivers/spi/spi_lm70llp.c | |||
@@ -191,7 +191,7 @@ static void lm70_chipselect(struct spi_device *spi, int value) | |||
191 | */ | 191 | */ |
192 | static u32 lm70_txrx(struct spi_device *spi, unsigned nsecs, u32 word, u8 bits) | 192 | static u32 lm70_txrx(struct spi_device *spi, unsigned nsecs, u32 word, u8 bits) |
193 | { | 193 | { |
194 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, word, bits); | 194 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, 0, word, bits); |
195 | } | 195 | } |
196 | 196 | ||
197 | static void spi_lm70llp_attach(struct parport *p) | 197 | static void spi_lm70llp_attach(struct parport *p) |
diff --git a/drivers/spi/spi_s3c24xx_gpio.c b/drivers/spi/spi_s3c24xx_gpio.c index 8979a75dbd7b..be991359bf92 100644 --- a/drivers/spi/spi_s3c24xx_gpio.c +++ b/drivers/spi/spi_s3c24xx_gpio.c | |||
@@ -64,25 +64,25 @@ static inline u32 getmiso(struct spi_device *dev) | |||
64 | static u32 s3c2410_spigpio_txrx_mode0(struct spi_device *spi, | 64 | static u32 s3c2410_spigpio_txrx_mode0(struct spi_device *spi, |
65 | unsigned nsecs, u32 word, u8 bits) | 65 | unsigned nsecs, u32 word, u8 bits) |
66 | { | 66 | { |
67 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, word, bits); | 67 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, 0, word, bits); |
68 | } | 68 | } |
69 | 69 | ||
70 | static u32 s3c2410_spigpio_txrx_mode1(struct spi_device *spi, | 70 | static u32 s3c2410_spigpio_txrx_mode1(struct spi_device *spi, |
71 | unsigned nsecs, u32 word, u8 bits) | 71 | unsigned nsecs, u32 word, u8 bits) |
72 | { | 72 | { |
73 | return bitbang_txrx_be_cpha1(spi, nsecs, 0, word, bits); | 73 | return bitbang_txrx_be_cpha1(spi, nsecs, 0, 0, word, bits); |
74 | } | 74 | } |
75 | 75 | ||
76 | static u32 s3c2410_spigpio_txrx_mode2(struct spi_device *spi, | 76 | static u32 s3c2410_spigpio_txrx_mode2(struct spi_device *spi, |
77 | unsigned nsecs, u32 word, u8 bits) | 77 | unsigned nsecs, u32 word, u8 bits) |
78 | { | 78 | { |
79 | return bitbang_txrx_be_cpha0(spi, nsecs, 1, word, bits); | 79 | return bitbang_txrx_be_cpha0(spi, nsecs, 1, 0, word, bits); |
80 | } | 80 | } |
81 | 81 | ||
82 | static u32 s3c2410_spigpio_txrx_mode3(struct spi_device *spi, | 82 | static u32 s3c2410_spigpio_txrx_mode3(struct spi_device *spi, |
83 | unsigned nsecs, u32 word, u8 bits) | 83 | unsigned nsecs, u32 word, u8 bits) |
84 | { | 84 | { |
85 | return bitbang_txrx_be_cpha1(spi, nsecs, 1, word, bits); | 85 | return bitbang_txrx_be_cpha1(spi, nsecs, 1, 0, word, bits); |
86 | } | 86 | } |
87 | 87 | ||
88 | 88 | ||
diff --git a/drivers/spi/spi_sh_sci.c b/drivers/spi/spi_sh_sci.c index a511be7961a0..5c6439161199 100644 --- a/drivers/spi/spi_sh_sci.c +++ b/drivers/spi/spi_sh_sci.c | |||
@@ -83,25 +83,25 @@ static inline u32 getmiso(struct spi_device *dev) | |||
83 | static u32 sh_sci_spi_txrx_mode0(struct spi_device *spi, | 83 | static u32 sh_sci_spi_txrx_mode0(struct spi_device *spi, |
84 | unsigned nsecs, u32 word, u8 bits) | 84 | unsigned nsecs, u32 word, u8 bits) |
85 | { | 85 | { |
86 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, word, bits); | 86 | return bitbang_txrx_be_cpha0(spi, nsecs, 0, 0, word, bits); |
87 | } | 87 | } |
88 | 88 | ||
89 | static u32 sh_sci_spi_txrx_mode1(struct spi_device *spi, | 89 | static u32 sh_sci_spi_txrx_mode1(struct spi_device *spi, |
90 | unsigned nsecs, u32 word, u8 bits) | 90 | unsigned nsecs, u32 word, u8 bits) |
91 | { | 91 | { |
92 | return bitbang_txrx_be_cpha1(spi, nsecs, 0, word, bits); | 92 | return bitbang_txrx_be_cpha1(spi, nsecs, 0, 0, word, bits); |
93 | } | 93 | } |
94 | 94 | ||
95 | static u32 sh_sci_spi_txrx_mode2(struct spi_device *spi, | 95 | static u32 sh_sci_spi_txrx_mode2(struct spi_device *spi, |
96 | unsigned nsecs, u32 word, u8 bits) | 96 | unsigned nsecs, u32 word, u8 bits) |
97 | { | 97 | { |
98 | return bitbang_txrx_be_cpha0(spi, nsecs, 1, word, bits); | 98 | return bitbang_txrx_be_cpha0(spi, nsecs, 1, 0, word, bits); |
99 | } | 99 | } |
100 | 100 | ||
101 | static u32 sh_sci_spi_txrx_mode3(struct spi_device *spi, | 101 | static u32 sh_sci_spi_txrx_mode3(struct spi_device *spi, |
102 | unsigned nsecs, u32 word, u8 bits) | 102 | unsigned nsecs, u32 word, u8 bits) |
103 | { | 103 | { |
104 | return bitbang_txrx_be_cpha1(spi, nsecs, 1, word, bits); | 104 | return bitbang_txrx_be_cpha1(spi, nsecs, 1, 0, word, bits); |
105 | } | 105 | } |
106 | 106 | ||
107 | static void sh_sci_spi_chipselect(struct spi_device *dev, int value) | 107 | static void sh_sci_spi_chipselect(struct spi_device *dev, int value) |