aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorSebastian Andrzej Siewior <bigeasy@linutronix.de>2009-05-22 15:19:40 -0400
committerJohn W. Linville <linville@tuxdriver.com>2009-06-03 14:05:08 -0400
commitf488b72de5bb2f380c157135922bac3ca1648564 (patch)
tree768c233de807f1f0026cf17368e3feb11671d066 /drivers
parent55aa4e0f16aa55e4b8cbe40b11e09cf029848f02 (diff)
net/libertas: make SPI interface big endian aware
The comment (which I remove) says that the translation is done SPI routines. IMHO this can't work because the SPI driver does not know whether the incomming bytes are part of the registers/bytes which need to be flipped or part of packet data which has to remain untouched. While adding le helpers I also removed spu_write_u32() which has no users. Tested-by: Andrey Yurovsky <andrey@cozybit.com> Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Acked-by: Dan Williams <dcbw@redhat.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/wireless/libertas/if_spi.c34
1 files changed, 16 insertions, 18 deletions
diff --git a/drivers/net/wireless/libertas/if_spi.c b/drivers/net/wireless/libertas/if_spi.c
index 5fa55fe1f860..ea23c5de1420 100644
--- a/drivers/net/wireless/libertas/if_spi.c
+++ b/drivers/net/wireless/libertas/if_spi.c
@@ -119,9 +119,6 @@ static struct chip_ident chip_id_to_device_name[] = {
119 * First we have to put a SPU register name on the bus. Then we can 119 * First we have to put a SPU register name on the bus. Then we can
120 * either read from or write to that register. 120 * either read from or write to that register.
121 * 121 *
122 * For 16-bit transactions, byte order on the bus is big-endian.
123 * We don't have to worry about that here, though.
124 * The translation takes place in the SPI routines.
125 */ 122 */
126 123
127static void spu_transaction_init(struct if_spi_card *card) 124static void spu_transaction_init(struct if_spi_card *card)
@@ -147,7 +144,7 @@ static void spu_transaction_finish(struct if_spi_card *card)
147static int spu_write(struct if_spi_card *card, u16 reg, const u8 *buf, int len) 144static int spu_write(struct if_spi_card *card, u16 reg, const u8 *buf, int len)
148{ 145{
149 int err = 0; 146 int err = 0;
150 u16 reg_out = reg | IF_SPI_WRITE_OPERATION_MASK; 147 u16 reg_out = cpu_to_le16(reg | IF_SPI_WRITE_OPERATION_MASK);
151 148
152 /* You must give an even number of bytes to the SPU, even if it 149 /* You must give an even number of bytes to the SPU, even if it
153 * doesn't care about the last one. */ 150 * doesn't care about the last one. */
@@ -169,16 +166,10 @@ out:
169 166
170static inline int spu_write_u16(struct if_spi_card *card, u16 reg, u16 val) 167static inline int spu_write_u16(struct if_spi_card *card, u16 reg, u16 val)
171{ 168{
172 return spu_write(card, reg, (u8 *)&val, sizeof(u16)); 169 u16 buff;
173}
174 170
175static inline int spu_write_u32(struct if_spi_card *card, u16 reg, u32 val) 171 buff = cpu_to_le16(val);
176{ 172 return spu_write(card, reg, (u8 *)&buff, sizeof(u16));
177 /* The lower 16 bits are written first. */
178 u16 out[2];
179 out[0] = val & 0xffff;
180 out[1] = (val & 0xffff0000) >> 16;
181 return spu_write(card, reg, (u8 *)&out, sizeof(u32));
182} 173}
183 174
184static inline int spu_reg_is_port_reg(u16 reg) 175static inline int spu_reg_is_port_reg(u16 reg)
@@ -198,7 +189,7 @@ static int spu_read(struct if_spi_card *card, u16 reg, u8 *buf, int len)
198 unsigned int i, delay; 189 unsigned int i, delay;
199 int err = 0; 190 int err = 0;
200 u16 zero = 0; 191 u16 zero = 0;
201 u16 reg_out = reg | IF_SPI_READ_OPERATION_MASK; 192 u16 reg_out = cpu_to_le16(reg | IF_SPI_READ_OPERATION_MASK);
202 193
203 /* You must take an even number of bytes from the SPU, even if you 194 /* You must take an even number of bytes from the SPU, even if you
204 * don't care about the last one. */ 195 * don't care about the last one. */
@@ -236,18 +227,25 @@ out:
236/* Read 16 bits from an SPI register */ 227/* Read 16 bits from an SPI register */
237static inline int spu_read_u16(struct if_spi_card *card, u16 reg, u16 *val) 228static inline int spu_read_u16(struct if_spi_card *card, u16 reg, u16 *val)
238{ 229{
239 return spu_read(card, reg, (u8 *)val, sizeof(u16)); 230 u16 buf;
231 int ret;
232
233 ret = spu_read(card, reg, (u8 *)&buf, sizeof(buf));
234 if (ret == 0)
235 *val = le16_to_cpup(&buf);
236 return ret;
240} 237}
241 238
242/* Read 32 bits from an SPI register. 239/* Read 32 bits from an SPI register.
243 * The low 16 bits are read first. */ 240 * The low 16 bits are read first. */
244static int spu_read_u32(struct if_spi_card *card, u16 reg, u32 *val) 241static int spu_read_u32(struct if_spi_card *card, u16 reg, u32 *val)
245{ 242{
246 u16 buf[2]; 243 u32 buf;
247 int err; 244 int err;
248 err = spu_read(card, reg, (u8 *)buf, sizeof(u32)); 245
246 err = spu_read(card, reg, (u8 *)&buf, sizeof(buf));
249 if (!err) 247 if (!err)
250 *val = buf[0] | (buf[1] << 16); 248 *val = le32_to_cpup(&buf);
251 return err; 249 return err;
252} 250}
253 251