From 22279507427d39cd137b3e2c864038134b0a87b0 Mon Sep 17 00:00:00 2001 From: Max Khon Date: Thu, 29 Nov 2007 04:06:19 +0000 Subject: Fix connect() for kernels without COMPAT_43. Approved by: portmgr (linimon) --- .../oracle8-client/files/patch-freebsd-oci8stub.c | 39 ++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 databases/oracle8-client/files/patch-freebsd-oci8stub.c (limited to 'databases/oracle8-client/files/patch-freebsd-oci8stub.c') diff --git a/databases/oracle8-client/files/patch-freebsd-oci8stub.c b/databases/oracle8-client/files/patch-freebsd-oci8stub.c new file mode 100644 index 000000000000..0ab25e92e0d3 --- /dev/null +++ b/databases/oracle8-client/files/patch-freebsd-oci8stub.c @@ -0,0 +1,39 @@ +--- freebsd/oci8stub.c.orig 2007-11-11 12:25:01.000000000 +0600 ++++ freebsd/oci8stub.c 2007-11-28 05:03:13.000000000 +0600 +@@ -2,6 +2,7 @@ + #include + #include + #include ++#include + #include + #include + #include +@@ -119,6 +120,13 @@ + + int __l_sigprocmask(int how, const sigset_t *set, sigset_t *oldset); + ++struct l_sockaddr { ++ u_int16_t sa_family; ++ char sa_data[14]; ++}; ++ ++int __l_connect(int s, const struct l_sockaddr *l_sa, socklen_t addrlen); ++ + #ifdef stdin + #undef stdin + #undef stdout +@@ -528,3 +536,14 @@ + + return sigprocmask(how, set, oldset); + } ++ ++int ++__l_connect(int s, const struct l_sockaddr *l_sa, socklen_t addrlen) ++{ ++ struct sockaddr sa; ++ ++ memcpy(sa.sa_data, l_sa->sa_data, sizeof(sa.sa_data)); ++ sa.sa_len = addrlen; ++ sa.sa_family = l_sa->sa_family; ++ return connect(s, &sa, addrlen); ++} -- cgit v1.2.3