mirror of
https://github.com/flatcar/scripts.git
synced 2025-08-20 05:51:18 +02:00
net-libs/libtirpc: Sync with the latest stable from Gentoo
This commit is contained in:
parent
fd39bb9875
commit
11d0f414b9
@ -1,2 +1,2 @@
|
|||||||
DIST libtirpc-1.0.1.tar.bz2 495125 SHA256 5156974f31be7ccbc8ab1de37c4739af6d9d42c87b1d5caf4835dda75fcbb89e SHA512 c9b449e737bc2bd3d56e31e8352f312e89a7ec2a11b73b5ac314e7d82d3b644c611e422b623912453b67b668f86a6de7bb7f18c9495dd15de8e2798ec2ff41c8 WHIRLPOOL cce6a4e69bd634b40d66594a81c23d2044b63eec16d6c96d6fcfaa7f2ca41fb9af99c8e2b964ec12be82682afa4090b218d7e14399fdfc9b32df6c2234bc3c9e
|
DIST libtirpc-1.0.2.tar.bz2 509601 BLAKE2B 7ccf23ca200e2027a66a3105d9b3d0612ac66a08498931f66526a291be6ddef8e7df533af4d44a0e4a1178edd6d51ae39ca50c2536b9b1be7179e7f17cfd165e SHA512 6c819019a8e81d8263d3c509b2eee59ba1ef092222c5a0a8d28f004c711afa252097eca7e6b0b919b2d780883dfd9ee7a363df4cee7fd2c9159a065257637cec
|
||||||
DIST libtirpc-glibc-nfs.tar.xz 8948 SHA256 2677cfedf626f3f5a8f6e507aed5bb8f79a7453b589d684dbbc086e755170d83 SHA512 90255bf0a27af16164e0710dd940778609925d473f4343093ff19d98cc4f23023788bf4edf0178eae1961afc0ba8b69b273de95b7d7e2afdb706701d8ba6f7ba WHIRLPOOL 06bcf3fd4e424a86071e5c4ddeb89aa571c862e765aae9382d9f9a55ab72cd1c623490555c1a9bd3380a2d04ecb10fb47a75a7dddf449d4368a1a01617226858
|
DIST libtirpc-glibc-nfs.tar.xz 8948 BLAKE2B 7316623d9f2b6928e296137fe2bf6794b208d549c2ffba9e4a35b47f7b04bf023798a09f38c02d039debf6adc466d7689cf3c8274d71a22eaff08729642c0a28 SHA512 90255bf0a27af16164e0710dd940778609925d473f4343093ff19d98cc4f23023788bf4edf0178eae1961afc0ba8b69b273de95b7d7e2afdb706701d8ba6f7ba
|
||||||
|
@ -1,255 +0,0 @@
|
|||||||
diff --git a/src/rpc_generic.c b/src/rpc_generic.c
|
|
||||||
index 2f09a8f..589cbd5 100644
|
|
||||||
--- a/src/rpc_generic.c
|
|
||||||
+++ b/src/rpc_generic.c
|
|
||||||
@@ -615,6 +615,9 @@ __rpc_taddr2uaddr_af(int af, const struct netbuf *nbuf)
|
|
||||||
|
|
||||||
switch (af) {
|
|
||||||
case AF_INET:
|
|
||||||
+ if (nbuf->len < sizeof(*sin)) {
|
|
||||||
+ return NULL;
|
|
||||||
+ }
|
|
||||||
sin = nbuf->buf;
|
|
||||||
if (inet_ntop(af, &sin->sin_addr, namebuf, sizeof namebuf)
|
|
||||||
== NULL)
|
|
||||||
@@ -626,6 +629,9 @@ __rpc_taddr2uaddr_af(int af, const struct netbuf *nbuf)
|
|
||||||
break;
|
|
||||||
#ifdef INET6
|
|
||||||
case AF_INET6:
|
|
||||||
+ if (nbuf->len < sizeof(*sin6)) {
|
|
||||||
+ return NULL;
|
|
||||||
+ }
|
|
||||||
sin6 = nbuf->buf;
|
|
||||||
if (inet_ntop(af, &sin6->sin6_addr, namebuf6, sizeof namebuf6)
|
|
||||||
== NULL)
|
|
||||||
@@ -667,6 +673,8 @@ __rpc_uaddr2taddr_af(int af, const char *uaddr)
|
|
||||||
|
|
||||||
port = 0;
|
|
||||||
sin = NULL;
|
|
||||||
+ if (uaddr == NULL)
|
|
||||||
+ return NULL;
|
|
||||||
addrstr = strdup(uaddr);
|
|
||||||
if (addrstr == NULL)
|
|
||||||
return NULL;
|
|
||||||
diff --git a/src/rpcb_prot.c b/src/rpcb_prot.c
|
|
||||||
index 43fd385..a923c8e 100644
|
|
||||||
--- a/src/rpcb_prot.c
|
|
||||||
+++ b/src/rpcb_prot.c
|
|
||||||
@@ -41,6 +41,7 @@
|
|
||||||
#include <rpc/types.h>
|
|
||||||
#include <rpc/xdr.h>
|
|
||||||
#include <rpc/rpcb_prot.h>
|
|
||||||
+#include "rpc_com.h"
|
|
||||||
|
|
||||||
bool_t
|
|
||||||
xdr_rpcb(xdrs, objp)
|
|
||||||
@@ -53,13 +54,13 @@ xdr_rpcb(xdrs, objp)
|
|
||||||
if (!xdr_u_int32_t(xdrs, &objp->r_vers)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->r_netid, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->r_netid, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->r_addr, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->r_addr, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->r_owner, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->r_owner, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
return (TRUE);
|
|
||||||
@@ -159,19 +160,19 @@ xdr_rpcb_entry(xdrs, objp)
|
|
||||||
XDR *xdrs;
|
|
||||||
rpcb_entry *objp;
|
|
||||||
{
|
|
||||||
- if (!xdr_string(xdrs, &objp->r_maddr, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->r_maddr, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->r_nc_netid, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->r_nc_netid, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
if (!xdr_u_int32_t(xdrs, &objp->r_nc_semantics)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->r_nc_protofmly, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->r_nc_protofmly, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->r_nc_proto, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->r_nc_proto, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
return (TRUE);
|
|
||||||
@@ -292,7 +293,7 @@ xdr_rpcb_rmtcallres(xdrs, p)
|
|
||||||
bool_t dummy;
|
|
||||||
struct r_rpcb_rmtcallres *objp = (struct r_rpcb_rmtcallres *)(void *)p;
|
|
||||||
|
|
||||||
- if (!xdr_string(xdrs, &objp->addr, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->addr, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
if (!xdr_u_int(xdrs, &objp->results.results_len)) {
|
|
||||||
@@ -312,6 +313,11 @@ xdr_netbuf(xdrs, objp)
|
|
||||||
if (!xdr_u_int32_t(xdrs, (u_int32_t *) &objp->maxlen)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ if (objp->maxlen > RPC_MAXDATASIZE) {
|
|
||||||
+ return (FALSE);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
dummy = xdr_bytes(xdrs, (char **)&(objp->buf),
|
|
||||||
(u_int *)&(objp->len), objp->maxlen);
|
|
||||||
return (dummy);
|
|
||||||
diff --git a/src/rpcb_st_xdr.c b/src/rpcb_st_xdr.c
|
|
||||||
index 08db745..28e6a48 100644
|
|
||||||
--- a/src/rpcb_st_xdr.c
|
|
||||||
+++ b/src/rpcb_st_xdr.c
|
|
||||||
@@ -37,6 +37,7 @@
|
|
||||||
|
|
||||||
|
|
||||||
#include <rpc/rpc.h>
|
|
||||||
+#include "rpc_com.h"
|
|
||||||
|
|
||||||
/* Link list of all the stats about getport and getaddr */
|
|
||||||
|
|
||||||
@@ -58,7 +59,7 @@ xdr_rpcbs_addrlist(xdrs, objp)
|
|
||||||
if (!xdr_int(xdrs, &objp->failure)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->netid, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->netid, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -109,7 +110,7 @@ xdr_rpcbs_rmtcalllist(xdrs, objp)
|
|
||||||
IXDR_PUT_INT32(buf, objp->failure);
|
|
||||||
IXDR_PUT_INT32(buf, objp->indirect);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->netid, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->netid, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
if (!xdr_pointer(xdrs, (char **)&objp->next,
|
|
||||||
@@ -147,7 +148,7 @@ xdr_rpcbs_rmtcalllist(xdrs, objp)
|
|
||||||
objp->failure = (int)IXDR_GET_INT32(buf);
|
|
||||||
objp->indirect = (int)IXDR_GET_INT32(buf);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->netid, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->netid, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
if (!xdr_pointer(xdrs, (char **)&objp->next,
|
|
||||||
@@ -175,7 +176,7 @@ xdr_rpcbs_rmtcalllist(xdrs, objp)
|
|
||||||
if (!xdr_int(xdrs, &objp->indirect)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
- if (!xdr_string(xdrs, &objp->netid, (u_int)~0)) {
|
|
||||||
+ if (!xdr_string(xdrs, &objp->netid, RPC_MAXDATASIZE)) {
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
if (!xdr_pointer(xdrs, (char **)&objp->next,
|
|
||||||
diff --git a/src/xdr.c b/src/xdr.c
|
|
||||||
index f3fb9ad..b9a1558 100644
|
|
||||||
--- a/src/xdr.c
|
|
||||||
+++ b/src/xdr.c
|
|
||||||
@@ -42,8 +42,10 @@
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
+#include <rpc/rpc.h>
|
|
||||||
#include <rpc/types.h>
|
|
||||||
#include <rpc/xdr.h>
|
|
||||||
+#include <rpc/rpc_com.h>
|
|
||||||
|
|
||||||
typedef quad_t longlong_t; /* ANSI long long type */
|
|
||||||
typedef u_quad_t u_longlong_t; /* ANSI unsigned long long type */
|
|
||||||
@@ -53,7 +55,6 @@ typedef u_quad_t u_longlong_t; /* ANSI unsigned long long type */
|
|
||||||
*/
|
|
||||||
#define XDR_FALSE ((long) 0)
|
|
||||||
#define XDR_TRUE ((long) 1)
|
|
||||||
-#define LASTUNSIGNED ((u_int) 0-1)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* for unit alignment
|
|
||||||
@@ -629,6 +630,7 @@ xdr_bytes(xdrs, cpp, sizep, maxsize)
|
|
||||||
{
|
|
||||||
char *sp = *cpp; /* sp is the actual string pointer */
|
|
||||||
u_int nodesize;
|
|
||||||
+ bool_t ret, allocated = FALSE;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* first deal with the length since xdr bytes are counted
|
|
||||||
@@ -652,6 +654,7 @@ xdr_bytes(xdrs, cpp, sizep, maxsize)
|
|
||||||
}
|
|
||||||
if (sp == NULL) {
|
|
||||||
*cpp = sp = mem_alloc(nodesize);
|
|
||||||
+ allocated = TRUE;
|
|
||||||
}
|
|
||||||
if (sp == NULL) {
|
|
||||||
warnx("xdr_bytes: out of memory");
|
|
||||||
@@ -660,7 +663,14 @@ xdr_bytes(xdrs, cpp, sizep, maxsize)
|
|
||||||
/* FALLTHROUGH */
|
|
||||||
|
|
||||||
case XDR_ENCODE:
|
|
||||||
- return (xdr_opaque(xdrs, sp, nodesize));
|
|
||||||
+ ret = xdr_opaque(xdrs, sp, nodesize);
|
|
||||||
+ if ((xdrs->x_op == XDR_DECODE) && (ret == FALSE)) {
|
|
||||||
+ if (allocated == TRUE) {
|
|
||||||
+ free(sp);
|
|
||||||
+ *cpp = NULL;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ return (ret);
|
|
||||||
|
|
||||||
case XDR_FREE:
|
|
||||||
if (sp != NULL) {
|
|
||||||
@@ -754,6 +764,7 @@ xdr_string(xdrs, cpp, maxsize)
|
|
||||||
char *sp = *cpp; /* sp is the actual string pointer */
|
|
||||||
u_int size;
|
|
||||||
u_int nodesize;
|
|
||||||
+ bool_t ret, allocated = FALSE;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* first deal with the length since xdr strings are counted-strings
|
|
||||||
@@ -793,8 +804,10 @@ xdr_string(xdrs, cpp, maxsize)
|
|
||||||
switch (xdrs->x_op) {
|
|
||||||
|
|
||||||
case XDR_DECODE:
|
|
||||||
- if (sp == NULL)
|
|
||||||
+ if (sp == NULL) {
|
|
||||||
*cpp = sp = mem_alloc(nodesize);
|
|
||||||
+ allocated = TRUE;
|
|
||||||
+ }
|
|
||||||
if (sp == NULL) {
|
|
||||||
warnx("xdr_string: out of memory");
|
|
||||||
return (FALSE);
|
|
||||||
@@ -803,7 +816,14 @@ xdr_string(xdrs, cpp, maxsize)
|
|
||||||
/* FALLTHROUGH */
|
|
||||||
|
|
||||||
case XDR_ENCODE:
|
|
||||||
- return (xdr_opaque(xdrs, sp, size));
|
|
||||||
+ ret = xdr_opaque(xdrs, sp, size);
|
|
||||||
+ if ((xdrs->x_op == XDR_DECODE) && (ret == FALSE)) {
|
|
||||||
+ if (allocated == TRUE) {
|
|
||||||
+ free(sp);
|
|
||||||
+ *cpp = NULL;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ return (ret);
|
|
||||||
|
|
||||||
case XDR_FREE:
|
|
||||||
mem_free(sp, nodesize);
|
|
||||||
@@ -823,7 +843,7 @@ xdr_wrapstring(xdrs, cpp)
|
|
||||||
XDR *xdrs;
|
|
||||||
char **cpp;
|
|
||||||
{
|
|
||||||
- return xdr_string(xdrs, cpp, LASTUNSIGNED);
|
|
||||||
+ return xdr_string(xdrs, cpp, RPC_MAXDATASIZE);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
@ -0,0 +1,49 @@
|
|||||||
|
diff -Naurp libtirpc-1.0.2.orig/src/auth_time.c libtirpc-1.0.2/src/auth_time.c
|
||||||
|
--- libtirpc-1.0.2.orig/src/auth_time.c 2017-07-05 11:02:23.000000000 -0400
|
||||||
|
+++ libtirpc-1.0.2/src/auth_time.c 2017-07-30 17:48:31.361420071 -0400
|
||||||
|
@@ -104,7 +104,7 @@ static int uaddr_to_sockaddr(uaddr, sin)
|
||||||
|
p_bytes[1] = (unsigned char)a[5] & 0x000000FF;
|
||||||
|
|
||||||
|
sin->sin_family = AF_INET; /* always */
|
||||||
|
- bcopy((char *)&p_bytes, (char *)&sin->sin_port, 2);
|
||||||
|
+ memmove((char *)&sin->sin_port, (char *)&p_bytes, 2);
|
||||||
|
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
|
diff -Naurp libtirpc-1.0.2.orig/src/crypt_client.c libtirpc-1.0.2/src/crypt_client.c
|
||||||
|
--- libtirpc-1.0.2.orig/src/crypt_client.c 2017-07-05 11:02:23.000000000 -0400
|
||||||
|
+++ libtirpc-1.0.2/src/crypt_client.c 2017-07-30 17:49:57.911419445 -0400
|
||||||
|
@@ -75,8 +75,8 @@ _des_crypt_call(buf, len, dparms)
|
||||||
|
des_crypt_1_arg.desbuf.desbuf_val = buf;
|
||||||
|
des_crypt_1_arg.des_dir = dparms->des_dir;
|
||||||
|
des_crypt_1_arg.des_mode = dparms->des_mode;
|
||||||
|
- bcopy(dparms->des_ivec, des_crypt_1_arg.des_ivec, 8);
|
||||||
|
- bcopy(dparms->des_key, des_crypt_1_arg.des_key, 8);
|
||||||
|
+ memmove(des_crypt_1_arg.des_ivec, dparms->des_ivec, 8);
|
||||||
|
+ memmove(des_crypt_1_arg.des_key, dparms->des_key, 8);
|
||||||
|
|
||||||
|
result_1 = des_crypt_1(&des_crypt_1_arg, clnt);
|
||||||
|
if (result_1 == (desresp *) NULL) {
|
||||||
|
@@ -88,8 +88,8 @@ _des_crypt_call(buf, len, dparms)
|
||||||
|
|
||||||
|
if (result_1->stat == DESERR_NONE ||
|
||||||
|
result_1->stat == DESERR_NOHWDEVICE) {
|
||||||
|
- bcopy(result_1->desbuf.desbuf_val, buf, len);
|
||||||
|
- bcopy(result_1->des_ivec, dparms->des_ivec, 8);
|
||||||
|
+ memmove(buf, result_1->desbuf.desbuf_val, len);
|
||||||
|
+ memmove(dparms->des_ivec, result_1->des_ivec, 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
clnt_freeres(clnt, (xdrproc_t)xdr_desresp, result_1);
|
||||||
|
diff -Naurp libtirpc-1.0.2.orig/src/svc_auth_des.c libtirpc-1.0.2/src/svc_auth_des.c
|
||||||
|
--- libtirpc-1.0.2.orig/src/svc_auth_des.c 2017-07-05 11:02:23.000000000 -0400
|
||||||
|
+++ libtirpc-1.0.2/src/svc_auth_des.c 2017-07-30 17:50:36.591419165 -0400
|
||||||
|
@@ -145,7 +145,7 @@ _svcauth_des(rqst, msg)
|
||||||
|
return (AUTH_BADCRED);
|
||||||
|
}
|
||||||
|
cred->adc_fullname.name = area->area_netname;
|
||||||
|
- bcopy((char *)ixdr, cred->adc_fullname.name,
|
||||||
|
+ memmove(cred->adc_fullname.name, (char *)ixdr,
|
||||||
|
(u_int)namelen);
|
||||||
|
cred->adc_fullname.name[namelen] = 0;
|
||||||
|
ixdr += (RNDUP(namelen) / BYTES_PER_XDR_UNIT);
|
@ -0,0 +1,36 @@
|
|||||||
|
diff -Naurp libtirpc-1.0.2.orig/src/auth_time.c libtirpc-1.0.2/src/auth_time.c
|
||||||
|
--- libtirpc-1.0.2.orig/src/auth_time.c 2017-07-05 11:02:23.000000000 -0400
|
||||||
|
+++ libtirpc-1.0.2/src/auth_time.c 2017-07-30 17:46:39.481420880 -0400
|
||||||
|
@@ -317,7 +317,7 @@ __rpc_get_time_offset(td, srv, thost, ua
|
||||||
|
sprintf(ipuaddr, "%d.%d.%d.%d.0.111", a1, a2, a3, a4);
|
||||||
|
useua = &ipuaddr[0];
|
||||||
|
|
||||||
|
- bzero((char *)&sin, sizeof(sin));
|
||||||
|
+ memset((char *)&sin, 0, sizeof(sin));
|
||||||
|
if (uaddr_to_sockaddr(useua, &sin)) {
|
||||||
|
msg("unable to translate uaddr to sockaddr.");
|
||||||
|
if (needfree)
|
||||||
|
diff -Naurp libtirpc-1.0.2.orig/src/des_impl.c libtirpc-1.0.2/src/des_impl.c
|
||||||
|
--- libtirpc-1.0.2.orig/src/des_impl.c 2017-07-05 11:02:23.000000000 -0400
|
||||||
|
+++ libtirpc-1.0.2/src/des_impl.c 2017-07-30 17:46:49.581420807 -0400
|
||||||
|
@@ -588,7 +588,7 @@ _des_crypt (char *buf, unsigned len, str
|
||||||
|
}
|
||||||
|
tin0 = tin1 = tout0 = tout1 = xor0 = xor1 = 0;
|
||||||
|
tbuf[0] = tbuf[1] = 0;
|
||||||
|
- __bzero (schedule, sizeof (schedule));
|
||||||
|
+ memset (schedule, 0, sizeof (schedule));
|
||||||
|
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
diff -Naurp libtirpc-1.0.2.orig/src/svc_auth_des.c libtirpc-1.0.2/src/svc_auth_des.c
|
||||||
|
--- libtirpc-1.0.2.orig/src/svc_auth_des.c 2017-07-05 11:02:23.000000000 -0400
|
||||||
|
+++ libtirpc-1.0.2/src/svc_auth_des.c 2017-07-30 17:46:58.771420741 -0400
|
||||||
|
@@ -356,7 +356,7 @@ cache_init()
|
||||||
|
|
||||||
|
authdes_cache = (struct cache_entry *)
|
||||||
|
mem_alloc(sizeof(struct cache_entry) * AUTHDES_CACHESZ);
|
||||||
|
- bzero((char *)authdes_cache,
|
||||||
|
+ memset((char *)authdes_cache, 0,
|
||||||
|
sizeof(struct cache_entry) * AUTHDES_CACHESZ);
|
||||||
|
|
||||||
|
authdes_lru = (short *)mem_alloc(sizeof(short) * AUTHDES_CACHESZ);
|
@ -0,0 +1,17 @@
|
|||||||
|
See
|
||||||
|
https://bugs.alpinelinux.org/issues/7041
|
||||||
|
https://git.alpinelinux.org/cgit/aports/commit/?id=9edb53cea056101c4963a04b747bf102de23f919
|
||||||
|
(just hit this myself when building libnsl)
|
||||||
|
... dilfridge
|
||||||
|
|
||||||
|
--- a/src/libtirpc.map
|
||||||
|
+++ b/src/libtirpc.map
|
||||||
|
@@ -298,7 +298,7 @@
|
||||||
|
key_gendes;
|
||||||
|
key_get_conv;
|
||||||
|
key_setsecret;
|
||||||
|
- key_secret_is_set;
|
||||||
|
+ key_secretkey_is_set;
|
||||||
|
key_setnet;
|
||||||
|
netname2host;
|
||||||
|
netname2user;
|
@ -0,0 +1,12 @@
|
|||||||
|
diff --git a/src/xdr_sizeof.c b/src/xdr_sizeof.c
|
||||||
|
index d23fbd1..79d6707 100644
|
||||||
|
--- a/src/xdr_sizeof.c
|
||||||
|
+++ b/src/xdr_sizeof.c
|
||||||
|
@@ -39,6 +39,7 @@
|
||||||
|
#include <rpc/xdr.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
+#include <stdint.h>
|
||||||
|
#include "un-namespace.h"
|
||||||
|
|
||||||
|
/* ARGSUSED */
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
EAPI="5"
|
EAPI="5"
|
||||||
|
|
||||||
inherit multilib-minimal toolchain-funcs eutils
|
inherit autotools multilib-minimal toolchain-funcs eutils
|
||||||
|
|
||||||
DESCRIPTION="Transport Independent RPC library (SunRPC replacement)"
|
DESCRIPTION="Transport Independent RPC library (SunRPC replacement)"
|
||||||
HOMEPAGE="http://libtirpc.sourceforge.net/"
|
HOMEPAGE="http://libtirpc.sourceforge.net/"
|
||||||
@ -12,7 +12,7 @@ SRC_URI="mirror://sourceforge/${PN}/${P}.tar.bz2
|
|||||||
|
|
||||||
LICENSE="GPL-2"
|
LICENSE="GPL-2"
|
||||||
SLOT="0/3" # subslot matches SONAME major
|
SLOT="0/3" # subslot matches SONAME major
|
||||||
KEYWORDS="~alpha amd64 ~arm arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86"
|
KEYWORDS="alpha amd64 arm arm64 hppa ia64 m68k ~mips ppc ppc64 s390 sh sparc x86 ~amd64-linux ~arm-linux ~x86-linux"
|
||||||
IUSE="ipv6 kerberos static-libs"
|
IUSE="ipv6 kerberos static-libs"
|
||||||
|
|
||||||
RDEPEND="kerberos? ( >=virtual/krb5-0-r1[${MULTILIB_USEDEP}] )"
|
RDEPEND="kerberos? ( >=virtual/krb5-0-r1[${MULTILIB_USEDEP}] )"
|
||||||
@ -21,16 +21,17 @@ DEPEND="${RDEPEND}
|
|||||||
>=virtual/pkgconfig-0-r1[${MULTILIB_USEDEP}]"
|
>=virtual/pkgconfig-0-r1[${MULTILIB_USEDEP}]"
|
||||||
|
|
||||||
PATCHES=(
|
PATCHES=(
|
||||||
"${FILESDIR}/${P}-CVE-2017-8779.patch"
|
"${FILESDIR}/${PN}-1.0.2-bcopy-to-memmove.patch"
|
||||||
|
"${FILESDIR}/${PN}-1.0.2-bzero-to-memset.patch"
|
||||||
|
"${FILESDIR}/${PN}-1.0.2-glibc-2.26.patch"
|
||||||
|
"${FILESDIR}/${PN}-1.0.2-exports.patch"
|
||||||
)
|
)
|
||||||
|
|
||||||
src_prepare() {
|
src_prepare() {
|
||||||
cp -r "${WORKDIR}"/tirpc "${S}"/ || die
|
cp -r "${WORKDIR}"/tirpc "${S}"/ || die
|
||||||
epatch "${PATCHES[@]}"
|
epatch "${PATCHES[@]}"
|
||||||
epatch_user
|
epatch_user
|
||||||
|
eautoreconf
|
||||||
# set netconfig path to /usr so nfs works in CoreOS PXE/ISO booted systems.
|
|
||||||
sed -ie "s,/etc,/usr/share/tirpc," "${S}/tirpc/netconfig.h" || die
|
|
||||||
}
|
}
|
||||||
|
|
||||||
multilib_src_configure() {
|
multilib_src_configure() {
|
||||||
@ -51,7 +52,7 @@ multilib_src_install() {
|
|||||||
multilib_src_install_all() {
|
multilib_src_install_all() {
|
||||||
einstalldocs
|
einstalldocs
|
||||||
|
|
||||||
insinto /usr/share/tirpc
|
insinto /etc
|
||||||
doins doc/netconfig
|
doins doc/netconfig
|
||||||
|
|
||||||
insinto /usr/include/tirpc
|
insinto /usr/include/tirpc
|
Loading…
x
Reference in New Issue
Block a user