xref: /openbmc/linux/drivers/rapidio/devices/tsi721.c (revision 4da722ca)
1 /*
2  * RapidIO mport driver for Tsi721 PCIExpress-to-SRIO bridge
3  *
4  * Copyright 2011 Integrated Device Technology, Inc.
5  * Alexandre Bounine <alexandre.bounine@idt.com>
6  * Chul Kim <chul.kim@idt.com>
7  *
8  * This program is free software; you can redistribute it and/or modify it
9  * under the terms of the GNU General Public License as published by the Free
10  * Software Foundation; either version 2 of the License, or (at your option)
11  * any later version.
12  *
13  * This program is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
16  * more details.
17  *
18  * You should have received a copy of the GNU General Public License along with
19  * this program; if not, write to the Free Software Foundation, Inc., 59
20  * Temple Place - Suite 330, Boston, MA  02111-1307, USA.
21  */
22 
23 #include <linux/io.h>
24 #include <linux/errno.h>
25 #include <linux/init.h>
26 #include <linux/ioport.h>
27 #include <linux/kernel.h>
28 #include <linux/module.h>
29 #include <linux/pci.h>
30 #include <linux/rio.h>
31 #include <linux/rio_drv.h>
32 #include <linux/dma-mapping.h>
33 #include <linux/interrupt.h>
34 #include <linux/kfifo.h>
35 #include <linux/delay.h>
36 
37 #include "tsi721.h"
38 
39 #ifdef DEBUG
40 u32 tsi_dbg_level;
41 module_param_named(dbg_level, tsi_dbg_level, uint, S_IWUSR | S_IRUGO);
42 MODULE_PARM_DESC(dbg_level, "Debugging output level (default 0 = none)");
43 #endif
44 
45 static int pcie_mrrs = -1;
46 module_param(pcie_mrrs, int, S_IRUGO);
47 MODULE_PARM_DESC(pcie_mrrs, "PCIe MRRS override value (0...5)");
48 
49 static u8 mbox_sel = 0x0f;
50 module_param(mbox_sel, byte, S_IRUGO);
51 MODULE_PARM_DESC(mbox_sel,
52 		 "RIO Messaging MBOX Selection Mask (default: 0x0f = all)");
53 
54 static void tsi721_omsg_handler(struct tsi721_device *priv, int ch);
55 static void tsi721_imsg_handler(struct tsi721_device *priv, int ch);
56 
57 /**
58  * tsi721_lcread - read from local SREP config space
59  * @mport: RapidIO master port info
60  * @index: ID of RapdiIO interface
61  * @offset: Offset into configuration space
62  * @len: Length (in bytes) of the maintenance transaction
63  * @data: Value to be read into
64  *
65  * Generates a local SREP space read. Returns %0 on
66  * success or %-EINVAL on failure.
67  */
68 static int tsi721_lcread(struct rio_mport *mport, int index, u32 offset,
69 			 int len, u32 *data)
70 {
71 	struct tsi721_device *priv = mport->priv;
72 
73 	if (len != sizeof(u32))
74 		return -EINVAL; /* only 32-bit access is supported */
75 
76 	*data = ioread32(priv->regs + offset);
77 
78 	return 0;
79 }
80 
81 /**
82  * tsi721_lcwrite - write into local SREP config space
83  * @mport: RapidIO master port info
84  * @index: ID of RapdiIO interface
85  * @offset: Offset into configuration space
86  * @len: Length (in bytes) of the maintenance transaction
87  * @data: Value to be written
88  *
89  * Generates a local write into SREP configuration space. Returns %0 on
90  * success or %-EINVAL on failure.
91  */
92 static int tsi721_lcwrite(struct rio_mport *mport, int index, u32 offset,
93 			  int len, u32 data)
94 {
95 	struct tsi721_device *priv = mport->priv;
96 
97 	if (len != sizeof(u32))
98 		return -EINVAL; /* only 32-bit access is supported */
99 
100 	iowrite32(data, priv->regs + offset);
101 
102 	return 0;
103 }
104 
105 /**
106  * tsi721_maint_dma - Helper function to generate RapidIO maintenance
107  *                    transactions using designated Tsi721 DMA channel.
108  * @priv: pointer to tsi721 private data
109  * @sys_size: RapdiIO transport system size
110  * @destid: Destination ID of transaction
111  * @hopcount: Number of hops to target device
112  * @offset: Offset into configuration space
113  * @len: Length (in bytes) of the maintenance transaction
114  * @data: Location to be read from or write into
115  * @do_wr: Operation flag (1 == MAINT_WR)
116  *
117  * Generates a RapidIO maintenance transaction (Read or Write).
118  * Returns %0 on success and %-EINVAL or %-EFAULT on failure.
119  */
120 static int tsi721_maint_dma(struct tsi721_device *priv, u32 sys_size,
121 			u16 destid, u8 hopcount, u32 offset, int len,
122 			u32 *data, int do_wr)
123 {
124 	void __iomem *regs = priv->regs + TSI721_DMAC_BASE(priv->mdma.ch_id);
125 	struct tsi721_dma_desc *bd_ptr;
126 	u32 rd_count, swr_ptr, ch_stat;
127 	int i, err = 0;
128 	u32 op = do_wr ? MAINT_WR : MAINT_RD;
129 
130 	if (offset > (RIO_MAINT_SPACE_SZ - len) || (len != sizeof(u32)))
131 		return -EINVAL;
132 
133 	bd_ptr = priv->mdma.bd_base;
134 
135 	rd_count = ioread32(regs + TSI721_DMAC_DRDCNT);
136 
137 	/* Initialize DMA descriptor */
138 	bd_ptr[0].type_id = cpu_to_le32((DTYPE2 << 29) | (op << 19) | destid);
139 	bd_ptr[0].bcount = cpu_to_le32((sys_size << 26) | 0x04);
140 	bd_ptr[0].raddr_lo = cpu_to_le32((hopcount << 24) | offset);
141 	bd_ptr[0].raddr_hi = 0;
142 	if (do_wr)
143 		bd_ptr[0].data[0] = cpu_to_be32p(data);
144 	else
145 		bd_ptr[0].data[0] = 0xffffffff;
146 
147 	mb();
148 
149 	/* Start DMA operation */
150 	iowrite32(rd_count + 2,	regs + TSI721_DMAC_DWRCNT);
151 	ioread32(regs + TSI721_DMAC_DWRCNT);
152 	i = 0;
153 
154 	/* Wait until DMA transfer is finished */
155 	while ((ch_stat = ioread32(regs + TSI721_DMAC_STS))
156 							& TSI721_DMAC_STS_RUN) {
157 		udelay(1);
158 		if (++i >= 5000000) {
159 			tsi_debug(MAINT, &priv->pdev->dev,
160 				"DMA[%d] read timeout ch_status=%x",
161 				priv->mdma.ch_id, ch_stat);
162 			if (!do_wr)
163 				*data = 0xffffffff;
164 			err = -EIO;
165 			goto err_out;
166 		}
167 	}
168 
169 	if (ch_stat & TSI721_DMAC_STS_ABORT) {
170 		/* If DMA operation aborted due to error,
171 		 * reinitialize DMA channel
172 		 */
173 		tsi_debug(MAINT, &priv->pdev->dev, "DMA ABORT ch_stat=%x",
174 			  ch_stat);
175 		tsi_debug(MAINT, &priv->pdev->dev,
176 			  "OP=%d : destid=%x hc=%x off=%x",
177 			  do_wr ? MAINT_WR : MAINT_RD,
178 			  destid, hopcount, offset);
179 		iowrite32(TSI721_DMAC_INT_ALL, regs + TSI721_DMAC_INT);
180 		iowrite32(TSI721_DMAC_CTL_INIT, regs + TSI721_DMAC_CTL);
181 		udelay(10);
182 		iowrite32(0, regs + TSI721_DMAC_DWRCNT);
183 		udelay(1);
184 		if (!do_wr)
185 			*data = 0xffffffff;
186 		err = -EIO;
187 		goto err_out;
188 	}
189 
190 	if (!do_wr)
191 		*data = be32_to_cpu(bd_ptr[0].data[0]);
192 
193 	/*
194 	 * Update descriptor status FIFO RD pointer.
195 	 * NOTE: Skipping check and clear FIFO entries because we are waiting
196 	 * for transfer to be completed.
197 	 */
198 	swr_ptr = ioread32(regs + TSI721_DMAC_DSWP);
199 	iowrite32(swr_ptr, regs + TSI721_DMAC_DSRP);
200 err_out:
201 
202 	return err;
203 }
204 
205 /**
206  * tsi721_cread_dma - Generate a RapidIO maintenance read transaction
207  *                    using Tsi721 BDMA engine.
208  * @mport: RapidIO master port control structure
209  * @index: ID of RapdiIO interface
210  * @destid: Destination ID of transaction
211  * @hopcount: Number of hops to target device
212  * @offset: Offset into configuration space
213  * @len: Length (in bytes) of the maintenance transaction
214  * @val: Location to be read into
215  *
216  * Generates a RapidIO maintenance read transaction.
217  * Returns %0 on success and %-EINVAL or %-EFAULT on failure.
218  */
219 static int tsi721_cread_dma(struct rio_mport *mport, int index, u16 destid,
220 			u8 hopcount, u32 offset, int len, u32 *data)
221 {
222 	struct tsi721_device *priv = mport->priv;
223 
224 	return tsi721_maint_dma(priv, mport->sys_size, destid, hopcount,
225 				offset, len, data, 0);
226 }
227 
228 /**
229  * tsi721_cwrite_dma - Generate a RapidIO maintenance write transaction
230  *                     using Tsi721 BDMA engine
231  * @mport: RapidIO master port control structure
232  * @index: ID of RapdiIO interface
233  * @destid: Destination ID of transaction
234  * @hopcount: Number of hops to target device
235  * @offset: Offset into configuration space
236  * @len: Length (in bytes) of the maintenance transaction
237  * @val: Value to be written
238  *
239  * Generates a RapidIO maintenance write transaction.
240  * Returns %0 on success and %-EINVAL or %-EFAULT on failure.
241  */
242 static int tsi721_cwrite_dma(struct rio_mport *mport, int index, u16 destid,
243 			 u8 hopcount, u32 offset, int len, u32 data)
244 {
245 	struct tsi721_device *priv = mport->priv;
246 	u32 temp = data;
247 
248 	return tsi721_maint_dma(priv, mport->sys_size, destid, hopcount,
249 				offset, len, &temp, 1);
250 }
251 
252 /**
253  * tsi721_pw_handler - Tsi721 inbound port-write interrupt handler
254  * @priv:  tsi721 device private structure
255  *
256  * Handles inbound port-write interrupts. Copies PW message from an internal
257  * buffer into PW message FIFO and schedules deferred routine to process
258  * queued messages.
259  */
260 static int
261 tsi721_pw_handler(struct tsi721_device *priv)
262 {
263 	u32 pw_stat;
264 	u32 pw_buf[TSI721_RIO_PW_MSG_SIZE/sizeof(u32)];
265 
266 
267 	pw_stat = ioread32(priv->regs + TSI721_RIO_PW_RX_STAT);
268 
269 	if (pw_stat & TSI721_RIO_PW_RX_STAT_PW_VAL) {
270 		pw_buf[0] = ioread32(priv->regs + TSI721_RIO_PW_RX_CAPT(0));
271 		pw_buf[1] = ioread32(priv->regs + TSI721_RIO_PW_RX_CAPT(1));
272 		pw_buf[2] = ioread32(priv->regs + TSI721_RIO_PW_RX_CAPT(2));
273 		pw_buf[3] = ioread32(priv->regs + TSI721_RIO_PW_RX_CAPT(3));
274 
275 		/* Queue PW message (if there is room in FIFO),
276 		 * otherwise discard it.
277 		 */
278 		spin_lock(&priv->pw_fifo_lock);
279 		if (kfifo_avail(&priv->pw_fifo) >= TSI721_RIO_PW_MSG_SIZE)
280 			kfifo_in(&priv->pw_fifo, pw_buf,
281 						TSI721_RIO_PW_MSG_SIZE);
282 		else
283 			priv->pw_discard_count++;
284 		spin_unlock(&priv->pw_fifo_lock);
285 	}
286 
287 	/* Clear pending PW interrupts */
288 	iowrite32(TSI721_RIO_PW_RX_STAT_PW_DISC | TSI721_RIO_PW_RX_STAT_PW_VAL,
289 		  priv->regs + TSI721_RIO_PW_RX_STAT);
290 
291 	schedule_work(&priv->pw_work);
292 
293 	return 0;
294 }
295 
296 static void tsi721_pw_dpc(struct work_struct *work)
297 {
298 	struct tsi721_device *priv = container_of(work, struct tsi721_device,
299 						    pw_work);
300 	union rio_pw_msg pwmsg;
301 
302 	/*
303 	 * Process port-write messages
304 	 */
305 	while (kfifo_out_spinlocked(&priv->pw_fifo, (unsigned char *)&pwmsg,
306 			 TSI721_RIO_PW_MSG_SIZE, &priv->pw_fifo_lock)) {
307 		/* Pass the port-write message to RIO core for processing */
308 		rio_inb_pwrite_handler(&priv->mport, &pwmsg);
309 	}
310 }
311 
312 /**
313  * tsi721_pw_enable - enable/disable port-write interface init
314  * @mport: Master port implementing the port write unit
315  * @enable:    1=enable; 0=disable port-write message handling
316  */
317 static int tsi721_pw_enable(struct rio_mport *mport, int enable)
318 {
319 	struct tsi721_device *priv = mport->priv;
320 	u32 rval;
321 
322 	rval = ioread32(priv->regs + TSI721_RIO_EM_INT_ENABLE);
323 
324 	if (enable)
325 		rval |= TSI721_RIO_EM_INT_ENABLE_PW_RX;
326 	else
327 		rval &= ~TSI721_RIO_EM_INT_ENABLE_PW_RX;
328 
329 	/* Clear pending PW interrupts */
330 	iowrite32(TSI721_RIO_PW_RX_STAT_PW_DISC | TSI721_RIO_PW_RX_STAT_PW_VAL,
331 		  priv->regs + TSI721_RIO_PW_RX_STAT);
332 	/* Update enable bits */
333 	iowrite32(rval, priv->regs + TSI721_RIO_EM_INT_ENABLE);
334 
335 	return 0;
336 }
337 
338 /**
339  * tsi721_dsend - Send a RapidIO doorbell
340  * @mport: RapidIO master port info
341  * @index: ID of RapidIO interface
342  * @destid: Destination ID of target device
343  * @data: 16-bit info field of RapidIO doorbell
344  *
345  * Sends a RapidIO doorbell message. Always returns %0.
346  */
347 static int tsi721_dsend(struct rio_mport *mport, int index,
348 			u16 destid, u16 data)
349 {
350 	struct tsi721_device *priv = mport->priv;
351 	u32 offset;
352 
353 	offset = (((mport->sys_size) ? RIO_TT_CODE_16 : RIO_TT_CODE_8) << 18) |
354 		 (destid << 2);
355 
356 	tsi_debug(DBELL, &priv->pdev->dev,
357 		  "Send Doorbell 0x%04x to destID 0x%x", data, destid);
358 	iowrite16be(data, priv->odb_base + offset);
359 
360 	return 0;
361 }
362 
363 /**
364  * tsi721_dbell_handler - Tsi721 doorbell interrupt handler
365  * @priv: tsi721 device-specific data structure
366  *
367  * Handles inbound doorbell interrupts. Copies doorbell entry from an internal
368  * buffer into DB message FIFO and schedules deferred  routine to process
369  * queued DBs.
370  */
371 static int
372 tsi721_dbell_handler(struct tsi721_device *priv)
373 {
374 	u32 regval;
375 
376 	/* Disable IDB interrupts */
377 	regval = ioread32(priv->regs + TSI721_SR_CHINTE(IDB_QUEUE));
378 	regval &= ~TSI721_SR_CHINT_IDBQRCV;
379 	iowrite32(regval,
380 		priv->regs + TSI721_SR_CHINTE(IDB_QUEUE));
381 
382 	schedule_work(&priv->idb_work);
383 
384 	return 0;
385 }
386 
387 static void tsi721_db_dpc(struct work_struct *work)
388 {
389 	struct tsi721_device *priv = container_of(work, struct tsi721_device,
390 						    idb_work);
391 	struct rio_mport *mport;
392 	struct rio_dbell *dbell;
393 	int found = 0;
394 	u32 wr_ptr, rd_ptr;
395 	u64 *idb_entry;
396 	u32 regval;
397 	union {
398 		u64 msg;
399 		u8  bytes[8];
400 	} idb;
401 
402 	/*
403 	 * Process queued inbound doorbells
404 	 */
405 	mport = &priv->mport;
406 
407 	wr_ptr = ioread32(priv->regs + TSI721_IDQ_WP(IDB_QUEUE)) % IDB_QSIZE;
408 	rd_ptr = ioread32(priv->regs + TSI721_IDQ_RP(IDB_QUEUE)) % IDB_QSIZE;
409 
410 	while (wr_ptr != rd_ptr) {
411 		idb_entry = (u64 *)(priv->idb_base +
412 					(TSI721_IDB_ENTRY_SIZE * rd_ptr));
413 		rd_ptr++;
414 		rd_ptr %= IDB_QSIZE;
415 		idb.msg = *idb_entry;
416 		*idb_entry = 0;
417 
418 		/* Process one doorbell */
419 		list_for_each_entry(dbell, &mport->dbells, node) {
420 			if ((dbell->res->start <= DBELL_INF(idb.bytes)) &&
421 			    (dbell->res->end >= DBELL_INF(idb.bytes))) {
422 				found = 1;
423 				break;
424 			}
425 		}
426 
427 		if (found) {
428 			dbell->dinb(mport, dbell->dev_id, DBELL_SID(idb.bytes),
429 				    DBELL_TID(idb.bytes), DBELL_INF(idb.bytes));
430 		} else {
431 			tsi_debug(DBELL, &priv->pdev->dev,
432 				  "spurious IDB sid %2.2x tid %2.2x info %4.4x",
433 				  DBELL_SID(idb.bytes), DBELL_TID(idb.bytes),
434 				  DBELL_INF(idb.bytes));
435 		}
436 
437 		wr_ptr = ioread32(priv->regs +
438 				  TSI721_IDQ_WP(IDB_QUEUE)) % IDB_QSIZE;
439 	}
440 
441 	iowrite32(rd_ptr & (IDB_QSIZE - 1),
442 		priv->regs + TSI721_IDQ_RP(IDB_QUEUE));
443 
444 	/* Re-enable IDB interrupts */
445 	regval = ioread32(priv->regs + TSI721_SR_CHINTE(IDB_QUEUE));
446 	regval |= TSI721_SR_CHINT_IDBQRCV;
447 	iowrite32(regval,
448 		priv->regs + TSI721_SR_CHINTE(IDB_QUEUE));
449 
450 	wr_ptr = ioread32(priv->regs + TSI721_IDQ_WP(IDB_QUEUE)) % IDB_QSIZE;
451 	if (wr_ptr != rd_ptr)
452 		schedule_work(&priv->idb_work);
453 }
454 
455 /**
456  * tsi721_irqhandler - Tsi721 interrupt handler
457  * @irq: Linux interrupt number
458  * @ptr: Pointer to interrupt-specific data (tsi721_device structure)
459  *
460  * Handles Tsi721 interrupts signaled using MSI and INTA. Checks reported
461  * interrupt events and calls an event-specific handler(s).
462  */
463 static irqreturn_t tsi721_irqhandler(int irq, void *ptr)
464 {
465 	struct tsi721_device *priv = (struct tsi721_device *)ptr;
466 	u32 dev_int;
467 	u32 dev_ch_int;
468 	u32 intval;
469 	u32 ch_inte;
470 
471 	/* For MSI mode disable all device-level interrupts */
472 	if (priv->flags & TSI721_USING_MSI)
473 		iowrite32(0, priv->regs + TSI721_DEV_INTE);
474 
475 	dev_int = ioread32(priv->regs + TSI721_DEV_INT);
476 	if (!dev_int)
477 		return IRQ_NONE;
478 
479 	dev_ch_int = ioread32(priv->regs + TSI721_DEV_CHAN_INT);
480 
481 	if (dev_int & TSI721_DEV_INT_SR2PC_CH) {
482 		/* Service SR2PC Channel interrupts */
483 		if (dev_ch_int & TSI721_INT_SR2PC_CHAN(IDB_QUEUE)) {
484 			/* Service Inbound Doorbell interrupt */
485 			intval = ioread32(priv->regs +
486 						TSI721_SR_CHINT(IDB_QUEUE));
487 			if (intval & TSI721_SR_CHINT_IDBQRCV)
488 				tsi721_dbell_handler(priv);
489 			else
490 				tsi_info(&priv->pdev->dev,
491 					"Unsupported SR_CH_INT %x", intval);
492 
493 			/* Clear interrupts */
494 			iowrite32(intval,
495 				priv->regs + TSI721_SR_CHINT(IDB_QUEUE));
496 			ioread32(priv->regs + TSI721_SR_CHINT(IDB_QUEUE));
497 		}
498 	}
499 
500 	if (dev_int & TSI721_DEV_INT_SMSG_CH) {
501 		int ch;
502 
503 		/*
504 		 * Service channel interrupts from Messaging Engine
505 		 */
506 
507 		if (dev_ch_int & TSI721_INT_IMSG_CHAN_M) { /* Inbound Msg */
508 			/* Disable signaled OB MSG Channel interrupts */
509 			ch_inte = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
510 			ch_inte &= ~(dev_ch_int & TSI721_INT_IMSG_CHAN_M);
511 			iowrite32(ch_inte, priv->regs + TSI721_DEV_CHAN_INTE);
512 
513 			/*
514 			 * Process Inbound Message interrupt for each MBOX
515 			 */
516 			for (ch = 4; ch < RIO_MAX_MBOX + 4; ch++) {
517 				if (!(dev_ch_int & TSI721_INT_IMSG_CHAN(ch)))
518 					continue;
519 				tsi721_imsg_handler(priv, ch);
520 			}
521 		}
522 
523 		if (dev_ch_int & TSI721_INT_OMSG_CHAN_M) { /* Outbound Msg */
524 			/* Disable signaled OB MSG Channel interrupts */
525 			ch_inte = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
526 			ch_inte &= ~(dev_ch_int & TSI721_INT_OMSG_CHAN_M);
527 			iowrite32(ch_inte, priv->regs + TSI721_DEV_CHAN_INTE);
528 
529 			/*
530 			 * Process Outbound Message interrupts for each MBOX
531 			 */
532 
533 			for (ch = 0; ch < RIO_MAX_MBOX; ch++) {
534 				if (!(dev_ch_int & TSI721_INT_OMSG_CHAN(ch)))
535 					continue;
536 				tsi721_omsg_handler(priv, ch);
537 			}
538 		}
539 	}
540 
541 	if (dev_int & TSI721_DEV_INT_SRIO) {
542 		/* Service SRIO MAC interrupts */
543 		intval = ioread32(priv->regs + TSI721_RIO_EM_INT_STAT);
544 		if (intval & TSI721_RIO_EM_INT_STAT_PW_RX)
545 			tsi721_pw_handler(priv);
546 	}
547 
548 #ifdef CONFIG_RAPIDIO_DMA_ENGINE
549 	if (dev_int & TSI721_DEV_INT_BDMA_CH) {
550 		int ch;
551 
552 		if (dev_ch_int & TSI721_INT_BDMA_CHAN_M) {
553 			tsi_debug(DMA, &priv->pdev->dev,
554 				  "IRQ from DMA channel 0x%08x", dev_ch_int);
555 
556 			for (ch = 0; ch < TSI721_DMA_MAXCH; ch++) {
557 				if (!(dev_ch_int & TSI721_INT_BDMA_CHAN(ch)))
558 					continue;
559 				tsi721_bdma_handler(&priv->bdma[ch]);
560 			}
561 		}
562 	}
563 #endif
564 
565 	/* For MSI mode re-enable device-level interrupts */
566 	if (priv->flags & TSI721_USING_MSI) {
567 		dev_int = TSI721_DEV_INT_SR2PC_CH | TSI721_DEV_INT_SRIO |
568 			TSI721_DEV_INT_SMSG_CH | TSI721_DEV_INT_BDMA_CH;
569 		iowrite32(dev_int, priv->regs + TSI721_DEV_INTE);
570 	}
571 
572 	return IRQ_HANDLED;
573 }
574 
575 static void tsi721_interrupts_init(struct tsi721_device *priv)
576 {
577 	u32 intr;
578 
579 	/* Enable IDB interrupts */
580 	iowrite32(TSI721_SR_CHINT_ALL,
581 		priv->regs + TSI721_SR_CHINT(IDB_QUEUE));
582 	iowrite32(TSI721_SR_CHINT_IDBQRCV,
583 		priv->regs + TSI721_SR_CHINTE(IDB_QUEUE));
584 
585 	/* Enable SRIO MAC interrupts */
586 	iowrite32(TSI721_RIO_EM_DEV_INT_EN_INT,
587 		priv->regs + TSI721_RIO_EM_DEV_INT_EN);
588 
589 	/* Enable interrupts from channels in use */
590 #ifdef CONFIG_RAPIDIO_DMA_ENGINE
591 	intr = TSI721_INT_SR2PC_CHAN(IDB_QUEUE) |
592 		(TSI721_INT_BDMA_CHAN_M &
593 		 ~TSI721_INT_BDMA_CHAN(TSI721_DMACH_MAINT));
594 #else
595 	intr = TSI721_INT_SR2PC_CHAN(IDB_QUEUE);
596 #endif
597 	iowrite32(intr,	priv->regs + TSI721_DEV_CHAN_INTE);
598 
599 	if (priv->flags & TSI721_USING_MSIX)
600 		intr = TSI721_DEV_INT_SRIO;
601 	else
602 		intr = TSI721_DEV_INT_SR2PC_CH | TSI721_DEV_INT_SRIO |
603 			TSI721_DEV_INT_SMSG_CH | TSI721_DEV_INT_BDMA_CH;
604 
605 	iowrite32(intr, priv->regs + TSI721_DEV_INTE);
606 	ioread32(priv->regs + TSI721_DEV_INTE);
607 }
608 
609 #ifdef CONFIG_PCI_MSI
610 /**
611  * tsi721_omsg_msix - MSI-X interrupt handler for outbound messaging
612  * @irq: Linux interrupt number
613  * @ptr: Pointer to interrupt-specific data (tsi721_device structure)
614  *
615  * Handles outbound messaging interrupts signaled using MSI-X.
616  */
617 static irqreturn_t tsi721_omsg_msix(int irq, void *ptr)
618 {
619 	struct tsi721_device *priv = (struct tsi721_device *)ptr;
620 	int mbox;
621 
622 	mbox = (irq - priv->msix[TSI721_VECT_OMB0_DONE].vector) % RIO_MAX_MBOX;
623 	tsi721_omsg_handler(priv, mbox);
624 	return IRQ_HANDLED;
625 }
626 
627 /**
628  * tsi721_imsg_msix - MSI-X interrupt handler for inbound messaging
629  * @irq: Linux interrupt number
630  * @ptr: Pointer to interrupt-specific data (tsi721_device structure)
631  *
632  * Handles inbound messaging interrupts signaled using MSI-X.
633  */
634 static irqreturn_t tsi721_imsg_msix(int irq, void *ptr)
635 {
636 	struct tsi721_device *priv = (struct tsi721_device *)ptr;
637 	int mbox;
638 
639 	mbox = (irq - priv->msix[TSI721_VECT_IMB0_RCV].vector) % RIO_MAX_MBOX;
640 	tsi721_imsg_handler(priv, mbox + 4);
641 	return IRQ_HANDLED;
642 }
643 
644 /**
645  * tsi721_srio_msix - Tsi721 MSI-X SRIO MAC interrupt handler
646  * @irq: Linux interrupt number
647  * @ptr: Pointer to interrupt-specific data (tsi721_device structure)
648  *
649  * Handles Tsi721 interrupts from SRIO MAC.
650  */
651 static irqreturn_t tsi721_srio_msix(int irq, void *ptr)
652 {
653 	struct tsi721_device *priv = (struct tsi721_device *)ptr;
654 	u32 srio_int;
655 
656 	/* Service SRIO MAC interrupts */
657 	srio_int = ioread32(priv->regs + TSI721_RIO_EM_INT_STAT);
658 	if (srio_int & TSI721_RIO_EM_INT_STAT_PW_RX)
659 		tsi721_pw_handler(priv);
660 
661 	return IRQ_HANDLED;
662 }
663 
664 /**
665  * tsi721_sr2pc_ch_msix - Tsi721 MSI-X SR2PC Channel interrupt handler
666  * @irq: Linux interrupt number
667  * @ptr: Pointer to interrupt-specific data (tsi721_device structure)
668  *
669  * Handles Tsi721 interrupts from SR2PC Channel.
670  * NOTE: At this moment services only one SR2PC channel associated with inbound
671  * doorbells.
672  */
673 static irqreturn_t tsi721_sr2pc_ch_msix(int irq, void *ptr)
674 {
675 	struct tsi721_device *priv = (struct tsi721_device *)ptr;
676 	u32 sr_ch_int;
677 
678 	/* Service Inbound DB interrupt from SR2PC channel */
679 	sr_ch_int = ioread32(priv->regs + TSI721_SR_CHINT(IDB_QUEUE));
680 	if (sr_ch_int & TSI721_SR_CHINT_IDBQRCV)
681 		tsi721_dbell_handler(priv);
682 
683 	/* Clear interrupts */
684 	iowrite32(sr_ch_int, priv->regs + TSI721_SR_CHINT(IDB_QUEUE));
685 	/* Read back to ensure that interrupt was cleared */
686 	sr_ch_int = ioread32(priv->regs + TSI721_SR_CHINT(IDB_QUEUE));
687 
688 	return IRQ_HANDLED;
689 }
690 
691 /**
692  * tsi721_request_msix - register interrupt service for MSI-X mode.
693  * @priv: tsi721 device-specific data structure
694  *
695  * Registers MSI-X interrupt service routines for interrupts that are active
696  * immediately after mport initialization. Messaging interrupt service routines
697  * should be registered during corresponding open requests.
698  */
699 static int tsi721_request_msix(struct tsi721_device *priv)
700 {
701 	int err = 0;
702 
703 	err = request_irq(priv->msix[TSI721_VECT_IDB].vector,
704 			tsi721_sr2pc_ch_msix, 0,
705 			priv->msix[TSI721_VECT_IDB].irq_name, (void *)priv);
706 	if (err)
707 		return err;
708 
709 	err = request_irq(priv->msix[TSI721_VECT_PWRX].vector,
710 			tsi721_srio_msix, 0,
711 			priv->msix[TSI721_VECT_PWRX].irq_name, (void *)priv);
712 	if (err) {
713 		free_irq(priv->msix[TSI721_VECT_IDB].vector, (void *)priv);
714 		return err;
715 	}
716 
717 	return 0;
718 }
719 
720 /**
721  * tsi721_enable_msix - Attempts to enable MSI-X support for Tsi721.
722  * @priv: pointer to tsi721 private data
723  *
724  * Configures MSI-X support for Tsi721. Supports only an exact number
725  * of requested vectors.
726  */
727 static int tsi721_enable_msix(struct tsi721_device *priv)
728 {
729 	struct msix_entry entries[TSI721_VECT_MAX];
730 	int err;
731 	int i;
732 
733 	entries[TSI721_VECT_IDB].entry = TSI721_MSIX_SR2PC_IDBQ_RCV(IDB_QUEUE);
734 	entries[TSI721_VECT_PWRX].entry = TSI721_MSIX_SRIO_MAC_INT;
735 
736 	/*
737 	 * Initialize MSI-X entries for Messaging Engine:
738 	 * this driver supports four RIO mailboxes (inbound and outbound)
739 	 * NOTE: Inbound message MBOX 0...4 use IB channels 4...7. Therefore
740 	 * offset +4 is added to IB MBOX number.
741 	 */
742 	for (i = 0; i < RIO_MAX_MBOX; i++) {
743 		entries[TSI721_VECT_IMB0_RCV + i].entry =
744 					TSI721_MSIX_IMSG_DQ_RCV(i + 4);
745 		entries[TSI721_VECT_IMB0_INT + i].entry =
746 					TSI721_MSIX_IMSG_INT(i + 4);
747 		entries[TSI721_VECT_OMB0_DONE + i].entry =
748 					TSI721_MSIX_OMSG_DONE(i);
749 		entries[TSI721_VECT_OMB0_INT + i].entry =
750 					TSI721_MSIX_OMSG_INT(i);
751 	}
752 
753 #ifdef CONFIG_RAPIDIO_DMA_ENGINE
754 	/*
755 	 * Initialize MSI-X entries for Block DMA Engine:
756 	 * this driver supports XXX DMA channels
757 	 * (one is reserved for SRIO maintenance transactions)
758 	 */
759 	for (i = 0; i < TSI721_DMA_CHNUM; i++) {
760 		entries[TSI721_VECT_DMA0_DONE + i].entry =
761 					TSI721_MSIX_DMACH_DONE(i);
762 		entries[TSI721_VECT_DMA0_INT + i].entry =
763 					TSI721_MSIX_DMACH_INT(i);
764 	}
765 #endif /* CONFIG_RAPIDIO_DMA_ENGINE */
766 
767 	err = pci_enable_msix_exact(priv->pdev, entries, ARRAY_SIZE(entries));
768 	if (err) {
769 		tsi_err(&priv->pdev->dev,
770 			"Failed to enable MSI-X (err=%d)", err);
771 		return err;
772 	}
773 
774 	/*
775 	 * Copy MSI-X vector information into tsi721 private structure
776 	 */
777 	priv->msix[TSI721_VECT_IDB].vector = entries[TSI721_VECT_IDB].vector;
778 	snprintf(priv->msix[TSI721_VECT_IDB].irq_name, IRQ_DEVICE_NAME_MAX,
779 		 DRV_NAME "-idb@pci:%s", pci_name(priv->pdev));
780 	priv->msix[TSI721_VECT_PWRX].vector = entries[TSI721_VECT_PWRX].vector;
781 	snprintf(priv->msix[TSI721_VECT_PWRX].irq_name, IRQ_DEVICE_NAME_MAX,
782 		 DRV_NAME "-pwrx@pci:%s", pci_name(priv->pdev));
783 
784 	for (i = 0; i < RIO_MAX_MBOX; i++) {
785 		priv->msix[TSI721_VECT_IMB0_RCV + i].vector =
786 				entries[TSI721_VECT_IMB0_RCV + i].vector;
787 		snprintf(priv->msix[TSI721_VECT_IMB0_RCV + i].irq_name,
788 			 IRQ_DEVICE_NAME_MAX, DRV_NAME "-imbr%d@pci:%s",
789 			 i, pci_name(priv->pdev));
790 
791 		priv->msix[TSI721_VECT_IMB0_INT + i].vector =
792 				entries[TSI721_VECT_IMB0_INT + i].vector;
793 		snprintf(priv->msix[TSI721_VECT_IMB0_INT + i].irq_name,
794 			 IRQ_DEVICE_NAME_MAX, DRV_NAME "-imbi%d@pci:%s",
795 			 i, pci_name(priv->pdev));
796 
797 		priv->msix[TSI721_VECT_OMB0_DONE + i].vector =
798 				entries[TSI721_VECT_OMB0_DONE + i].vector;
799 		snprintf(priv->msix[TSI721_VECT_OMB0_DONE + i].irq_name,
800 			 IRQ_DEVICE_NAME_MAX, DRV_NAME "-ombd%d@pci:%s",
801 			 i, pci_name(priv->pdev));
802 
803 		priv->msix[TSI721_VECT_OMB0_INT + i].vector =
804 				entries[TSI721_VECT_OMB0_INT + i].vector;
805 		snprintf(priv->msix[TSI721_VECT_OMB0_INT + i].irq_name,
806 			 IRQ_DEVICE_NAME_MAX, DRV_NAME "-ombi%d@pci:%s",
807 			 i, pci_name(priv->pdev));
808 	}
809 
810 #ifdef CONFIG_RAPIDIO_DMA_ENGINE
811 	for (i = 0; i < TSI721_DMA_CHNUM; i++) {
812 		priv->msix[TSI721_VECT_DMA0_DONE + i].vector =
813 				entries[TSI721_VECT_DMA0_DONE + i].vector;
814 		snprintf(priv->msix[TSI721_VECT_DMA0_DONE + i].irq_name,
815 			 IRQ_DEVICE_NAME_MAX, DRV_NAME "-dmad%d@pci:%s",
816 			 i, pci_name(priv->pdev));
817 
818 		priv->msix[TSI721_VECT_DMA0_INT + i].vector =
819 				entries[TSI721_VECT_DMA0_INT + i].vector;
820 		snprintf(priv->msix[TSI721_VECT_DMA0_INT + i].irq_name,
821 			 IRQ_DEVICE_NAME_MAX, DRV_NAME "-dmai%d@pci:%s",
822 			 i, pci_name(priv->pdev));
823 	}
824 #endif /* CONFIG_RAPIDIO_DMA_ENGINE */
825 
826 	return 0;
827 }
828 #endif /* CONFIG_PCI_MSI */
829 
830 static int tsi721_request_irq(struct tsi721_device *priv)
831 {
832 	int err;
833 
834 #ifdef CONFIG_PCI_MSI
835 	if (priv->flags & TSI721_USING_MSIX)
836 		err = tsi721_request_msix(priv);
837 	else
838 #endif
839 		err = request_irq(priv->pdev->irq, tsi721_irqhandler,
840 			  (priv->flags & TSI721_USING_MSI) ? 0 : IRQF_SHARED,
841 			  DRV_NAME, (void *)priv);
842 
843 	if (err)
844 		tsi_err(&priv->pdev->dev,
845 			"Unable to allocate interrupt, err=%d", err);
846 
847 	return err;
848 }
849 
850 static void tsi721_free_irq(struct tsi721_device *priv)
851 {
852 #ifdef CONFIG_PCI_MSI
853 	if (priv->flags & TSI721_USING_MSIX) {
854 		free_irq(priv->msix[TSI721_VECT_IDB].vector, (void *)priv);
855 		free_irq(priv->msix[TSI721_VECT_PWRX].vector, (void *)priv);
856 	} else
857 #endif
858 	free_irq(priv->pdev->irq, (void *)priv);
859 }
860 
861 static int
862 tsi721_obw_alloc(struct tsi721_device *priv, struct tsi721_obw_bar *pbar,
863 		 u32 size, int *win_id)
864 {
865 	u64 win_base;
866 	u64 bar_base;
867 	u64 bar_end;
868 	u32 align;
869 	struct tsi721_ob_win *win;
870 	struct tsi721_ob_win *new_win = NULL;
871 	int new_win_idx = -1;
872 	int i = 0;
873 
874 	bar_base = pbar->base;
875 	bar_end =  bar_base + pbar->size;
876 	win_base = bar_base;
877 	align = size/TSI721_PC2SR_ZONES;
878 
879 	while (i < TSI721_IBWIN_NUM) {
880 		for (i = 0; i < TSI721_IBWIN_NUM; i++) {
881 			if (!priv->ob_win[i].active) {
882 				if (new_win == NULL) {
883 					new_win = &priv->ob_win[i];
884 					new_win_idx = i;
885 				}
886 				continue;
887 			}
888 
889 			/*
890 			 * If this window belongs to the current BAR check it
891 			 * for overlap
892 			 */
893 			win = &priv->ob_win[i];
894 
895 			if (win->base >= bar_base && win->base < bar_end) {
896 				if (win_base < (win->base + win->size) &&
897 						(win_base + size) > win->base) {
898 					/* Overlap detected */
899 					win_base = win->base + win->size;
900 					win_base = ALIGN(win_base, align);
901 					break;
902 				}
903 			}
904 		}
905 	}
906 
907 	if (win_base + size > bar_end)
908 		return -ENOMEM;
909 
910 	if (!new_win) {
911 		tsi_err(&priv->pdev->dev, "OBW count tracking failed");
912 		return -EIO;
913 	}
914 
915 	new_win->active = true;
916 	new_win->base = win_base;
917 	new_win->size = size;
918 	new_win->pbar = pbar;
919 	priv->obwin_cnt--;
920 	pbar->free -= size;
921 	*win_id = new_win_idx;
922 	return 0;
923 }
924 
925 static int tsi721_map_outb_win(struct rio_mport *mport, u16 destid, u64 rstart,
926 			u32 size, u32 flags, dma_addr_t *laddr)
927 {
928 	struct tsi721_device *priv = mport->priv;
929 	int i;
930 	struct tsi721_obw_bar *pbar;
931 	struct tsi721_ob_win *ob_win;
932 	int obw = -1;
933 	u32 rval;
934 	u64 rio_addr;
935 	u32 zsize;
936 	int ret = -ENOMEM;
937 
938 	tsi_debug(OBW, &priv->pdev->dev,
939 		  "did=%d ra=0x%llx sz=0x%x", destid, rstart, size);
940 
941 	if (!is_power_of_2(size) || (size < 0x8000) || (rstart & (size - 1)))
942 		return -EINVAL;
943 
944 	if (priv->obwin_cnt == 0)
945 		return -EBUSY;
946 
947 	for (i = 0; i < 2; i++) {
948 		if (priv->p2r_bar[i].free >= size) {
949 			pbar = &priv->p2r_bar[i];
950 			ret = tsi721_obw_alloc(priv, pbar, size, &obw);
951 			if (!ret)
952 				break;
953 		}
954 	}
955 
956 	if (ret)
957 		return ret;
958 
959 	WARN_ON(obw == -1);
960 	ob_win = &priv->ob_win[obw];
961 	ob_win->destid = destid;
962 	ob_win->rstart = rstart;
963 	tsi_debug(OBW, &priv->pdev->dev,
964 		  "allocated OBW%d @%llx", obw, ob_win->base);
965 
966 	/*
967 	 * Configure Outbound Window
968 	 */
969 
970 	zsize = size/TSI721_PC2SR_ZONES;
971 	rio_addr = rstart;
972 
973 	/*
974 	 * Program Address Translation Zones:
975 	 *  This implementation uses all 8 zones associated wit window.
976 	 */
977 	for (i = 0; i < TSI721_PC2SR_ZONES; i++) {
978 
979 		while (ioread32(priv->regs + TSI721_ZONE_SEL) &
980 			TSI721_ZONE_SEL_GO) {
981 			udelay(1);
982 		}
983 
984 		rval = (u32)(rio_addr & TSI721_LUT_DATA0_ADD) |
985 			TSI721_LUT_DATA0_NREAD | TSI721_LUT_DATA0_NWR;
986 		iowrite32(rval, priv->regs + TSI721_LUT_DATA0);
987 		rval = (u32)(rio_addr >> 32);
988 		iowrite32(rval, priv->regs + TSI721_LUT_DATA1);
989 		rval = destid;
990 		iowrite32(rval, priv->regs + TSI721_LUT_DATA2);
991 
992 		rval = TSI721_ZONE_SEL_GO | (obw << 3) | i;
993 		iowrite32(rval, priv->regs + TSI721_ZONE_SEL);
994 
995 		rio_addr += zsize;
996 	}
997 
998 	iowrite32(TSI721_OBWIN_SIZE(size) << 8,
999 		  priv->regs + TSI721_OBWINSZ(obw));
1000 	iowrite32((u32)(ob_win->base >> 32), priv->regs + TSI721_OBWINUB(obw));
1001 	iowrite32((u32)(ob_win->base & TSI721_OBWINLB_BA) | TSI721_OBWINLB_WEN,
1002 		  priv->regs + TSI721_OBWINLB(obw));
1003 
1004 	*laddr = ob_win->base;
1005 	return 0;
1006 }
1007 
1008 static void tsi721_unmap_outb_win(struct rio_mport *mport,
1009 				  u16 destid, u64 rstart)
1010 {
1011 	struct tsi721_device *priv = mport->priv;
1012 	struct tsi721_ob_win *ob_win;
1013 	int i;
1014 
1015 	tsi_debug(OBW, &priv->pdev->dev, "did=%d ra=0x%llx", destid, rstart);
1016 
1017 	for (i = 0; i < TSI721_OBWIN_NUM; i++) {
1018 		ob_win = &priv->ob_win[i];
1019 
1020 		if (ob_win->active &&
1021 		    ob_win->destid == destid && ob_win->rstart == rstart) {
1022 			tsi_debug(OBW, &priv->pdev->dev,
1023 				  "free OBW%d @%llx", i, ob_win->base);
1024 			ob_win->active = false;
1025 			iowrite32(0, priv->regs + TSI721_OBWINLB(i));
1026 			ob_win->pbar->free += ob_win->size;
1027 			priv->obwin_cnt++;
1028 			break;
1029 		}
1030 	}
1031 }
1032 
1033 /**
1034  * tsi721_init_pc2sr_mapping - initializes outbound (PCIe->SRIO)
1035  * translation regions.
1036  * @priv: pointer to tsi721 private data
1037  *
1038  * Disables SREP translation regions.
1039  */
1040 static void tsi721_init_pc2sr_mapping(struct tsi721_device *priv)
1041 {
1042 	int i, z;
1043 	u32 rval;
1044 
1045 	/* Disable all PC2SR translation windows */
1046 	for (i = 0; i < TSI721_OBWIN_NUM; i++)
1047 		iowrite32(0, priv->regs + TSI721_OBWINLB(i));
1048 
1049 	/* Initialize zone lookup tables to avoid ECC errors on reads */
1050 	iowrite32(0, priv->regs + TSI721_LUT_DATA0);
1051 	iowrite32(0, priv->regs + TSI721_LUT_DATA1);
1052 	iowrite32(0, priv->regs + TSI721_LUT_DATA2);
1053 
1054 	for (i = 0; i < TSI721_OBWIN_NUM; i++) {
1055 		for (z = 0; z < TSI721_PC2SR_ZONES; z++) {
1056 			while (ioread32(priv->regs + TSI721_ZONE_SEL) &
1057 				TSI721_ZONE_SEL_GO) {
1058 				udelay(1);
1059 			}
1060 			rval = TSI721_ZONE_SEL_GO | (i << 3) | z;
1061 			iowrite32(rval, priv->regs + TSI721_ZONE_SEL);
1062 		}
1063 	}
1064 
1065 	if (priv->p2r_bar[0].size == 0 && priv->p2r_bar[1].size == 0) {
1066 		priv->obwin_cnt = 0;
1067 		return;
1068 	}
1069 
1070 	priv->p2r_bar[0].free = priv->p2r_bar[0].size;
1071 	priv->p2r_bar[1].free = priv->p2r_bar[1].size;
1072 
1073 	for (i = 0; i < TSI721_OBWIN_NUM; i++)
1074 		priv->ob_win[i].active = false;
1075 
1076 	priv->obwin_cnt = TSI721_OBWIN_NUM;
1077 }
1078 
1079 /**
1080  * tsi721_rio_map_inb_mem -- Mapping inbound memory region.
1081  * @mport: RapidIO master port
1082  * @lstart: Local memory space start address.
1083  * @rstart: RapidIO space start address.
1084  * @size: The mapping region size.
1085  * @flags: Flags for mapping. 0 for using default flags.
1086  *
1087  * Return: 0 -- Success.
1088  *
1089  * This function will create the inbound mapping
1090  * from rstart to lstart.
1091  */
1092 static int tsi721_rio_map_inb_mem(struct rio_mport *mport, dma_addr_t lstart,
1093 		u64 rstart, u64 size, u32 flags)
1094 {
1095 	struct tsi721_device *priv = mport->priv;
1096 	int i, avail = -1;
1097 	u32 regval;
1098 	struct tsi721_ib_win *ib_win;
1099 	bool direct = (lstart == rstart);
1100 	u64 ibw_size;
1101 	dma_addr_t loc_start;
1102 	u64 ibw_start;
1103 	struct tsi721_ib_win_mapping *map = NULL;
1104 	int ret = -EBUSY;
1105 
1106 	/* Max IBW size supported by HW is 16GB */
1107 	if (size > 0x400000000UL)
1108 		return -EINVAL;
1109 
1110 	if (direct) {
1111 		/* Calculate minimal acceptable window size and base address */
1112 
1113 		ibw_size = roundup_pow_of_two(size);
1114 		ibw_start = lstart & ~(ibw_size - 1);
1115 
1116 		tsi_debug(IBW, &priv->pdev->dev,
1117 			"Direct (RIO_0x%llx -> PCIe_%pad), size=0x%llx, ibw_start = 0x%llx",
1118 			rstart, &lstart, size, ibw_start);
1119 
1120 		while ((lstart + size) > (ibw_start + ibw_size)) {
1121 			ibw_size *= 2;
1122 			ibw_start = lstart & ~(ibw_size - 1);
1123 			/* Check for crossing IBW max size 16GB */
1124 			if (ibw_size > 0x400000000UL)
1125 				return -EBUSY;
1126 		}
1127 
1128 		loc_start = ibw_start;
1129 
1130 		map = kzalloc(sizeof(struct tsi721_ib_win_mapping), GFP_ATOMIC);
1131 		if (map == NULL)
1132 			return -ENOMEM;
1133 
1134 	} else {
1135 		tsi_debug(IBW, &priv->pdev->dev,
1136 			"Translated (RIO_0x%llx -> PCIe_%pad), size=0x%llx",
1137 			rstart, &lstart, size);
1138 
1139 		if (!is_power_of_2(size) || size < 0x1000 ||
1140 		    ((u64)lstart & (size - 1)) || (rstart & (size - 1)))
1141 			return -EINVAL;
1142 		if (priv->ibwin_cnt == 0)
1143 			return -EBUSY;
1144 		ibw_start = rstart;
1145 		ibw_size = size;
1146 		loc_start = lstart;
1147 	}
1148 
1149 	/*
1150 	 * Scan for overlapping with active regions and mark the first available
1151 	 * IB window at the same time.
1152 	 */
1153 	for (i = 0; i < TSI721_IBWIN_NUM; i++) {
1154 		ib_win = &priv->ib_win[i];
1155 
1156 		if (!ib_win->active) {
1157 			if (avail == -1) {
1158 				avail = i;
1159 				ret = 0;
1160 			}
1161 		} else if (ibw_start < (ib_win->rstart + ib_win->size) &&
1162 			   (ibw_start + ibw_size) > ib_win->rstart) {
1163 			/* Return error if address translation involved */
1164 			if (!direct || ib_win->xlat) {
1165 				ret = -EFAULT;
1166 				break;
1167 			}
1168 
1169 			/*
1170 			 * Direct mappings usually are larger than originally
1171 			 * requested fragments - check if this new request fits
1172 			 * into it.
1173 			 */
1174 			if (rstart >= ib_win->rstart &&
1175 			    (rstart + size) <= (ib_win->rstart +
1176 							ib_win->size)) {
1177 				/* We are in - no further mapping required */
1178 				map->lstart = lstart;
1179 				list_add_tail(&map->node, &ib_win->mappings);
1180 				return 0;
1181 			}
1182 
1183 			ret = -EFAULT;
1184 			break;
1185 		}
1186 	}
1187 
1188 	if (ret)
1189 		goto out;
1190 	i = avail;
1191 
1192 	/* Sanity check: available IB window must be disabled at this point */
1193 	regval = ioread32(priv->regs + TSI721_IBWIN_LB(i));
1194 	if (WARN_ON(regval & TSI721_IBWIN_LB_WEN)) {
1195 		ret = -EIO;
1196 		goto out;
1197 	}
1198 
1199 	ib_win = &priv->ib_win[i];
1200 	ib_win->active = true;
1201 	ib_win->rstart = ibw_start;
1202 	ib_win->lstart = loc_start;
1203 	ib_win->size = ibw_size;
1204 	ib_win->xlat = (lstart != rstart);
1205 	INIT_LIST_HEAD(&ib_win->mappings);
1206 
1207 	/*
1208 	 * When using direct IBW mapping and have larger than requested IBW size
1209 	 * we can have multiple local memory blocks mapped through the same IBW
1210 	 * To handle this situation we maintain list of "clients" for such IBWs.
1211 	 */
1212 	if (direct) {
1213 		map->lstart = lstart;
1214 		list_add_tail(&map->node, &ib_win->mappings);
1215 	}
1216 
1217 	iowrite32(TSI721_IBWIN_SIZE(ibw_size) << 8,
1218 			priv->regs + TSI721_IBWIN_SZ(i));
1219 
1220 	iowrite32(((u64)loc_start >> 32), priv->regs + TSI721_IBWIN_TUA(i));
1221 	iowrite32(((u64)loc_start & TSI721_IBWIN_TLA_ADD),
1222 		  priv->regs + TSI721_IBWIN_TLA(i));
1223 
1224 	iowrite32(ibw_start >> 32, priv->regs + TSI721_IBWIN_UB(i));
1225 	iowrite32((ibw_start & TSI721_IBWIN_LB_BA) | TSI721_IBWIN_LB_WEN,
1226 		priv->regs + TSI721_IBWIN_LB(i));
1227 
1228 	priv->ibwin_cnt--;
1229 
1230 	tsi_debug(IBW, &priv->pdev->dev,
1231 		"Configured IBWIN%d (RIO_0x%llx -> PCIe_%pad), size=0x%llx",
1232 		i, ibw_start, &loc_start, ibw_size);
1233 
1234 	return 0;
1235 out:
1236 	kfree(map);
1237 	return ret;
1238 }
1239 
1240 /**
1241  * tsi721_rio_unmap_inb_mem -- Unmapping inbound memory region.
1242  * @mport: RapidIO master port
1243  * @lstart: Local memory space start address.
1244  */
1245 static void tsi721_rio_unmap_inb_mem(struct rio_mport *mport,
1246 				dma_addr_t lstart)
1247 {
1248 	struct tsi721_device *priv = mport->priv;
1249 	struct tsi721_ib_win *ib_win;
1250 	int i;
1251 
1252 	tsi_debug(IBW, &priv->pdev->dev,
1253 		"Unmap IBW mapped to PCIe_%pad", &lstart);
1254 
1255 	/* Search for matching active inbound translation window */
1256 	for (i = 0; i < TSI721_IBWIN_NUM; i++) {
1257 		ib_win = &priv->ib_win[i];
1258 
1259 		/* Address translating IBWs must to be an exact march */
1260 		if (!ib_win->active ||
1261 		    (ib_win->xlat && lstart != ib_win->lstart))
1262 			continue;
1263 
1264 		if (lstart >= ib_win->lstart &&
1265 		    lstart < (ib_win->lstart + ib_win->size)) {
1266 
1267 			if (!ib_win->xlat) {
1268 				struct tsi721_ib_win_mapping *map;
1269 				int found = 0;
1270 
1271 				list_for_each_entry(map,
1272 						    &ib_win->mappings, node) {
1273 					if (map->lstart == lstart) {
1274 						list_del(&map->node);
1275 						kfree(map);
1276 						found = 1;
1277 						break;
1278 					}
1279 				}
1280 
1281 				if (!found)
1282 					continue;
1283 
1284 				if (!list_empty(&ib_win->mappings))
1285 					break;
1286 			}
1287 
1288 			tsi_debug(IBW, &priv->pdev->dev, "Disable IBWIN_%d", i);
1289 			iowrite32(0, priv->regs + TSI721_IBWIN_LB(i));
1290 			ib_win->active = false;
1291 			priv->ibwin_cnt++;
1292 			break;
1293 		}
1294 	}
1295 
1296 	if (i == TSI721_IBWIN_NUM)
1297 		tsi_debug(IBW, &priv->pdev->dev,
1298 			"IB window mapped to %pad not found", &lstart);
1299 }
1300 
1301 /**
1302  * tsi721_init_sr2pc_mapping - initializes inbound (SRIO->PCIe)
1303  * translation regions.
1304  * @priv: pointer to tsi721 private data
1305  *
1306  * Disables inbound windows.
1307  */
1308 static void tsi721_init_sr2pc_mapping(struct tsi721_device *priv)
1309 {
1310 	int i;
1311 
1312 	/* Disable all SR2PC inbound windows */
1313 	for (i = 0; i < TSI721_IBWIN_NUM; i++)
1314 		iowrite32(0, priv->regs + TSI721_IBWIN_LB(i));
1315 	priv->ibwin_cnt = TSI721_IBWIN_NUM;
1316 }
1317 
1318 /*
1319  * tsi721_close_sr2pc_mapping - closes all active inbound (SRIO->PCIe)
1320  * translation regions.
1321  * @priv: pointer to tsi721 device private data
1322  */
1323 static void tsi721_close_sr2pc_mapping(struct tsi721_device *priv)
1324 {
1325 	struct tsi721_ib_win *ib_win;
1326 	int i;
1327 
1328 	/* Disable all active SR2PC inbound windows */
1329 	for (i = 0; i < TSI721_IBWIN_NUM; i++) {
1330 		ib_win = &priv->ib_win[i];
1331 		if (ib_win->active) {
1332 			iowrite32(0, priv->regs + TSI721_IBWIN_LB(i));
1333 			ib_win->active = false;
1334 		}
1335 	}
1336 }
1337 
1338 /**
1339  * tsi721_port_write_init - Inbound port write interface init
1340  * @priv: pointer to tsi721 private data
1341  *
1342  * Initializes inbound port write handler.
1343  * Returns %0 on success or %-ENOMEM on failure.
1344  */
1345 static int tsi721_port_write_init(struct tsi721_device *priv)
1346 {
1347 	priv->pw_discard_count = 0;
1348 	INIT_WORK(&priv->pw_work, tsi721_pw_dpc);
1349 	spin_lock_init(&priv->pw_fifo_lock);
1350 	if (kfifo_alloc(&priv->pw_fifo,
1351 			TSI721_RIO_PW_MSG_SIZE * 32, GFP_KERNEL)) {
1352 		tsi_err(&priv->pdev->dev, "PW FIFO allocation failed");
1353 		return -ENOMEM;
1354 	}
1355 
1356 	/* Use reliable port-write capture mode */
1357 	iowrite32(TSI721_RIO_PW_CTL_PWC_REL, priv->regs + TSI721_RIO_PW_CTL);
1358 	return 0;
1359 }
1360 
1361 static void tsi721_port_write_free(struct tsi721_device *priv)
1362 {
1363 	kfifo_free(&priv->pw_fifo);
1364 }
1365 
1366 static int tsi721_doorbell_init(struct tsi721_device *priv)
1367 {
1368 	/* Outbound Doorbells do not require any setup.
1369 	 * Tsi721 uses dedicated PCI BAR1 to generate doorbells.
1370 	 * That BAR1 was mapped during the probe routine.
1371 	 */
1372 
1373 	/* Initialize Inbound Doorbell processing DPC and queue */
1374 	priv->db_discard_count = 0;
1375 	INIT_WORK(&priv->idb_work, tsi721_db_dpc);
1376 
1377 	/* Allocate buffer for inbound doorbells queue */
1378 	priv->idb_base = dma_zalloc_coherent(&priv->pdev->dev,
1379 				IDB_QSIZE * TSI721_IDB_ENTRY_SIZE,
1380 				&priv->idb_dma, GFP_KERNEL);
1381 	if (!priv->idb_base)
1382 		return -ENOMEM;
1383 
1384 	tsi_debug(DBELL, &priv->pdev->dev,
1385 		  "Allocated IDB buffer @ %p (phys = %pad)",
1386 		  priv->idb_base, &priv->idb_dma);
1387 
1388 	iowrite32(TSI721_IDQ_SIZE_VAL(IDB_QSIZE),
1389 		priv->regs + TSI721_IDQ_SIZE(IDB_QUEUE));
1390 	iowrite32(((u64)priv->idb_dma >> 32),
1391 		priv->regs + TSI721_IDQ_BASEU(IDB_QUEUE));
1392 	iowrite32(((u64)priv->idb_dma & TSI721_IDQ_BASEL_ADDR),
1393 		priv->regs + TSI721_IDQ_BASEL(IDB_QUEUE));
1394 	/* Enable accepting all inbound doorbells */
1395 	iowrite32(0, priv->regs + TSI721_IDQ_MASK(IDB_QUEUE));
1396 
1397 	iowrite32(TSI721_IDQ_INIT, priv->regs + TSI721_IDQ_CTL(IDB_QUEUE));
1398 
1399 	iowrite32(0, priv->regs + TSI721_IDQ_RP(IDB_QUEUE));
1400 
1401 	return 0;
1402 }
1403 
1404 static void tsi721_doorbell_free(struct tsi721_device *priv)
1405 {
1406 	if (priv->idb_base == NULL)
1407 		return;
1408 
1409 	/* Free buffer allocated for inbound doorbell queue */
1410 	dma_free_coherent(&priv->pdev->dev, IDB_QSIZE * TSI721_IDB_ENTRY_SIZE,
1411 			  priv->idb_base, priv->idb_dma);
1412 	priv->idb_base = NULL;
1413 }
1414 
1415 /**
1416  * tsi721_bdma_maint_init - Initialize maintenance request BDMA channel.
1417  * @priv: pointer to tsi721 private data
1418  *
1419  * Initialize BDMA channel allocated for RapidIO maintenance read/write
1420  * request generation
1421  * Returns %0 on success or %-ENOMEM on failure.
1422  */
1423 static int tsi721_bdma_maint_init(struct tsi721_device *priv)
1424 {
1425 	struct tsi721_dma_desc *bd_ptr;
1426 	u64		*sts_ptr;
1427 	dma_addr_t	bd_phys, sts_phys;
1428 	int		sts_size;
1429 	int		bd_num = 2;
1430 	void __iomem	*regs;
1431 
1432 	tsi_debug(MAINT, &priv->pdev->dev,
1433 		  "Init BDMA_%d Maintenance requests", TSI721_DMACH_MAINT);
1434 
1435 	/*
1436 	 * Initialize DMA channel for maintenance requests
1437 	 */
1438 
1439 	priv->mdma.ch_id = TSI721_DMACH_MAINT;
1440 	regs = priv->regs + TSI721_DMAC_BASE(TSI721_DMACH_MAINT);
1441 
1442 	/* Allocate space for DMA descriptors */
1443 	bd_ptr = dma_zalloc_coherent(&priv->pdev->dev,
1444 					bd_num * sizeof(struct tsi721_dma_desc),
1445 					&bd_phys, GFP_KERNEL);
1446 	if (!bd_ptr)
1447 		return -ENOMEM;
1448 
1449 	priv->mdma.bd_num = bd_num;
1450 	priv->mdma.bd_phys = bd_phys;
1451 	priv->mdma.bd_base = bd_ptr;
1452 
1453 	tsi_debug(MAINT, &priv->pdev->dev, "DMA descriptors @ %p (phys = %pad)",
1454 		  bd_ptr, &bd_phys);
1455 
1456 	/* Allocate space for descriptor status FIFO */
1457 	sts_size = (bd_num >= TSI721_DMA_MINSTSSZ) ?
1458 					bd_num : TSI721_DMA_MINSTSSZ;
1459 	sts_size = roundup_pow_of_two(sts_size);
1460 	sts_ptr = dma_zalloc_coherent(&priv->pdev->dev,
1461 				     sts_size * sizeof(struct tsi721_dma_sts),
1462 				     &sts_phys, GFP_KERNEL);
1463 	if (!sts_ptr) {
1464 		/* Free space allocated for DMA descriptors */
1465 		dma_free_coherent(&priv->pdev->dev,
1466 				  bd_num * sizeof(struct tsi721_dma_desc),
1467 				  bd_ptr, bd_phys);
1468 		priv->mdma.bd_base = NULL;
1469 		return -ENOMEM;
1470 	}
1471 
1472 	priv->mdma.sts_phys = sts_phys;
1473 	priv->mdma.sts_base = sts_ptr;
1474 	priv->mdma.sts_size = sts_size;
1475 
1476 	tsi_debug(MAINT, &priv->pdev->dev,
1477 		"desc status FIFO @ %p (phys = %pad) size=0x%x",
1478 		sts_ptr, &sts_phys, sts_size);
1479 
1480 	/* Initialize DMA descriptors ring */
1481 	bd_ptr[bd_num - 1].type_id = cpu_to_le32(DTYPE3 << 29);
1482 	bd_ptr[bd_num - 1].next_lo = cpu_to_le32((u64)bd_phys &
1483 						 TSI721_DMAC_DPTRL_MASK);
1484 	bd_ptr[bd_num - 1].next_hi = cpu_to_le32((u64)bd_phys >> 32);
1485 
1486 	/* Setup DMA descriptor pointers */
1487 	iowrite32(((u64)bd_phys >> 32),	regs + TSI721_DMAC_DPTRH);
1488 	iowrite32(((u64)bd_phys & TSI721_DMAC_DPTRL_MASK),
1489 		regs + TSI721_DMAC_DPTRL);
1490 
1491 	/* Setup descriptor status FIFO */
1492 	iowrite32(((u64)sts_phys >> 32), regs + TSI721_DMAC_DSBH);
1493 	iowrite32(((u64)sts_phys & TSI721_DMAC_DSBL_MASK),
1494 		regs + TSI721_DMAC_DSBL);
1495 	iowrite32(TSI721_DMAC_DSSZ_SIZE(sts_size),
1496 		regs + TSI721_DMAC_DSSZ);
1497 
1498 	/* Clear interrupt bits */
1499 	iowrite32(TSI721_DMAC_INT_ALL, regs + TSI721_DMAC_INT);
1500 
1501 	ioread32(regs + TSI721_DMAC_INT);
1502 
1503 	/* Toggle DMA channel initialization */
1504 	iowrite32(TSI721_DMAC_CTL_INIT,	regs + TSI721_DMAC_CTL);
1505 	ioread32(regs + TSI721_DMAC_CTL);
1506 	udelay(10);
1507 
1508 	return 0;
1509 }
1510 
1511 static int tsi721_bdma_maint_free(struct tsi721_device *priv)
1512 {
1513 	u32 ch_stat;
1514 	struct tsi721_bdma_maint *mdma = &priv->mdma;
1515 	void __iomem *regs = priv->regs + TSI721_DMAC_BASE(mdma->ch_id);
1516 
1517 	if (mdma->bd_base == NULL)
1518 		return 0;
1519 
1520 	/* Check if DMA channel still running */
1521 	ch_stat = ioread32(regs + TSI721_DMAC_STS);
1522 	if (ch_stat & TSI721_DMAC_STS_RUN)
1523 		return -EFAULT;
1524 
1525 	/* Put DMA channel into init state */
1526 	iowrite32(TSI721_DMAC_CTL_INIT,	regs + TSI721_DMAC_CTL);
1527 
1528 	/* Free space allocated for DMA descriptors */
1529 	dma_free_coherent(&priv->pdev->dev,
1530 		mdma->bd_num * sizeof(struct tsi721_dma_desc),
1531 		mdma->bd_base, mdma->bd_phys);
1532 	mdma->bd_base = NULL;
1533 
1534 	/* Free space allocated for status FIFO */
1535 	dma_free_coherent(&priv->pdev->dev,
1536 		mdma->sts_size * sizeof(struct tsi721_dma_sts),
1537 		mdma->sts_base, mdma->sts_phys);
1538 	mdma->sts_base = NULL;
1539 	return 0;
1540 }
1541 
1542 /* Enable Inbound Messaging Interrupts */
1543 static void
1544 tsi721_imsg_interrupt_enable(struct tsi721_device *priv, int ch,
1545 				  u32 inte_mask)
1546 {
1547 	u32 rval;
1548 
1549 	if (!inte_mask)
1550 		return;
1551 
1552 	/* Clear pending Inbound Messaging interrupts */
1553 	iowrite32(inte_mask, priv->regs + TSI721_IBDMAC_INT(ch));
1554 
1555 	/* Enable Inbound Messaging interrupts */
1556 	rval = ioread32(priv->regs + TSI721_IBDMAC_INTE(ch));
1557 	iowrite32(rval | inte_mask, priv->regs + TSI721_IBDMAC_INTE(ch));
1558 
1559 	if (priv->flags & TSI721_USING_MSIX)
1560 		return; /* Finished if we are in MSI-X mode */
1561 
1562 	/*
1563 	 * For MSI and INTA interrupt signalling we need to enable next levels
1564 	 */
1565 
1566 	/* Enable Device Channel Interrupt */
1567 	rval = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
1568 	iowrite32(rval | TSI721_INT_IMSG_CHAN(ch),
1569 		  priv->regs + TSI721_DEV_CHAN_INTE);
1570 }
1571 
1572 /* Disable Inbound Messaging Interrupts */
1573 static void
1574 tsi721_imsg_interrupt_disable(struct tsi721_device *priv, int ch,
1575 				   u32 inte_mask)
1576 {
1577 	u32 rval;
1578 
1579 	if (!inte_mask)
1580 		return;
1581 
1582 	/* Clear pending Inbound Messaging interrupts */
1583 	iowrite32(inte_mask, priv->regs + TSI721_IBDMAC_INT(ch));
1584 
1585 	/* Disable Inbound Messaging interrupts */
1586 	rval = ioread32(priv->regs + TSI721_IBDMAC_INTE(ch));
1587 	rval &= ~inte_mask;
1588 	iowrite32(rval, priv->regs + TSI721_IBDMAC_INTE(ch));
1589 
1590 	if (priv->flags & TSI721_USING_MSIX)
1591 		return; /* Finished if we are in MSI-X mode */
1592 
1593 	/*
1594 	 * For MSI and INTA interrupt signalling we need to disable next levels
1595 	 */
1596 
1597 	/* Disable Device Channel Interrupt */
1598 	rval = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
1599 	rval &= ~TSI721_INT_IMSG_CHAN(ch);
1600 	iowrite32(rval, priv->regs + TSI721_DEV_CHAN_INTE);
1601 }
1602 
1603 /* Enable Outbound Messaging interrupts */
1604 static void
1605 tsi721_omsg_interrupt_enable(struct tsi721_device *priv, int ch,
1606 				  u32 inte_mask)
1607 {
1608 	u32 rval;
1609 
1610 	if (!inte_mask)
1611 		return;
1612 
1613 	/* Clear pending Outbound Messaging interrupts */
1614 	iowrite32(inte_mask, priv->regs + TSI721_OBDMAC_INT(ch));
1615 
1616 	/* Enable Outbound Messaging channel interrupts */
1617 	rval = ioread32(priv->regs + TSI721_OBDMAC_INTE(ch));
1618 	iowrite32(rval | inte_mask, priv->regs + TSI721_OBDMAC_INTE(ch));
1619 
1620 	if (priv->flags & TSI721_USING_MSIX)
1621 		return; /* Finished if we are in MSI-X mode */
1622 
1623 	/*
1624 	 * For MSI and INTA interrupt signalling we need to enable next levels
1625 	 */
1626 
1627 	/* Enable Device Channel Interrupt */
1628 	rval = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
1629 	iowrite32(rval | TSI721_INT_OMSG_CHAN(ch),
1630 		  priv->regs + TSI721_DEV_CHAN_INTE);
1631 }
1632 
1633 /* Disable Outbound Messaging interrupts */
1634 static void
1635 tsi721_omsg_interrupt_disable(struct tsi721_device *priv, int ch,
1636 				   u32 inte_mask)
1637 {
1638 	u32 rval;
1639 
1640 	if (!inte_mask)
1641 		return;
1642 
1643 	/* Clear pending Outbound Messaging interrupts */
1644 	iowrite32(inte_mask, priv->regs + TSI721_OBDMAC_INT(ch));
1645 
1646 	/* Disable Outbound Messaging interrupts */
1647 	rval = ioread32(priv->regs + TSI721_OBDMAC_INTE(ch));
1648 	rval &= ~inte_mask;
1649 	iowrite32(rval, priv->regs + TSI721_OBDMAC_INTE(ch));
1650 
1651 	if (priv->flags & TSI721_USING_MSIX)
1652 		return; /* Finished if we are in MSI-X mode */
1653 
1654 	/*
1655 	 * For MSI and INTA interrupt signalling we need to disable next levels
1656 	 */
1657 
1658 	/* Disable Device Channel Interrupt */
1659 	rval = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
1660 	rval &= ~TSI721_INT_OMSG_CHAN(ch);
1661 	iowrite32(rval, priv->regs + TSI721_DEV_CHAN_INTE);
1662 }
1663 
1664 /**
1665  * tsi721_add_outb_message - Add message to the Tsi721 outbound message queue
1666  * @mport: Master port with outbound message queue
1667  * @rdev: Target of outbound message
1668  * @mbox: Outbound mailbox
1669  * @buffer: Message to add to outbound queue
1670  * @len: Length of message
1671  */
1672 static int
1673 tsi721_add_outb_message(struct rio_mport *mport, struct rio_dev *rdev, int mbox,
1674 			void *buffer, size_t len)
1675 {
1676 	struct tsi721_device *priv = mport->priv;
1677 	struct tsi721_omsg_desc *desc;
1678 	u32 tx_slot;
1679 	unsigned long flags;
1680 
1681 	if (!priv->omsg_init[mbox] ||
1682 	    len > TSI721_MSG_MAX_SIZE || len < 8)
1683 		return -EINVAL;
1684 
1685 	spin_lock_irqsave(&priv->omsg_ring[mbox].lock, flags);
1686 
1687 	tx_slot = priv->omsg_ring[mbox].tx_slot;
1688 
1689 	/* Copy copy message into transfer buffer */
1690 	memcpy(priv->omsg_ring[mbox].omq_base[tx_slot], buffer, len);
1691 
1692 	if (len & 0x7)
1693 		len += 8;
1694 
1695 	/* Build descriptor associated with buffer */
1696 	desc = priv->omsg_ring[mbox].omd_base;
1697 	desc[tx_slot].type_id = cpu_to_le32((DTYPE4 << 29) | rdev->destid);
1698 #ifdef TSI721_OMSG_DESC_INT
1699 	/* Request IOF_DONE interrupt generation for each N-th frame in queue */
1700 	if (tx_slot % 4 == 0)
1701 		desc[tx_slot].type_id |= cpu_to_le32(TSI721_OMD_IOF);
1702 #endif
1703 	desc[tx_slot].msg_info =
1704 		cpu_to_le32((mport->sys_size << 26) | (mbox << 22) |
1705 			    (0xe << 12) | (len & 0xff8));
1706 	desc[tx_slot].bufptr_lo =
1707 		cpu_to_le32((u64)priv->omsg_ring[mbox].omq_phys[tx_slot] &
1708 			    0xffffffff);
1709 	desc[tx_slot].bufptr_hi =
1710 		cpu_to_le32((u64)priv->omsg_ring[mbox].omq_phys[tx_slot] >> 32);
1711 
1712 	priv->omsg_ring[mbox].wr_count++;
1713 
1714 	/* Go to next descriptor */
1715 	if (++priv->omsg_ring[mbox].tx_slot == priv->omsg_ring[mbox].size) {
1716 		priv->omsg_ring[mbox].tx_slot = 0;
1717 		/* Move through the ring link descriptor at the end */
1718 		priv->omsg_ring[mbox].wr_count++;
1719 	}
1720 
1721 	mb();
1722 
1723 	/* Set new write count value */
1724 	iowrite32(priv->omsg_ring[mbox].wr_count,
1725 		priv->regs + TSI721_OBDMAC_DWRCNT(mbox));
1726 	ioread32(priv->regs + TSI721_OBDMAC_DWRCNT(mbox));
1727 
1728 	spin_unlock_irqrestore(&priv->omsg_ring[mbox].lock, flags);
1729 
1730 	return 0;
1731 }
1732 
1733 /**
1734  * tsi721_omsg_handler - Outbound Message Interrupt Handler
1735  * @priv: pointer to tsi721 private data
1736  * @ch:   number of OB MSG channel to service
1737  *
1738  * Services channel interrupts from outbound messaging engine.
1739  */
1740 static void tsi721_omsg_handler(struct tsi721_device *priv, int ch)
1741 {
1742 	u32 omsg_int;
1743 	struct rio_mport *mport = &priv->mport;
1744 	void *dev_id = NULL;
1745 	u32 tx_slot = 0xffffffff;
1746 	int do_callback = 0;
1747 
1748 	spin_lock(&priv->omsg_ring[ch].lock);
1749 
1750 	omsg_int = ioread32(priv->regs + TSI721_OBDMAC_INT(ch));
1751 
1752 	if (omsg_int & TSI721_OBDMAC_INT_ST_FULL)
1753 		tsi_info(&priv->pdev->dev,
1754 			"OB MBOX%d: Status FIFO is full", ch);
1755 
1756 	if (omsg_int & (TSI721_OBDMAC_INT_DONE | TSI721_OBDMAC_INT_IOF_DONE)) {
1757 		u32 srd_ptr;
1758 		u64 *sts_ptr, last_ptr = 0, prev_ptr = 0;
1759 		int i, j;
1760 
1761 		/*
1762 		 * Find last successfully processed descriptor
1763 		 */
1764 
1765 		/* Check and clear descriptor status FIFO entries */
1766 		srd_ptr = priv->omsg_ring[ch].sts_rdptr;
1767 		sts_ptr = priv->omsg_ring[ch].sts_base;
1768 		j = srd_ptr * 8;
1769 		while (sts_ptr[j]) {
1770 			for (i = 0; i < 8 && sts_ptr[j]; i++, j++) {
1771 				prev_ptr = last_ptr;
1772 				last_ptr = le64_to_cpu(sts_ptr[j]);
1773 				sts_ptr[j] = 0;
1774 			}
1775 
1776 			++srd_ptr;
1777 			srd_ptr %= priv->omsg_ring[ch].sts_size;
1778 			j = srd_ptr * 8;
1779 		}
1780 
1781 		if (last_ptr == 0)
1782 			goto no_sts_update;
1783 
1784 		priv->omsg_ring[ch].sts_rdptr = srd_ptr;
1785 		iowrite32(srd_ptr, priv->regs + TSI721_OBDMAC_DSRP(ch));
1786 
1787 		if (!mport->outb_msg[ch].mcback)
1788 			goto no_sts_update;
1789 
1790 		/* Inform upper layer about transfer completion */
1791 
1792 		tx_slot = (last_ptr - (u64)priv->omsg_ring[ch].omd_phys)/
1793 						sizeof(struct tsi721_omsg_desc);
1794 
1795 		/*
1796 		 * Check if this is a Link Descriptor (LD).
1797 		 * If yes, ignore LD and use descriptor processed
1798 		 * before LD.
1799 		 */
1800 		if (tx_slot == priv->omsg_ring[ch].size) {
1801 			if (prev_ptr)
1802 				tx_slot = (prev_ptr -
1803 					(u64)priv->omsg_ring[ch].omd_phys)/
1804 						sizeof(struct tsi721_omsg_desc);
1805 			else
1806 				goto no_sts_update;
1807 		}
1808 
1809 		if (tx_slot >= priv->omsg_ring[ch].size)
1810 			tsi_debug(OMSG, &priv->pdev->dev,
1811 				  "OB_MSG tx_slot=%x > size=%x",
1812 				  tx_slot, priv->omsg_ring[ch].size);
1813 		WARN_ON(tx_slot >= priv->omsg_ring[ch].size);
1814 
1815 		/* Move slot index to the next message to be sent */
1816 		++tx_slot;
1817 		if (tx_slot == priv->omsg_ring[ch].size)
1818 			tx_slot = 0;
1819 
1820 		dev_id = priv->omsg_ring[ch].dev_id;
1821 		do_callback = 1;
1822 	}
1823 
1824 no_sts_update:
1825 
1826 	if (omsg_int & TSI721_OBDMAC_INT_ERROR) {
1827 		/*
1828 		* Outbound message operation aborted due to error,
1829 		* reinitialize OB MSG channel
1830 		*/
1831 
1832 		tsi_debug(OMSG, &priv->pdev->dev, "OB MSG ABORT ch_stat=%x",
1833 			  ioread32(priv->regs + TSI721_OBDMAC_STS(ch)));
1834 
1835 		iowrite32(TSI721_OBDMAC_INT_ERROR,
1836 				priv->regs + TSI721_OBDMAC_INT(ch));
1837 		iowrite32(TSI721_OBDMAC_CTL_RETRY_THR | TSI721_OBDMAC_CTL_INIT,
1838 				priv->regs + TSI721_OBDMAC_CTL(ch));
1839 		ioread32(priv->regs + TSI721_OBDMAC_CTL(ch));
1840 
1841 		/* Inform upper level to clear all pending tx slots */
1842 		dev_id = priv->omsg_ring[ch].dev_id;
1843 		tx_slot = priv->omsg_ring[ch].tx_slot;
1844 		do_callback = 1;
1845 
1846 		/* Synch tx_slot tracking */
1847 		iowrite32(priv->omsg_ring[ch].tx_slot,
1848 			priv->regs + TSI721_OBDMAC_DRDCNT(ch));
1849 		ioread32(priv->regs + TSI721_OBDMAC_DRDCNT(ch));
1850 		priv->omsg_ring[ch].wr_count = priv->omsg_ring[ch].tx_slot;
1851 		priv->omsg_ring[ch].sts_rdptr = 0;
1852 	}
1853 
1854 	/* Clear channel interrupts */
1855 	iowrite32(omsg_int, priv->regs + TSI721_OBDMAC_INT(ch));
1856 
1857 	if (!(priv->flags & TSI721_USING_MSIX)) {
1858 		u32 ch_inte;
1859 
1860 		/* Re-enable channel interrupts */
1861 		ch_inte = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
1862 		ch_inte |= TSI721_INT_OMSG_CHAN(ch);
1863 		iowrite32(ch_inte, priv->regs + TSI721_DEV_CHAN_INTE);
1864 	}
1865 
1866 	spin_unlock(&priv->omsg_ring[ch].lock);
1867 
1868 	if (mport->outb_msg[ch].mcback && do_callback)
1869 		mport->outb_msg[ch].mcback(mport, dev_id, ch, tx_slot);
1870 }
1871 
1872 /**
1873  * tsi721_open_outb_mbox - Initialize Tsi721 outbound mailbox
1874  * @mport: Master port implementing Outbound Messaging Engine
1875  * @dev_id: Device specific pointer to pass on event
1876  * @mbox: Mailbox to open
1877  * @entries: Number of entries in the outbound mailbox ring
1878  */
1879 static int tsi721_open_outb_mbox(struct rio_mport *mport, void *dev_id,
1880 				 int mbox, int entries)
1881 {
1882 	struct tsi721_device *priv = mport->priv;
1883 	struct tsi721_omsg_desc *bd_ptr;
1884 	int i, rc = 0;
1885 
1886 	if ((entries < TSI721_OMSGD_MIN_RING_SIZE) ||
1887 	    (entries > (TSI721_OMSGD_RING_SIZE)) ||
1888 	    (!is_power_of_2(entries)) || mbox >= RIO_MAX_MBOX) {
1889 		rc = -EINVAL;
1890 		goto out;
1891 	}
1892 
1893 	if ((mbox_sel & (1 << mbox)) == 0) {
1894 		rc = -ENODEV;
1895 		goto out;
1896 	}
1897 
1898 	priv->omsg_ring[mbox].dev_id = dev_id;
1899 	priv->omsg_ring[mbox].size = entries;
1900 	priv->omsg_ring[mbox].sts_rdptr = 0;
1901 	spin_lock_init(&priv->omsg_ring[mbox].lock);
1902 
1903 	/* Outbound Msg Buffer allocation based on
1904 	   the number of maximum descriptor entries */
1905 	for (i = 0; i < entries; i++) {
1906 		priv->omsg_ring[mbox].omq_base[i] =
1907 			dma_alloc_coherent(
1908 				&priv->pdev->dev, TSI721_MSG_BUFFER_SIZE,
1909 				&priv->omsg_ring[mbox].omq_phys[i],
1910 				GFP_KERNEL);
1911 		if (priv->omsg_ring[mbox].omq_base[i] == NULL) {
1912 			tsi_debug(OMSG, &priv->pdev->dev,
1913 				  "ENOMEM for OB_MSG_%d data buffer", mbox);
1914 			rc = -ENOMEM;
1915 			goto out_buf;
1916 		}
1917 	}
1918 
1919 	/* Outbound message descriptor allocation */
1920 	priv->omsg_ring[mbox].omd_base = dma_alloc_coherent(
1921 				&priv->pdev->dev,
1922 				(entries + 1) * sizeof(struct tsi721_omsg_desc),
1923 				&priv->omsg_ring[mbox].omd_phys, GFP_KERNEL);
1924 	if (priv->omsg_ring[mbox].omd_base == NULL) {
1925 		tsi_debug(OMSG, &priv->pdev->dev,
1926 			"ENOMEM for OB_MSG_%d descriptor memory", mbox);
1927 		rc = -ENOMEM;
1928 		goto out_buf;
1929 	}
1930 
1931 	priv->omsg_ring[mbox].tx_slot = 0;
1932 
1933 	/* Outbound message descriptor status FIFO allocation */
1934 	priv->omsg_ring[mbox].sts_size = roundup_pow_of_two(entries + 1);
1935 	priv->omsg_ring[mbox].sts_base = dma_zalloc_coherent(&priv->pdev->dev,
1936 			priv->omsg_ring[mbox].sts_size *
1937 						sizeof(struct tsi721_dma_sts),
1938 			&priv->omsg_ring[mbox].sts_phys, GFP_KERNEL);
1939 	if (priv->omsg_ring[mbox].sts_base == NULL) {
1940 		tsi_debug(OMSG, &priv->pdev->dev,
1941 			"ENOMEM for OB_MSG_%d status FIFO", mbox);
1942 		rc = -ENOMEM;
1943 		goto out_desc;
1944 	}
1945 
1946 	/*
1947 	 * Configure Outbound Messaging Engine
1948 	 */
1949 
1950 	/* Setup Outbound Message descriptor pointer */
1951 	iowrite32(((u64)priv->omsg_ring[mbox].omd_phys >> 32),
1952 			priv->regs + TSI721_OBDMAC_DPTRH(mbox));
1953 	iowrite32(((u64)priv->omsg_ring[mbox].omd_phys &
1954 					TSI721_OBDMAC_DPTRL_MASK),
1955 			priv->regs + TSI721_OBDMAC_DPTRL(mbox));
1956 
1957 	/* Setup Outbound Message descriptor status FIFO */
1958 	iowrite32(((u64)priv->omsg_ring[mbox].sts_phys >> 32),
1959 			priv->regs + TSI721_OBDMAC_DSBH(mbox));
1960 	iowrite32(((u64)priv->omsg_ring[mbox].sts_phys &
1961 					TSI721_OBDMAC_DSBL_MASK),
1962 			priv->regs + TSI721_OBDMAC_DSBL(mbox));
1963 	iowrite32(TSI721_DMAC_DSSZ_SIZE(priv->omsg_ring[mbox].sts_size),
1964 		priv->regs + (u32)TSI721_OBDMAC_DSSZ(mbox));
1965 
1966 	/* Enable interrupts */
1967 
1968 #ifdef CONFIG_PCI_MSI
1969 	if (priv->flags & TSI721_USING_MSIX) {
1970 		int idx = TSI721_VECT_OMB0_DONE + mbox;
1971 
1972 		/* Request interrupt service if we are in MSI-X mode */
1973 		rc = request_irq(priv->msix[idx].vector, tsi721_omsg_msix, 0,
1974 				 priv->msix[idx].irq_name, (void *)priv);
1975 
1976 		if (rc) {
1977 			tsi_debug(OMSG, &priv->pdev->dev,
1978 				"Unable to get MSI-X IRQ for OBOX%d-DONE",
1979 				mbox);
1980 			goto out_stat;
1981 		}
1982 
1983 		idx = TSI721_VECT_OMB0_INT + mbox;
1984 		rc = request_irq(priv->msix[idx].vector, tsi721_omsg_msix, 0,
1985 				 priv->msix[idx].irq_name, (void *)priv);
1986 
1987 		if (rc)	{
1988 			tsi_debug(OMSG, &priv->pdev->dev,
1989 				"Unable to get MSI-X IRQ for MBOX%d-INT", mbox);
1990 			idx = TSI721_VECT_OMB0_DONE + mbox;
1991 			free_irq(priv->msix[idx].vector, (void *)priv);
1992 			goto out_stat;
1993 		}
1994 	}
1995 #endif /* CONFIG_PCI_MSI */
1996 
1997 	tsi721_omsg_interrupt_enable(priv, mbox, TSI721_OBDMAC_INT_ALL);
1998 
1999 	/* Initialize Outbound Message descriptors ring */
2000 	bd_ptr = priv->omsg_ring[mbox].omd_base;
2001 	bd_ptr[entries].type_id = cpu_to_le32(DTYPE5 << 29);
2002 	bd_ptr[entries].msg_info = 0;
2003 	bd_ptr[entries].next_lo =
2004 		cpu_to_le32((u64)priv->omsg_ring[mbox].omd_phys &
2005 		TSI721_OBDMAC_DPTRL_MASK);
2006 	bd_ptr[entries].next_hi =
2007 		cpu_to_le32((u64)priv->omsg_ring[mbox].omd_phys >> 32);
2008 	priv->omsg_ring[mbox].wr_count = 0;
2009 	mb();
2010 
2011 	/* Initialize Outbound Message engine */
2012 	iowrite32(TSI721_OBDMAC_CTL_RETRY_THR | TSI721_OBDMAC_CTL_INIT,
2013 		  priv->regs + TSI721_OBDMAC_CTL(mbox));
2014 	ioread32(priv->regs + TSI721_OBDMAC_DWRCNT(mbox));
2015 	udelay(10);
2016 
2017 	priv->omsg_init[mbox] = 1;
2018 
2019 	return 0;
2020 
2021 #ifdef CONFIG_PCI_MSI
2022 out_stat:
2023 	dma_free_coherent(&priv->pdev->dev,
2024 		priv->omsg_ring[mbox].sts_size * sizeof(struct tsi721_dma_sts),
2025 		priv->omsg_ring[mbox].sts_base,
2026 		priv->omsg_ring[mbox].sts_phys);
2027 
2028 	priv->omsg_ring[mbox].sts_base = NULL;
2029 #endif /* CONFIG_PCI_MSI */
2030 
2031 out_desc:
2032 	dma_free_coherent(&priv->pdev->dev,
2033 		(entries + 1) * sizeof(struct tsi721_omsg_desc),
2034 		priv->omsg_ring[mbox].omd_base,
2035 		priv->omsg_ring[mbox].omd_phys);
2036 
2037 	priv->omsg_ring[mbox].omd_base = NULL;
2038 
2039 out_buf:
2040 	for (i = 0; i < priv->omsg_ring[mbox].size; i++) {
2041 		if (priv->omsg_ring[mbox].omq_base[i]) {
2042 			dma_free_coherent(&priv->pdev->dev,
2043 				TSI721_MSG_BUFFER_SIZE,
2044 				priv->omsg_ring[mbox].omq_base[i],
2045 				priv->omsg_ring[mbox].omq_phys[i]);
2046 
2047 			priv->omsg_ring[mbox].omq_base[i] = NULL;
2048 		}
2049 	}
2050 
2051 out:
2052 	return rc;
2053 }
2054 
2055 /**
2056  * tsi721_close_outb_mbox - Close Tsi721 outbound mailbox
2057  * @mport: Master port implementing the outbound message unit
2058  * @mbox: Mailbox to close
2059  */
2060 static void tsi721_close_outb_mbox(struct rio_mport *mport, int mbox)
2061 {
2062 	struct tsi721_device *priv = mport->priv;
2063 	u32 i;
2064 
2065 	if (!priv->omsg_init[mbox])
2066 		return;
2067 	priv->omsg_init[mbox] = 0;
2068 
2069 	/* Disable Interrupts */
2070 
2071 	tsi721_omsg_interrupt_disable(priv, mbox, TSI721_OBDMAC_INT_ALL);
2072 
2073 #ifdef CONFIG_PCI_MSI
2074 	if (priv->flags & TSI721_USING_MSIX) {
2075 		free_irq(priv->msix[TSI721_VECT_OMB0_DONE + mbox].vector,
2076 			 (void *)priv);
2077 		free_irq(priv->msix[TSI721_VECT_OMB0_INT + mbox].vector,
2078 			 (void *)priv);
2079 	}
2080 #endif /* CONFIG_PCI_MSI */
2081 
2082 	/* Free OMSG Descriptor Status FIFO */
2083 	dma_free_coherent(&priv->pdev->dev,
2084 		priv->omsg_ring[mbox].sts_size * sizeof(struct tsi721_dma_sts),
2085 		priv->omsg_ring[mbox].sts_base,
2086 		priv->omsg_ring[mbox].sts_phys);
2087 
2088 	priv->omsg_ring[mbox].sts_base = NULL;
2089 
2090 	/* Free OMSG descriptors */
2091 	dma_free_coherent(&priv->pdev->dev,
2092 		(priv->omsg_ring[mbox].size + 1) *
2093 			sizeof(struct tsi721_omsg_desc),
2094 		priv->omsg_ring[mbox].omd_base,
2095 		priv->omsg_ring[mbox].omd_phys);
2096 
2097 	priv->omsg_ring[mbox].omd_base = NULL;
2098 
2099 	/* Free message buffers */
2100 	for (i = 0; i < priv->omsg_ring[mbox].size; i++) {
2101 		if (priv->omsg_ring[mbox].omq_base[i]) {
2102 			dma_free_coherent(&priv->pdev->dev,
2103 				TSI721_MSG_BUFFER_SIZE,
2104 				priv->omsg_ring[mbox].omq_base[i],
2105 				priv->omsg_ring[mbox].omq_phys[i]);
2106 
2107 			priv->omsg_ring[mbox].omq_base[i] = NULL;
2108 		}
2109 	}
2110 }
2111 
2112 /**
2113  * tsi721_imsg_handler - Inbound Message Interrupt Handler
2114  * @priv: pointer to tsi721 private data
2115  * @ch: inbound message channel number to service
2116  *
2117  * Services channel interrupts from inbound messaging engine.
2118  */
2119 static void tsi721_imsg_handler(struct tsi721_device *priv, int ch)
2120 {
2121 	u32 mbox = ch - 4;
2122 	u32 imsg_int;
2123 	struct rio_mport *mport = &priv->mport;
2124 
2125 	spin_lock(&priv->imsg_ring[mbox].lock);
2126 
2127 	imsg_int = ioread32(priv->regs + TSI721_IBDMAC_INT(ch));
2128 
2129 	if (imsg_int & TSI721_IBDMAC_INT_SRTO)
2130 		tsi_info(&priv->pdev->dev, "IB MBOX%d SRIO timeout", mbox);
2131 
2132 	if (imsg_int & TSI721_IBDMAC_INT_PC_ERROR)
2133 		tsi_info(&priv->pdev->dev, "IB MBOX%d PCIe error", mbox);
2134 
2135 	if (imsg_int & TSI721_IBDMAC_INT_FQ_LOW)
2136 		tsi_info(&priv->pdev->dev, "IB MBOX%d IB free queue low", mbox);
2137 
2138 	/* Clear IB channel interrupts */
2139 	iowrite32(imsg_int, priv->regs + TSI721_IBDMAC_INT(ch));
2140 
2141 	/* If an IB Msg is received notify the upper layer */
2142 	if (imsg_int & TSI721_IBDMAC_INT_DQ_RCV &&
2143 		mport->inb_msg[mbox].mcback)
2144 		mport->inb_msg[mbox].mcback(mport,
2145 				priv->imsg_ring[mbox].dev_id, mbox, -1);
2146 
2147 	if (!(priv->flags & TSI721_USING_MSIX)) {
2148 		u32 ch_inte;
2149 
2150 		/* Re-enable channel interrupts */
2151 		ch_inte = ioread32(priv->regs + TSI721_DEV_CHAN_INTE);
2152 		ch_inte |= TSI721_INT_IMSG_CHAN(ch);
2153 		iowrite32(ch_inte, priv->regs + TSI721_DEV_CHAN_INTE);
2154 	}
2155 
2156 	spin_unlock(&priv->imsg_ring[mbox].lock);
2157 }
2158 
2159 /**
2160  * tsi721_open_inb_mbox - Initialize Tsi721 inbound mailbox
2161  * @mport: Master port implementing the Inbound Messaging Engine
2162  * @dev_id: Device specific pointer to pass on event
2163  * @mbox: Mailbox to open
2164  * @entries: Number of entries in the inbound mailbox ring
2165  */
2166 static int tsi721_open_inb_mbox(struct rio_mport *mport, void *dev_id,
2167 				int mbox, int entries)
2168 {
2169 	struct tsi721_device *priv = mport->priv;
2170 	int ch = mbox + 4;
2171 	int i;
2172 	u64 *free_ptr;
2173 	int rc = 0;
2174 
2175 	if ((entries < TSI721_IMSGD_MIN_RING_SIZE) ||
2176 	    (entries > TSI721_IMSGD_RING_SIZE) ||
2177 	    (!is_power_of_2(entries)) || mbox >= RIO_MAX_MBOX) {
2178 		rc = -EINVAL;
2179 		goto out;
2180 	}
2181 
2182 	if ((mbox_sel & (1 << mbox)) == 0) {
2183 		rc = -ENODEV;
2184 		goto out;
2185 	}
2186 
2187 	/* Initialize IB Messaging Ring */
2188 	priv->imsg_ring[mbox].dev_id = dev_id;
2189 	priv->imsg_ring[mbox].size = entries;
2190 	priv->imsg_ring[mbox].rx_slot = 0;
2191 	priv->imsg_ring[mbox].desc_rdptr = 0;
2192 	priv->imsg_ring[mbox].fq_wrptr = 0;
2193 	for (i = 0; i < priv->imsg_ring[mbox].size; i++)
2194 		priv->imsg_ring[mbox].imq_base[i] = NULL;
2195 	spin_lock_init(&priv->imsg_ring[mbox].lock);
2196 
2197 	/* Allocate buffers for incoming messages */
2198 	priv->imsg_ring[mbox].buf_base =
2199 		dma_alloc_coherent(&priv->pdev->dev,
2200 				   entries * TSI721_MSG_BUFFER_SIZE,
2201 				   &priv->imsg_ring[mbox].buf_phys,
2202 				   GFP_KERNEL);
2203 
2204 	if (priv->imsg_ring[mbox].buf_base == NULL) {
2205 		tsi_err(&priv->pdev->dev,
2206 			"Failed to allocate buffers for IB MBOX%d", mbox);
2207 		rc = -ENOMEM;
2208 		goto out;
2209 	}
2210 
2211 	/* Allocate memory for circular free list */
2212 	priv->imsg_ring[mbox].imfq_base =
2213 		dma_alloc_coherent(&priv->pdev->dev,
2214 				   entries * 8,
2215 				   &priv->imsg_ring[mbox].imfq_phys,
2216 				   GFP_KERNEL);
2217 
2218 	if (priv->imsg_ring[mbox].imfq_base == NULL) {
2219 		tsi_err(&priv->pdev->dev,
2220 			"Failed to allocate free queue for IB MBOX%d", mbox);
2221 		rc = -ENOMEM;
2222 		goto out_buf;
2223 	}
2224 
2225 	/* Allocate memory for Inbound message descriptors */
2226 	priv->imsg_ring[mbox].imd_base =
2227 		dma_alloc_coherent(&priv->pdev->dev,
2228 				   entries * sizeof(struct tsi721_imsg_desc),
2229 				   &priv->imsg_ring[mbox].imd_phys, GFP_KERNEL);
2230 
2231 	if (priv->imsg_ring[mbox].imd_base == NULL) {
2232 		tsi_err(&priv->pdev->dev,
2233 			"Failed to allocate descriptor memory for IB MBOX%d",
2234 			mbox);
2235 		rc = -ENOMEM;
2236 		goto out_dma;
2237 	}
2238 
2239 	/* Fill free buffer pointer list */
2240 	free_ptr = priv->imsg_ring[mbox].imfq_base;
2241 	for (i = 0; i < entries; i++)
2242 		free_ptr[i] = cpu_to_le64(
2243 				(u64)(priv->imsg_ring[mbox].buf_phys) +
2244 				i * 0x1000);
2245 
2246 	mb();
2247 
2248 	/*
2249 	 * For mapping of inbound SRIO Messages into appropriate queues we need
2250 	 * to set Inbound Device ID register in the messaging engine. We do it
2251 	 * once when first inbound mailbox is requested.
2252 	 */
2253 	if (!(priv->flags & TSI721_IMSGID_SET)) {
2254 		iowrite32((u32)priv->mport.host_deviceid,
2255 			priv->regs + TSI721_IB_DEVID);
2256 		priv->flags |= TSI721_IMSGID_SET;
2257 	}
2258 
2259 	/*
2260 	 * Configure Inbound Messaging channel (ch = mbox + 4)
2261 	 */
2262 
2263 	/* Setup Inbound Message free queue */
2264 	iowrite32(((u64)priv->imsg_ring[mbox].imfq_phys >> 32),
2265 		priv->regs + TSI721_IBDMAC_FQBH(ch));
2266 	iowrite32(((u64)priv->imsg_ring[mbox].imfq_phys &
2267 			TSI721_IBDMAC_FQBL_MASK),
2268 		priv->regs+TSI721_IBDMAC_FQBL(ch));
2269 	iowrite32(TSI721_DMAC_DSSZ_SIZE(entries),
2270 		priv->regs + TSI721_IBDMAC_FQSZ(ch));
2271 
2272 	/* Setup Inbound Message descriptor queue */
2273 	iowrite32(((u64)priv->imsg_ring[mbox].imd_phys >> 32),
2274 		priv->regs + TSI721_IBDMAC_DQBH(ch));
2275 	iowrite32(((u32)priv->imsg_ring[mbox].imd_phys &
2276 		   (u32)TSI721_IBDMAC_DQBL_MASK),
2277 		priv->regs+TSI721_IBDMAC_DQBL(ch));
2278 	iowrite32(TSI721_DMAC_DSSZ_SIZE(entries),
2279 		priv->regs + TSI721_IBDMAC_DQSZ(ch));
2280 
2281 	/* Enable interrupts */
2282 
2283 #ifdef CONFIG_PCI_MSI
2284 	if (priv->flags & TSI721_USING_MSIX) {
2285 		int idx = TSI721_VECT_IMB0_RCV + mbox;
2286 
2287 		/* Request interrupt service if we are in MSI-X mode */
2288 		rc = request_irq(priv->msix[idx].vector, tsi721_imsg_msix, 0,
2289 				 priv->msix[idx].irq_name, (void *)priv);
2290 
2291 		if (rc) {
2292 			tsi_debug(IMSG, &priv->pdev->dev,
2293 				"Unable to get MSI-X IRQ for IBOX%d-DONE",
2294 				mbox);
2295 			goto out_desc;
2296 		}
2297 
2298 		idx = TSI721_VECT_IMB0_INT + mbox;
2299 		rc = request_irq(priv->msix[idx].vector, tsi721_imsg_msix, 0,
2300 				 priv->msix[idx].irq_name, (void *)priv);
2301 
2302 		if (rc)	{
2303 			tsi_debug(IMSG, &priv->pdev->dev,
2304 				"Unable to get MSI-X IRQ for IBOX%d-INT", mbox);
2305 			free_irq(
2306 				priv->msix[TSI721_VECT_IMB0_RCV + mbox].vector,
2307 				(void *)priv);
2308 			goto out_desc;
2309 		}
2310 	}
2311 #endif /* CONFIG_PCI_MSI */
2312 
2313 	tsi721_imsg_interrupt_enable(priv, ch, TSI721_IBDMAC_INT_ALL);
2314 
2315 	/* Initialize Inbound Message Engine */
2316 	iowrite32(TSI721_IBDMAC_CTL_INIT, priv->regs + TSI721_IBDMAC_CTL(ch));
2317 	ioread32(priv->regs + TSI721_IBDMAC_CTL(ch));
2318 	udelay(10);
2319 	priv->imsg_ring[mbox].fq_wrptr = entries - 1;
2320 	iowrite32(entries - 1, priv->regs + TSI721_IBDMAC_FQWP(ch));
2321 
2322 	priv->imsg_init[mbox] = 1;
2323 	return 0;
2324 
2325 #ifdef CONFIG_PCI_MSI
2326 out_desc:
2327 	dma_free_coherent(&priv->pdev->dev,
2328 		priv->imsg_ring[mbox].size * sizeof(struct tsi721_imsg_desc),
2329 		priv->imsg_ring[mbox].imd_base,
2330 		priv->imsg_ring[mbox].imd_phys);
2331 
2332 	priv->imsg_ring[mbox].imd_base = NULL;
2333 #endif /* CONFIG_PCI_MSI */
2334 
2335 out_dma:
2336 	dma_free_coherent(&priv->pdev->dev,
2337 		priv->imsg_ring[mbox].size * 8,
2338 		priv->imsg_ring[mbox].imfq_base,
2339 		priv->imsg_ring[mbox].imfq_phys);
2340 
2341 	priv->imsg_ring[mbox].imfq_base = NULL;
2342 
2343 out_buf:
2344 	dma_free_coherent(&priv->pdev->dev,
2345 		priv->imsg_ring[mbox].size * TSI721_MSG_BUFFER_SIZE,
2346 		priv->imsg_ring[mbox].buf_base,
2347 		priv->imsg_ring[mbox].buf_phys);
2348 
2349 	priv->imsg_ring[mbox].buf_base = NULL;
2350 
2351 out:
2352 	return rc;
2353 }
2354 
2355 /**
2356  * tsi721_close_inb_mbox - Shut down Tsi721 inbound mailbox
2357  * @mport: Master port implementing the Inbound Messaging Engine
2358  * @mbox: Mailbox to close
2359  */
2360 static void tsi721_close_inb_mbox(struct rio_mport *mport, int mbox)
2361 {
2362 	struct tsi721_device *priv = mport->priv;
2363 	u32 rx_slot;
2364 	int ch = mbox + 4;
2365 
2366 	if (!priv->imsg_init[mbox]) /* mbox isn't initialized yet */
2367 		return;
2368 	priv->imsg_init[mbox] = 0;
2369 
2370 	/* Disable Inbound Messaging Engine */
2371 
2372 	/* Disable Interrupts */
2373 	tsi721_imsg_interrupt_disable(priv, ch, TSI721_OBDMAC_INT_MASK);
2374 
2375 #ifdef CONFIG_PCI_MSI
2376 	if (priv->flags & TSI721_USING_MSIX) {
2377 		free_irq(priv->msix[TSI721_VECT_IMB0_RCV + mbox].vector,
2378 				(void *)priv);
2379 		free_irq(priv->msix[TSI721_VECT_IMB0_INT + mbox].vector,
2380 				(void *)priv);
2381 	}
2382 #endif /* CONFIG_PCI_MSI */
2383 
2384 	/* Clear Inbound Buffer Queue */
2385 	for (rx_slot = 0; rx_slot < priv->imsg_ring[mbox].size; rx_slot++)
2386 		priv->imsg_ring[mbox].imq_base[rx_slot] = NULL;
2387 
2388 	/* Free memory allocated for message buffers */
2389 	dma_free_coherent(&priv->pdev->dev,
2390 		priv->imsg_ring[mbox].size * TSI721_MSG_BUFFER_SIZE,
2391 		priv->imsg_ring[mbox].buf_base,
2392 		priv->imsg_ring[mbox].buf_phys);
2393 
2394 	priv->imsg_ring[mbox].buf_base = NULL;
2395 
2396 	/* Free memory allocated for free pointr list */
2397 	dma_free_coherent(&priv->pdev->dev,
2398 		priv->imsg_ring[mbox].size * 8,
2399 		priv->imsg_ring[mbox].imfq_base,
2400 		priv->imsg_ring[mbox].imfq_phys);
2401 
2402 	priv->imsg_ring[mbox].imfq_base = NULL;
2403 
2404 	/* Free memory allocated for RX descriptors */
2405 	dma_free_coherent(&priv->pdev->dev,
2406 		priv->imsg_ring[mbox].size * sizeof(struct tsi721_imsg_desc),
2407 		priv->imsg_ring[mbox].imd_base,
2408 		priv->imsg_ring[mbox].imd_phys);
2409 
2410 	priv->imsg_ring[mbox].imd_base = NULL;
2411 }
2412 
2413 /**
2414  * tsi721_add_inb_buffer - Add buffer to the Tsi721 inbound message queue
2415  * @mport: Master port implementing the Inbound Messaging Engine
2416  * @mbox: Inbound mailbox number
2417  * @buf: Buffer to add to inbound queue
2418  */
2419 static int tsi721_add_inb_buffer(struct rio_mport *mport, int mbox, void *buf)
2420 {
2421 	struct tsi721_device *priv = mport->priv;
2422 	u32 rx_slot;
2423 	int rc = 0;
2424 
2425 	rx_slot = priv->imsg_ring[mbox].rx_slot;
2426 	if (priv->imsg_ring[mbox].imq_base[rx_slot]) {
2427 		tsi_err(&priv->pdev->dev,
2428 			"Error adding inbound buffer %d, buffer exists",
2429 			rx_slot);
2430 		rc = -EINVAL;
2431 		goto out;
2432 	}
2433 
2434 	priv->imsg_ring[mbox].imq_base[rx_slot] = buf;
2435 
2436 	if (++priv->imsg_ring[mbox].rx_slot == priv->imsg_ring[mbox].size)
2437 		priv->imsg_ring[mbox].rx_slot = 0;
2438 
2439 out:
2440 	return rc;
2441 }
2442 
2443 /**
2444  * tsi721_get_inb_message - Fetch inbound message from the Tsi721 MSG Queue
2445  * @mport: Master port implementing the Inbound Messaging Engine
2446  * @mbox: Inbound mailbox number
2447  *
2448  * Returns pointer to the message on success or NULL on failure.
2449  */
2450 static void *tsi721_get_inb_message(struct rio_mport *mport, int mbox)
2451 {
2452 	struct tsi721_device *priv = mport->priv;
2453 	struct tsi721_imsg_desc *desc;
2454 	u32 rx_slot;
2455 	void *rx_virt = NULL;
2456 	u64 rx_phys;
2457 	void *buf = NULL;
2458 	u64 *free_ptr;
2459 	int ch = mbox + 4;
2460 	int msg_size;
2461 
2462 	if (!priv->imsg_init[mbox])
2463 		return NULL;
2464 
2465 	desc = priv->imsg_ring[mbox].imd_base;
2466 	desc += priv->imsg_ring[mbox].desc_rdptr;
2467 
2468 	if (!(le32_to_cpu(desc->msg_info) & TSI721_IMD_HO))
2469 		goto out;
2470 
2471 	rx_slot = priv->imsg_ring[mbox].rx_slot;
2472 	while (priv->imsg_ring[mbox].imq_base[rx_slot] == NULL) {
2473 		if (++rx_slot == priv->imsg_ring[mbox].size)
2474 			rx_slot = 0;
2475 	}
2476 
2477 	rx_phys = ((u64)le32_to_cpu(desc->bufptr_hi) << 32) |
2478 			le32_to_cpu(desc->bufptr_lo);
2479 
2480 	rx_virt = priv->imsg_ring[mbox].buf_base +
2481 		  (rx_phys - (u64)priv->imsg_ring[mbox].buf_phys);
2482 
2483 	buf = priv->imsg_ring[mbox].imq_base[rx_slot];
2484 	msg_size = le32_to_cpu(desc->msg_info) & TSI721_IMD_BCOUNT;
2485 	if (msg_size == 0)
2486 		msg_size = RIO_MAX_MSG_SIZE;
2487 
2488 	memcpy(buf, rx_virt, msg_size);
2489 	priv->imsg_ring[mbox].imq_base[rx_slot] = NULL;
2490 
2491 	desc->msg_info &= cpu_to_le32(~TSI721_IMD_HO);
2492 	if (++priv->imsg_ring[mbox].desc_rdptr == priv->imsg_ring[mbox].size)
2493 		priv->imsg_ring[mbox].desc_rdptr = 0;
2494 
2495 	iowrite32(priv->imsg_ring[mbox].desc_rdptr,
2496 		priv->regs + TSI721_IBDMAC_DQRP(ch));
2497 
2498 	/* Return free buffer into the pointer list */
2499 	free_ptr = priv->imsg_ring[mbox].imfq_base;
2500 	free_ptr[priv->imsg_ring[mbox].fq_wrptr] = cpu_to_le64(rx_phys);
2501 
2502 	if (++priv->imsg_ring[mbox].fq_wrptr == priv->imsg_ring[mbox].size)
2503 		priv->imsg_ring[mbox].fq_wrptr = 0;
2504 
2505 	iowrite32(priv->imsg_ring[mbox].fq_wrptr,
2506 		priv->regs + TSI721_IBDMAC_FQWP(ch));
2507 out:
2508 	return buf;
2509 }
2510 
2511 /**
2512  * tsi721_messages_init - Initialization of Messaging Engine
2513  * @priv: pointer to tsi721 private data
2514  *
2515  * Configures Tsi721 messaging engine.
2516  */
2517 static int tsi721_messages_init(struct tsi721_device *priv)
2518 {
2519 	int	ch;
2520 
2521 	iowrite32(0, priv->regs + TSI721_SMSG_ECC_LOG);
2522 	iowrite32(0, priv->regs + TSI721_RETRY_GEN_CNT);
2523 	iowrite32(0, priv->regs + TSI721_RETRY_RX_CNT);
2524 
2525 	/* Set SRIO Message Request/Response Timeout */
2526 	iowrite32(TSI721_RQRPTO_VAL, priv->regs + TSI721_RQRPTO);
2527 
2528 	/* Initialize Inbound Messaging Engine Registers */
2529 	for (ch = 0; ch < TSI721_IMSG_CHNUM; ch++) {
2530 		/* Clear interrupt bits */
2531 		iowrite32(TSI721_IBDMAC_INT_MASK,
2532 			priv->regs + TSI721_IBDMAC_INT(ch));
2533 		/* Clear Status */
2534 		iowrite32(0, priv->regs + TSI721_IBDMAC_STS(ch));
2535 
2536 		iowrite32(TSI721_SMSG_ECC_COR_LOG_MASK,
2537 				priv->regs + TSI721_SMSG_ECC_COR_LOG(ch));
2538 		iowrite32(TSI721_SMSG_ECC_NCOR_MASK,
2539 				priv->regs + TSI721_SMSG_ECC_NCOR(ch));
2540 	}
2541 
2542 	return 0;
2543 }
2544 
2545 /**
2546  * tsi721_query_mport - Fetch inbound message from the Tsi721 MSG Queue
2547  * @mport: Master port implementing the Inbound Messaging Engine
2548  * @mbox: Inbound mailbox number
2549  *
2550  * Returns pointer to the message on success or NULL on failure.
2551  */
2552 static int tsi721_query_mport(struct rio_mport *mport,
2553 			      struct rio_mport_attr *attr)
2554 {
2555 	struct tsi721_device *priv = mport->priv;
2556 	u32 rval;
2557 
2558 	rval = ioread32(priv->regs + 0x100 + RIO_PORT_N_ERR_STS_CSR(0, 0));
2559 	if (rval & RIO_PORT_N_ERR_STS_PORT_OK) {
2560 		rval = ioread32(priv->regs + 0x100 + RIO_PORT_N_CTL2_CSR(0, 0));
2561 		attr->link_speed = (rval & RIO_PORT_N_CTL2_SEL_BAUD) >> 28;
2562 		rval = ioread32(priv->regs + 0x100 + RIO_PORT_N_CTL_CSR(0, 0));
2563 		attr->link_width = (rval & RIO_PORT_N_CTL_IPW) >> 27;
2564 	} else
2565 		attr->link_speed = RIO_LINK_DOWN;
2566 
2567 #ifdef CONFIG_RAPIDIO_DMA_ENGINE
2568 	attr->flags = RIO_MPORT_DMA | RIO_MPORT_DMA_SG;
2569 	attr->dma_max_sge = 0;
2570 	attr->dma_max_size = TSI721_BDMA_MAX_BCOUNT;
2571 	attr->dma_align = 0;
2572 #else
2573 	attr->flags = 0;
2574 #endif
2575 	return 0;
2576 }
2577 
2578 /**
2579  * tsi721_disable_ints - disables all device interrupts
2580  * @priv: pointer to tsi721 private data
2581  */
2582 static void tsi721_disable_ints(struct tsi721_device *priv)
2583 {
2584 	int ch;
2585 
2586 	/* Disable all device level interrupts */
2587 	iowrite32(0, priv->regs + TSI721_DEV_INTE);
2588 
2589 	/* Disable all Device Channel interrupts */
2590 	iowrite32(0, priv->regs + TSI721_DEV_CHAN_INTE);
2591 
2592 	/* Disable all Inbound Msg Channel interrupts */
2593 	for (ch = 0; ch < TSI721_IMSG_CHNUM; ch++)
2594 		iowrite32(0, priv->regs + TSI721_IBDMAC_INTE(ch));
2595 
2596 	/* Disable all Outbound Msg Channel interrupts */
2597 	for (ch = 0; ch < TSI721_OMSG_CHNUM; ch++)
2598 		iowrite32(0, priv->regs + TSI721_OBDMAC_INTE(ch));
2599 
2600 	/* Disable all general messaging interrupts */
2601 	iowrite32(0, priv->regs + TSI721_SMSG_INTE);
2602 
2603 	/* Disable all BDMA Channel interrupts */
2604 	for (ch = 0; ch < TSI721_DMA_MAXCH; ch++)
2605 		iowrite32(0,
2606 			priv->regs + TSI721_DMAC_BASE(ch) + TSI721_DMAC_INTE);
2607 
2608 	/* Disable all general BDMA interrupts */
2609 	iowrite32(0, priv->regs + TSI721_BDMA_INTE);
2610 
2611 	/* Disable all SRIO Channel interrupts */
2612 	for (ch = 0; ch < TSI721_SRIO_MAXCH; ch++)
2613 		iowrite32(0, priv->regs + TSI721_SR_CHINTE(ch));
2614 
2615 	/* Disable all general SR2PC interrupts */
2616 	iowrite32(0, priv->regs + TSI721_SR2PC_GEN_INTE);
2617 
2618 	/* Disable all PC2SR interrupts */
2619 	iowrite32(0, priv->regs + TSI721_PC2SR_INTE);
2620 
2621 	/* Disable all I2C interrupts */
2622 	iowrite32(0, priv->regs + TSI721_I2C_INT_ENABLE);
2623 
2624 	/* Disable SRIO MAC interrupts */
2625 	iowrite32(0, priv->regs + TSI721_RIO_EM_INT_ENABLE);
2626 	iowrite32(0, priv->regs + TSI721_RIO_EM_DEV_INT_EN);
2627 }
2628 
2629 static struct rio_ops tsi721_rio_ops = {
2630 	.lcread			= tsi721_lcread,
2631 	.lcwrite		= tsi721_lcwrite,
2632 	.cread			= tsi721_cread_dma,
2633 	.cwrite			= tsi721_cwrite_dma,
2634 	.dsend			= tsi721_dsend,
2635 	.open_inb_mbox		= tsi721_open_inb_mbox,
2636 	.close_inb_mbox		= tsi721_close_inb_mbox,
2637 	.open_outb_mbox		= tsi721_open_outb_mbox,
2638 	.close_outb_mbox	= tsi721_close_outb_mbox,
2639 	.add_outb_message	= tsi721_add_outb_message,
2640 	.add_inb_buffer		= tsi721_add_inb_buffer,
2641 	.get_inb_message	= tsi721_get_inb_message,
2642 	.map_inb		= tsi721_rio_map_inb_mem,
2643 	.unmap_inb		= tsi721_rio_unmap_inb_mem,
2644 	.pwenable		= tsi721_pw_enable,
2645 	.query_mport		= tsi721_query_mport,
2646 	.map_outb		= tsi721_map_outb_win,
2647 	.unmap_outb		= tsi721_unmap_outb_win,
2648 };
2649 
2650 static void tsi721_mport_release(struct device *dev)
2651 {
2652 	struct rio_mport *mport = to_rio_mport(dev);
2653 
2654 	tsi_debug(EXIT, dev, "%s id=%d", mport->name, mport->id);
2655 }
2656 
2657 /**
2658  * tsi721_setup_mport - Setup Tsi721 as RapidIO subsystem master port
2659  * @priv: pointer to tsi721 private data
2660  *
2661  * Configures Tsi721 as RapidIO master port.
2662  */
2663 static int tsi721_setup_mport(struct tsi721_device *priv)
2664 {
2665 	struct pci_dev *pdev = priv->pdev;
2666 	int err = 0;
2667 	struct rio_mport *mport = &priv->mport;
2668 
2669 	err = rio_mport_initialize(mport);
2670 	if (err)
2671 		return err;
2672 
2673 	mport->ops = &tsi721_rio_ops;
2674 	mport->index = 0;
2675 	mport->sys_size = 0; /* small system */
2676 	mport->priv = (void *)priv;
2677 	mport->phys_efptr = 0x100;
2678 	mport->phys_rmap = 1;
2679 	mport->dev.parent = &pdev->dev;
2680 	mport->dev.release = tsi721_mport_release;
2681 
2682 	INIT_LIST_HEAD(&mport->dbells);
2683 
2684 	rio_init_dbell_res(&mport->riores[RIO_DOORBELL_RESOURCE], 0, 0xffff);
2685 	rio_init_mbox_res(&mport->riores[RIO_INB_MBOX_RESOURCE], 0, 3);
2686 	rio_init_mbox_res(&mport->riores[RIO_OUTB_MBOX_RESOURCE], 0, 3);
2687 	snprintf(mport->name, RIO_MAX_MPORT_NAME, "%s(%s)",
2688 		 dev_driver_string(&pdev->dev), dev_name(&pdev->dev));
2689 
2690 	/* Hook up interrupt handler */
2691 
2692 #ifdef CONFIG_PCI_MSI
2693 	if (!tsi721_enable_msix(priv))
2694 		priv->flags |= TSI721_USING_MSIX;
2695 	else if (!pci_enable_msi(pdev))
2696 		priv->flags |= TSI721_USING_MSI;
2697 	else
2698 		tsi_debug(MPORT, &pdev->dev,
2699 			 "MSI/MSI-X is not available. Using legacy INTx.");
2700 #endif /* CONFIG_PCI_MSI */
2701 
2702 	err = tsi721_request_irq(priv);
2703 
2704 	if (err) {
2705 		tsi_err(&pdev->dev, "Unable to get PCI IRQ %02X (err=0x%x)",
2706 			pdev->irq, err);
2707 		return err;
2708 	}
2709 
2710 #ifdef CONFIG_RAPIDIO_DMA_ENGINE
2711 	err = tsi721_register_dma(priv);
2712 	if (err)
2713 		goto err_exit;
2714 #endif
2715 	/* Enable SRIO link */
2716 	iowrite32(ioread32(priv->regs + TSI721_DEVCTL) |
2717 		  TSI721_DEVCTL_SRBOOT_CMPL,
2718 		  priv->regs + TSI721_DEVCTL);
2719 
2720 	if (mport->host_deviceid >= 0)
2721 		iowrite32(RIO_PORT_GEN_HOST | RIO_PORT_GEN_MASTER |
2722 			  RIO_PORT_GEN_DISCOVERED,
2723 			  priv->regs + (0x100 + RIO_PORT_GEN_CTL_CSR));
2724 	else
2725 		iowrite32(0, priv->regs + (0x100 + RIO_PORT_GEN_CTL_CSR));
2726 
2727 	err = rio_register_mport(mport);
2728 	if (err) {
2729 		tsi721_unregister_dma(priv);
2730 		goto err_exit;
2731 	}
2732 
2733 	return 0;
2734 
2735 err_exit:
2736 	tsi721_free_irq(priv);
2737 	return err;
2738 }
2739 
2740 static int tsi721_probe(struct pci_dev *pdev,
2741 				  const struct pci_device_id *id)
2742 {
2743 	struct tsi721_device *priv;
2744 	int err;
2745 
2746 	priv = kzalloc(sizeof(struct tsi721_device), GFP_KERNEL);
2747 	if (!priv) {
2748 		err = -ENOMEM;
2749 		goto err_exit;
2750 	}
2751 
2752 	err = pci_enable_device(pdev);
2753 	if (err) {
2754 		tsi_err(&pdev->dev, "Failed to enable PCI device");
2755 		goto err_clean;
2756 	}
2757 
2758 	priv->pdev = pdev;
2759 
2760 #ifdef DEBUG
2761 	{
2762 		int i;
2763 
2764 		for (i = 0; i <= PCI_STD_RESOURCE_END; i++) {
2765 			tsi_debug(INIT, &pdev->dev, "res%d %pR",
2766 				  i, &pdev->resource[i]);
2767 		}
2768 	}
2769 #endif
2770 	/*
2771 	 * Verify BAR configuration
2772 	 */
2773 
2774 	/* BAR_0 (registers) must be 512KB+ in 32-bit address space */
2775 	if (!(pci_resource_flags(pdev, BAR_0) & IORESOURCE_MEM) ||
2776 	    pci_resource_flags(pdev, BAR_0) & IORESOURCE_MEM_64 ||
2777 	    pci_resource_len(pdev, BAR_0) < TSI721_REG_SPACE_SIZE) {
2778 		tsi_err(&pdev->dev, "Missing or misconfigured CSR BAR0");
2779 		err = -ENODEV;
2780 		goto err_disable_pdev;
2781 	}
2782 
2783 	/* BAR_1 (outbound doorbells) must be 16MB+ in 32-bit address space */
2784 	if (!(pci_resource_flags(pdev, BAR_1) & IORESOURCE_MEM) ||
2785 	    pci_resource_flags(pdev, BAR_1) & IORESOURCE_MEM_64 ||
2786 	    pci_resource_len(pdev, BAR_1) < TSI721_DB_WIN_SIZE) {
2787 		tsi_err(&pdev->dev, "Missing or misconfigured Doorbell BAR1");
2788 		err = -ENODEV;
2789 		goto err_disable_pdev;
2790 	}
2791 
2792 	/*
2793 	 * BAR_2 and BAR_4 (outbound translation) must be in 64-bit PCIe address
2794 	 * space.
2795 	 * NOTE: BAR_2 and BAR_4 are not used by this version of driver.
2796 	 * It may be a good idea to keep them disabled using HW configuration
2797 	 * to save PCI memory space.
2798 	 */
2799 
2800 	priv->p2r_bar[0].size = priv->p2r_bar[1].size = 0;
2801 
2802 	if (pci_resource_flags(pdev, BAR_2) & IORESOURCE_MEM_64) {
2803 		if (pci_resource_flags(pdev, BAR_2) & IORESOURCE_PREFETCH)
2804 			tsi_debug(INIT, &pdev->dev,
2805 				 "Prefetchable OBW BAR2 will not be used");
2806 		else {
2807 			priv->p2r_bar[0].base = pci_resource_start(pdev, BAR_2);
2808 			priv->p2r_bar[0].size = pci_resource_len(pdev, BAR_2);
2809 		}
2810 	}
2811 
2812 	if (pci_resource_flags(pdev, BAR_4) & IORESOURCE_MEM_64) {
2813 		if (pci_resource_flags(pdev, BAR_4) & IORESOURCE_PREFETCH)
2814 			tsi_debug(INIT, &pdev->dev,
2815 				 "Prefetchable OBW BAR4 will not be used");
2816 		else {
2817 			priv->p2r_bar[1].base = pci_resource_start(pdev, BAR_4);
2818 			priv->p2r_bar[1].size = pci_resource_len(pdev, BAR_4);
2819 		}
2820 	}
2821 
2822 	err = pci_request_regions(pdev, DRV_NAME);
2823 	if (err) {
2824 		tsi_err(&pdev->dev, "Unable to obtain PCI resources");
2825 		goto err_disable_pdev;
2826 	}
2827 
2828 	pci_set_master(pdev);
2829 
2830 	priv->regs = pci_ioremap_bar(pdev, BAR_0);
2831 	if (!priv->regs) {
2832 		tsi_err(&pdev->dev, "Unable to map device registers space");
2833 		err = -ENOMEM;
2834 		goto err_free_res;
2835 	}
2836 
2837 	priv->odb_base = pci_ioremap_bar(pdev, BAR_1);
2838 	if (!priv->odb_base) {
2839 		tsi_err(&pdev->dev, "Unable to map outbound doorbells space");
2840 		err = -ENOMEM;
2841 		goto err_unmap_bars;
2842 	}
2843 
2844 	/* Configure DMA attributes. */
2845 	if (pci_set_dma_mask(pdev, DMA_BIT_MASK(64))) {
2846 		err = pci_set_dma_mask(pdev, DMA_BIT_MASK(32));
2847 		if (err) {
2848 			tsi_err(&pdev->dev, "Unable to set DMA mask");
2849 			goto err_unmap_bars;
2850 		}
2851 
2852 		if (pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(32)))
2853 			tsi_info(&pdev->dev, "Unable to set consistent DMA mask");
2854 	} else {
2855 		err = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(64));
2856 		if (err)
2857 			tsi_info(&pdev->dev, "Unable to set consistent DMA mask");
2858 	}
2859 
2860 	BUG_ON(!pci_is_pcie(pdev));
2861 
2862 	/* Clear "no snoop" and "relaxed ordering" bits. */
2863 	pcie_capability_clear_and_set_word(pdev, PCI_EXP_DEVCTL,
2864 		PCI_EXP_DEVCTL_RELAX_EN | PCI_EXP_DEVCTL_NOSNOOP_EN, 0);
2865 
2866 	/* Override PCIe Maximum Read Request Size setting if requested */
2867 	if (pcie_mrrs >= 0) {
2868 		if (pcie_mrrs <= 5)
2869 			pcie_capability_clear_and_set_word(pdev, PCI_EXP_DEVCTL,
2870 					PCI_EXP_DEVCTL_READRQ, pcie_mrrs << 12);
2871 		else
2872 			tsi_info(&pdev->dev,
2873 				 "Invalid MRRS override value %d", pcie_mrrs);
2874 	}
2875 
2876 	/* Adjust PCIe completion timeout. */
2877 	pcie_capability_clear_and_set_word(pdev, PCI_EXP_DEVCTL2, 0xf, 0x2);
2878 
2879 	/*
2880 	 * FIXUP: correct offsets of MSI-X tables in the MSI-X Capability Block
2881 	 */
2882 	pci_write_config_dword(pdev, TSI721_PCIECFG_EPCTL, 0x01);
2883 	pci_write_config_dword(pdev, TSI721_PCIECFG_MSIXTBL,
2884 						TSI721_MSIXTBL_OFFSET);
2885 	pci_write_config_dword(pdev, TSI721_PCIECFG_MSIXPBA,
2886 						TSI721_MSIXPBA_OFFSET);
2887 	pci_write_config_dword(pdev, TSI721_PCIECFG_EPCTL, 0);
2888 	/* End of FIXUP */
2889 
2890 	tsi721_disable_ints(priv);
2891 
2892 	tsi721_init_pc2sr_mapping(priv);
2893 	tsi721_init_sr2pc_mapping(priv);
2894 
2895 	if (tsi721_bdma_maint_init(priv)) {
2896 		tsi_err(&pdev->dev, "BDMA initialization failed");
2897 		err = -ENOMEM;
2898 		goto err_unmap_bars;
2899 	}
2900 
2901 	err = tsi721_doorbell_init(priv);
2902 	if (err)
2903 		goto err_free_bdma;
2904 
2905 	tsi721_port_write_init(priv);
2906 
2907 	err = tsi721_messages_init(priv);
2908 	if (err)
2909 		goto err_free_consistent;
2910 
2911 	err = tsi721_setup_mport(priv);
2912 	if (err)
2913 		goto err_free_consistent;
2914 
2915 	pci_set_drvdata(pdev, priv);
2916 	tsi721_interrupts_init(priv);
2917 
2918 	return 0;
2919 
2920 err_free_consistent:
2921 	tsi721_port_write_free(priv);
2922 	tsi721_doorbell_free(priv);
2923 err_free_bdma:
2924 	tsi721_bdma_maint_free(priv);
2925 err_unmap_bars:
2926 	if (priv->regs)
2927 		iounmap(priv->regs);
2928 	if (priv->odb_base)
2929 		iounmap(priv->odb_base);
2930 err_free_res:
2931 	pci_release_regions(pdev);
2932 	pci_clear_master(pdev);
2933 err_disable_pdev:
2934 	pci_disable_device(pdev);
2935 err_clean:
2936 	kfree(priv);
2937 err_exit:
2938 	return err;
2939 }
2940 
2941 static void tsi721_remove(struct pci_dev *pdev)
2942 {
2943 	struct tsi721_device *priv = pci_get_drvdata(pdev);
2944 
2945 	tsi_debug(EXIT, &pdev->dev, "enter");
2946 
2947 	tsi721_disable_ints(priv);
2948 	tsi721_free_irq(priv);
2949 	flush_scheduled_work();
2950 	rio_unregister_mport(&priv->mport);
2951 
2952 	tsi721_unregister_dma(priv);
2953 	tsi721_bdma_maint_free(priv);
2954 	tsi721_doorbell_free(priv);
2955 	tsi721_port_write_free(priv);
2956 	tsi721_close_sr2pc_mapping(priv);
2957 
2958 	if (priv->regs)
2959 		iounmap(priv->regs);
2960 	if (priv->odb_base)
2961 		iounmap(priv->odb_base);
2962 #ifdef CONFIG_PCI_MSI
2963 	if (priv->flags & TSI721_USING_MSIX)
2964 		pci_disable_msix(priv->pdev);
2965 	else if (priv->flags & TSI721_USING_MSI)
2966 		pci_disable_msi(priv->pdev);
2967 #endif
2968 	pci_release_regions(pdev);
2969 	pci_clear_master(pdev);
2970 	pci_disable_device(pdev);
2971 	pci_set_drvdata(pdev, NULL);
2972 	kfree(priv);
2973 	tsi_debug(EXIT, &pdev->dev, "exit");
2974 }
2975 
2976 static void tsi721_shutdown(struct pci_dev *pdev)
2977 {
2978 	struct tsi721_device *priv = pci_get_drvdata(pdev);
2979 
2980 	tsi_debug(EXIT, &pdev->dev, "enter");
2981 
2982 	tsi721_disable_ints(priv);
2983 	tsi721_dma_stop_all(priv);
2984 	pci_clear_master(pdev);
2985 	pci_disable_device(pdev);
2986 }
2987 
2988 static const struct pci_device_id tsi721_pci_tbl[] = {
2989 	{ PCI_DEVICE(PCI_VENDOR_ID_IDT, PCI_DEVICE_ID_TSI721) },
2990 	{ 0, }	/* terminate list */
2991 };
2992 
2993 MODULE_DEVICE_TABLE(pci, tsi721_pci_tbl);
2994 
2995 static struct pci_driver tsi721_driver = {
2996 	.name		= "tsi721",
2997 	.id_table	= tsi721_pci_tbl,
2998 	.probe		= tsi721_probe,
2999 	.remove		= tsi721_remove,
3000 	.shutdown	= tsi721_shutdown,
3001 };
3002 
3003 module_pci_driver(tsi721_driver);
3004 
3005 MODULE_DESCRIPTION("IDT Tsi721 PCIExpress-to-SRIO bridge driver");
3006 MODULE_AUTHOR("Integrated Device Technology, Inc.");
3007 MODULE_LICENSE("GPL");
3008