[ofa-general] [PATCH 0/21] Reliable Datagram Sockets (RDS)
Andy Grover
andy.grover at oracle.com
Mon Jan 26 18:17:37 PST 2009
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
More information about the general
mailing list