[PATCH 0/21] Reliable Datagram Sockets (RDS)

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Andy Grover
Date: Monday, January 26, 2009 - 7:17 pm

Hi Roland,

This patchset adds support for RDS as an Infiniband ULP. RDS is an
Oracle-originated protocol used to send IPC datagrams (up to 1MB) reliably,
and is used currently in Oracle RAC and Exadata products. It's lived
in OFED for 2+ years and I think it's time to get it upstream -- most
likely into your -next tree for .30, but if it snuck into .29 via the
"new code merge-window exception" then even better.

I've run checkpatch & sparse to clean up as many issues as possible so
what remains are really the design peculiarities (aka warts) that arise
from being a protocol designed by one company for a single critical
application. I think upstreaming this code is the first step towards
working out those issues, and making the end result available to a wider
audience.

Also available for review at:
git://git.openfabrics.org/~agrover/ofed_1_4/linux-2.6 for-roland

Thoughts? shortlog follows.

Thanks -- Regards -- Andy

Andy Grover (21):
      RDS: Socket interface
      RDS: Main header file
      RDS: Congestion-handling code
      RDS: Transport code
      RDS: Info and stats
      RDS: Connection handling
      RDS: loopback
      RDS: sysctls
      RDS: Message parsing
      RDS: send.c
      RDS: recv.c
      RDS: RDMA support
      RDS/IB: Infiniband transport
      RDS/IB: Ring-handling code.
      RDS/IB: Implement RDMA ops using FMRs
      RDS/IB: Implement IB-specific datagram send.
      RDS/IB: Receive datagrams via IB
      RDS/IB: Stats and sysctls
      RDS: Documentation
      RDS: Kconfig and Makefile
      RDS: Add AF and PF #defines for RDS sockets

 Documentation/networking/rds.txt        |  356 +++++++++++
 drivers/infiniband/Kconfig              |    2 +
 drivers/infiniband/Makefile             |    1 +
 drivers/infiniband/ulp/rds/Kconfig      |   13 +
 drivers/infiniband/ulp/rds/Makefile     |   13 +
 drivers/infiniband/ulp/rds/af_rds.c     |  677 +++++++++++++++++++++
 drivers/infiniband/ulp/rds/bind.c       |  202 +++++++
 drivers/infiniband/ulp/rds/cong.c       |  424 +++++++++++++
 drivers/infiniband/ulp/rds/connection.c |  501 +++++++++++++++
 drivers/infiniband/ulp/rds/ib.c         |  312 ++++++++++
 drivers/infiniband/ulp/rds/ib.h         |  358 +++++++++++
 drivers/infiniband/ulp/rds/ib_cm.c      |  882
+++++++++++++++++++++++++++
 drivers/infiniband/ulp/rds/ib_rdma.c    |  641 ++++++++++++++++++++
 drivers/infiniband/ulp/rds/ib_recv.c    |  894
+++++++++++++++++++++++++++
 drivers/infiniband/ulp/rds/ib_ring.c    |  168 +++++
 drivers/infiniband/ulp/rds/ib_send.c    |  852
++++++++++++++++++++++++++
 drivers/infiniband/ulp/rds/ib_stats.c   |   95 +++
 drivers/infiniband/ulp/rds/ib_sysctl.c  |  137 +++++
 drivers/infiniband/ulp/rds/info.c       |  243 ++++++++
 drivers/infiniband/ulp/rds/info.h       |   43 ++
 drivers/infiniband/ulp/rds/loop.c       |  189 ++++++
 drivers/infiniband/ulp/rds/loop.h       |    9 +
 drivers/infiniband/ulp/rds/message.c    |  414 +++++++++++++
 drivers/infiniband/ulp/rds/page.c       |  222 +++++++
 drivers/infiniband/ulp/rds/rdma.c       |  682 +++++++++++++++++++++
 drivers/infiniband/ulp/rds/rdma.h       |   84 +++
 drivers/infiniband/ulp/rds/rds.h        |  763 +++++++++++++++++++++++
 drivers/infiniband/ulp/rds/rds_rdma.h   |  245 ++++++++
 drivers/infiniband/ulp/rds/recv.c       |  550 +++++++++++++++++
 drivers/infiniband/ulp/rds/send.c       | 1006
+++++++++++++++++++++++++++++++
 drivers/infiniband/ulp/rds/stats.c      |  150 +++++
 drivers/infiniband/ulp/rds/sysctl.c     |  164 +++++
 drivers/infiniband/ulp/rds/threads.c    |  273 +++++++++
 drivers/infiniband/ulp/rds/transport.c  |  134 ++++
 include/linux/socket.h                  |    4 +-
 35 files changed, 11702 insertions(+), 1 deletions(-)
 create mode 100644 Documentation/networking/rds.txt
 create mode 100644 drivers/infiniband/ulp/rds/Kconfig
 create mode 100644 drivers/infiniband/ulp/rds/Makefile
 create mode 100644 drivers/infiniband/ulp/rds/af_rds.c
 create mode 100644 drivers/infiniband/ulp/rds/bind.c
 create mode 100644 drivers/infiniband/ulp/rds/cong.c
 create mode 100644 drivers/infiniband/ulp/rds/connection.c
 create mode 100644 drivers/infiniband/ulp/rds/ib.c
 create mode 100644 drivers/infiniband/ulp/rds/ib.h
 create mode 100644 drivers/infiniband/ulp/rds/ib_cm.c
 create mode 100644 drivers/infiniband/ulp/rds/ib_rdma.c
 create mode 100644 drivers/infiniband/ulp/rds/ib_recv.c
 create mode 100644 drivers/infiniband/ulp/rds/ib_ring.c
 create mode 100644 drivers/infiniband/ulp/rds/ib_send.c
 create mode 100644 drivers/infiniband/ulp/rds/ib_stats.c
 create mode 100644 drivers/infiniband/ulp/rds/ib_sysctl.c
 create mode 100644 drivers/infiniband/ulp/rds/info.c
 create mode 100644 drivers/infiniband/ulp/rds/info.h
 create mode 100644 drivers/infiniband/ulp/rds/loop.c
 create mode 100644 drivers/infiniband/ulp/rds/loop.h
 create mode 100644 drivers/infiniband/ulp/rds/message.c
 create mode 100644 drivers/infiniband/ulp/rds/page.c
 create mode 100644 drivers/infiniband/ulp/rds/rdma.c
 create mode 100644 drivers/infiniband/ulp/rds/rdma.h
 create mode 100644 drivers/infiniband/ulp/rds/rds.h
 create mode 100644 drivers/infiniband/ulp/rds/rds_rdma.h
 create mode 100644 drivers/infiniband/ulp/rds/recv.c
 create mode 100644 drivers/infiniband/ulp/rds/send.c
 create mode 100644 drivers/infiniband/ulp/rds/stats.c
 create mode 100644 drivers/infiniband/ulp/rds/sysctl.c
 create mode 100644 drivers/infiniband/ulp/rds/threads.c
 create mode 100644 drivers/infiniband/ulp/rds/transport.c

end

--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH 0/21] Reliable Datagram Sockets (RDS), Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 01/21] RDS: Socket interface, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 02/21] RDS: Main header file, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 03/21] RDS: Congestion-handling code, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 04/21] RDS: Transport code, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 05/21] RDS: Info and stats, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 06/21] RDS: Connection handling, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 07/21] RDS: loopback, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 08/21] RDS: sysctls, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 09/21] RDS: Message parsing, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 10/21] RDS: send.c, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 11/21] RDS: recv.c, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 12/21] RDS: RDMA support, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 13/21] RDS/IB: Infiniband transport, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 14/21] RDS/IB: Ring-handling code., Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 15/21] RDS/IB: Implement RDMA ops using FMRs, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 17/21] RDS/IB: Receive datagrams via IB, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 18/21] RDS/IB: Stats and sysctls, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 19/21] RDS: Documentation, Andy Grover, (Mon Jan 26, 7:17 pm)
[PATCH 20/21] RDS: Kconfig and Makefile, Andy Grover, (Mon Jan 26, 7:17 pm)
Re: [PATCH 01/21] RDS: Socket interface, Stephen Hemminger, (Mon Jan 26, 8:46 pm)
Re: [PATCH 03/21] RDS: Congestion-handling code, Stephen Hemminger, (Mon Jan 26, 8:48 pm)
Re: [PATCH 01/21] RDS: Socket interface, David Miller, (Mon Jan 26, 9:11 pm)
Re: [PATCH 02/21] RDS: Main header file, Rémi, (Tue Jan 27, 12:34 am)
Re: [PATCH 01/21] RDS: Socket interface, Evgeniy Polyakov, (Tue Jan 27, 5:08 am)
Re: [PATCH 02/21] RDS: Main header file, Evgeniy Polyakov, (Tue Jan 27, 6:05 am)
Re: [PATCH 03/21] RDS: Congestion-handling code, Evgeniy Polyakov, (Tue Jan 27, 6:10 am)
Re: [PATCH 04/21] RDS: Transport code, Evgeniy Polyakov, (Tue Jan 27, 6:18 am)
Re: [PATCH 05/21] RDS: Info and stats, Evgeniy Polyakov, (Tue Jan 27, 6:28 am)
Re: [PATCH 06/21] RDS: Connection handling, Evgeniy Polyakov, (Tue Jan 27, 6:34 am)
Re: [PATCH 06/21] RDS: Connection handling, Oliver Neukum, (Tue Jan 27, 6:47 am)
Re: [PATCH 06/21] RDS: Connection handling, Evgeniy Polyakov, (Tue Jan 27, 6:51 am)
Re: [PATCH 03/21] RDS: Congestion-handling code, Andrew Grover, (Tue Jan 27, 12:10 pm)
Re: [PATCH 03/21] RDS: Congestion-handling code, Andrew Grover, (Tue Jan 27, 12:15 pm)
Re: [PATCH 02/21] RDS: Main header file, Andrew Grover, (Tue Jan 27, 12:23 pm)
Re: [PATCH 02/21] RDS: Main header file, Andrew Grover, (Tue Jan 27, 12:27 pm)
Re: [PATCH 04/21] RDS: Transport code, Andrew Grover, (Tue Jan 27, 12:36 pm)
Re: [PATCH 04/21] RDS: Transport code, Evgeniy Polyakov, (Tue Jan 27, 2:56 pm)
Re: [PATCH 04/21] RDS: Transport code, Andrew Grover, (Tue Jan 27, 3:15 pm)
Re: [PATCH 0/21] Reliable Datagram Sockets (RDS), Roland Dreier, (Wed Jan 28, 3:37 pm)
Re: [PATCH 03/21] RDS: Congestion-handling code, Roland Dreier, (Wed Jan 28, 3:57 pm)
Re: [PATCH 20/21] RDS: Kconfig and Makefile, Roland Dreier, (Wed Jan 28, 3:59 pm)
Re: [PATCH 17/21] RDS/IB: Receive datagrams via IB, Roland Dreier, (Wed Jan 28, 5:05 pm)
Re: [PATCH 0/21] Reliable Datagram Sockets (RDS), Andy Grover, (Wed Jan 28, 6:29 pm)
Re: [PATCH 20/21] RDS: Kconfig and Makefile, Andy Grover, (Wed Jan 28, 7:19 pm)
Re: [PATCH 17/21] RDS/IB: Receive datagrams via IB, Andy Grover, (Wed Jan 28, 7:20 pm)
Re: [PATCH 03/21] RDS: Congestion-handling code, Andy Grover, (Wed Jan 28, 7:39 pm)
Re: [PATCH 01/21] RDS: Socket interface, Andrew Grover, (Wed Jan 28, 8:17 pm)
Re: [PATCH 01/21] RDS: Socket interface, Andrew Grover, (Wed Jan 28, 9:02 pm)
Re: [PATCH 20/21] RDS: Kconfig and Makefile, Roland Dreier, (Wed Jan 28, 10:14 pm)
Re: [ofa-general] Re: [PATCH 06/21] RDS: Connection handling, Evgeniy Polyakov, (Thu Jan 29, 1:03 am)
Re: [PATCH 01/21] RDS: Socket interface, Evgeniy Polyakov, (Thu Jan 29, 9:24 am)
Re: [PATCH 01/21] RDS: Socket interface, Andrew Grover, (Thu Jan 29, 1:22 pm)
Re: [PATCH 17/21] RDS/IB: Receive datagrams via IB, Olaf Kirch, (Thu Jan 29, 2:02 pm)
Re: [PATCH 17/21] RDS/IB: Receive datagrams via IB, Roland Dreier, (Thu Jan 29, 2:47 pm)