diff options
author | Thomas Moll <thomas.moll@sysgo.com> | 2010-05-26 17:44:01 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-05-27 12:12:51 -0400 |
commit | 933af4a6c4913ab4c0691c8fb27fc305063889cd (patch) | |
tree | 5bc7b63482131f184e006ef0d3346aac79d300cb /drivers/rapidio/rio-scan.c | |
parent | a52c8f521fed43bce53451d7dfddf2b42a2af689 (diff) |
rapidio: add enabling SRIO port RX and TX
Add the functionality to enable Input receiver and Output transmitter of
every port, to allow non-maintenance traffic.
Signed-off-by: Thomas Moll <thomas.moll@sysgo.com>
Signed-off-by: Alexandre Bounine <abounine@tundra.com>
Cc: Matt Porter <mporter@kernel.crashing.org>
Cc: Li Yang <leoli@freescale.com>
Cc: Kumar Gala <galak@kernel.crashing.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/rapidio/rio-scan.c')
-rw-r--r-- | drivers/rapidio/rio-scan.c | 79 |
1 files changed, 78 insertions, 1 deletions
diff --git a/drivers/rapidio/rio-scan.c b/drivers/rapidio/rio-scan.c index 74633cc6b2eb..1faa1a5756e2 100644 --- a/drivers/rapidio/rio-scan.c +++ b/drivers/rapidio/rio-scan.c | |||
@@ -8,6 +8,10 @@ | |||
8 | * Alex Bounine <alexandre.bounine@idt.com> | 8 | * Alex Bounine <alexandre.bounine@idt.com> |
9 | * - Added Port-Write/Error Management initialization and handling | 9 | * - Added Port-Write/Error Management initialization and handling |
10 | * | 10 | * |
11 | * Copyright 2009 Sysgo AG | ||
12 | * Thomas Moll <thomas.moll@sysgo.com> | ||
13 | * - Added Input- Output- enable functionality, to allow full communication | ||
14 | * | ||
11 | * This program is free software; you can redistribute it and/or modify it | 15 | * This program is free software; you can redistribute it and/or modify it |
12 | * under the terms of the GNU General Public License as published by the | 16 | * under the terms of the GNU General Public License as published by the |
13 | * Free Software Foundation; either version 2 of the License, or (at your | 17 | * Free Software Foundation; either version 2 of the License, or (at your |
@@ -328,6 +332,65 @@ static int __devinit rio_add_device(struct rio_dev *rdev) | |||
328 | } | 332 | } |
329 | 333 | ||
330 | /** | 334 | /** |
335 | * rio_enable_rx_tx_port - enable input reciever and output transmitter of | ||
336 | * given port | ||
337 | * @port: Master port associated with the RIO network | ||
338 | * @local: local=1 select local port otherwise a far device is reached | ||
339 | * @destid: Destination ID of the device to check host bit | ||
340 | * @hopcount: Number of hops to reach the target | ||
341 | * @port_num: Port (-number on switch) to enable on a far end device | ||
342 | * | ||
343 | * Returns 0 or 1 from on General Control Command and Status Register | ||
344 | * (EXT_PTR+0x3C) | ||
345 | */ | ||
346 | inline int rio_enable_rx_tx_port(struct rio_mport *port, | ||
347 | int local, u16 destid, | ||
348 | u8 hopcount, u8 port_num) { | ||
349 | #ifdef CONFIG_RAPIDIO_ENABLE_RX_TX_PORTS | ||
350 | u32 regval; | ||
351 | u32 ext_ftr_ptr; | ||
352 | |||
353 | /* | ||
354 | * enable rx input tx output port | ||
355 | */ | ||
356 | pr_debug("rio_enable_rx_tx_port(local = %d, destid = %d, hopcount = " | ||
357 | "%d, port_num = %d)\n", local, destid, hopcount, port_num); | ||
358 | |||
359 | ext_ftr_ptr = rio_mport_get_physefb(port, local, destid, hopcount); | ||
360 | |||
361 | if (local) { | ||
362 | rio_local_read_config_32(port, ext_ftr_ptr + | ||
363 | RIO_PORT_N_CTL_CSR(0), | ||
364 | ®val); | ||
365 | } else { | ||
366 | if (rio_mport_read_config_32(port, destid, hopcount, | ||
367 | ext_ftr_ptr + RIO_PORT_N_CTL_CSR(port_num), ®val) < 0) | ||
368 | return -EIO; | ||
369 | } | ||
370 | |||
371 | if (regval & RIO_PORT_N_CTL_P_TYP_SER) { | ||
372 | /* serial */ | ||
373 | regval = regval | RIO_PORT_N_CTL_EN_RX_SER | ||
374 | | RIO_PORT_N_CTL_EN_TX_SER; | ||
375 | } else { | ||
376 | /* parallel */ | ||
377 | regval = regval | RIO_PORT_N_CTL_EN_RX_PAR | ||
378 | | RIO_PORT_N_CTL_EN_TX_PAR; | ||
379 | } | ||
380 | |||
381 | if (local) { | ||
382 | rio_local_write_config_32(port, ext_ftr_ptr + | ||
383 | RIO_PORT_N_CTL_CSR(0), regval); | ||
384 | } else { | ||
385 | if (rio_mport_write_config_32(port, destid, hopcount, | ||
386 | ext_ftr_ptr + RIO_PORT_N_CTL_CSR(port_num), regval) < 0) | ||
387 | return -EIO; | ||
388 | } | ||
389 | #endif | ||
390 | return 0; | ||
391 | } | ||
392 | |||
393 | /** | ||
331 | * rio_setup_device- Allocates and sets up a RIO device | 394 | * rio_setup_device- Allocates and sets up a RIO device |
332 | * @net: RIO network | 395 | * @net: RIO network |
333 | * @port: Master port to send transactions | 396 | * @port: Master port to send transactions |
@@ -430,9 +493,14 @@ static struct rio_dev __devinit *rio_setup_device(struct rio_net *net, | |||
430 | 493 | ||
431 | list_add_tail(&rswitch->node, &rio_switches); | 494 | list_add_tail(&rswitch->node, &rio_switches); |
432 | 495 | ||
433 | } else | 496 | } else { |
497 | if (do_enum) | ||
498 | /*Enable Input Output Port (transmitter reviever)*/ | ||
499 | rio_enable_rx_tx_port(port, 0, destid, hopcount, 0); | ||
500 | |||
434 | dev_set_name(&rdev->dev, "%02x:e:%04x", rdev->net->id, | 501 | dev_set_name(&rdev->dev, "%02x:e:%04x", rdev->net->id, |
435 | rdev->destid); | 502 | rdev->destid); |
503 | } | ||
436 | 504 | ||
437 | rdev->dev.bus = &rio_bus_type; | 505 | rdev->dev.bus = &rio_bus_type; |
438 | 506 | ||
@@ -812,6 +880,11 @@ static int __devinit rio_enum_peer(struct rio_net *net, struct rio_mport *port, | |||
812 | rio_name(rdev), rdev->vid, rdev->did, num_ports); | 880 | rio_name(rdev), rdev->vid, rdev->did, num_ports); |
813 | sw_destid = next_destid; | 881 | sw_destid = next_destid; |
814 | for (port_num = 0; port_num < num_ports; port_num++) { | 882 | for (port_num = 0; port_num < num_ports; port_num++) { |
883 | /*Enable Input Output Port (transmitter reviever)*/ | ||
884 | rio_enable_rx_tx_port(port, 0, | ||
885 | RIO_ANY_DESTID(port->sys_size), | ||
886 | hopcount, port_num); | ||
887 | |||
815 | if (sw_inport == port_num) { | 888 | if (sw_inport == port_num) { |
816 | rdev->rswitch->port_ok |= (1 << port_num); | 889 | rdev->rswitch->port_ok |= (1 << port_num); |
817 | continue; | 890 | continue; |
@@ -1132,6 +1205,10 @@ int __devinit rio_enum_mport(struct rio_mport *mport) | |||
1132 | rc = -ENOMEM; | 1205 | rc = -ENOMEM; |
1133 | goto out; | 1206 | goto out; |
1134 | } | 1207 | } |
1208 | |||
1209 | /* Enable Input Output Port (transmitter reviever) */ | ||
1210 | rio_enable_rx_tx_port(mport, 1, 0, 0, 0); | ||
1211 | |||
1135 | if (rio_enum_peer(net, mport, 0) < 0) { | 1212 | if (rio_enum_peer(net, mport, 0) < 0) { |
1136 | /* A higher priority host won enumeration, bail. */ | 1213 | /* A higher priority host won enumeration, bail. */ |
1137 | printk(KERN_INFO | 1214 | printk(KERN_INFO |