patches for easier mirroring, to eliminate a special copy, to make www.freebsd.org/security a full copy of security.freebsd.org and be eventually be the same. For now files are just sitting there. The symlinks are missing. Discussed on: www (repository location) Discussed with: simon (so)
		
			
				
	
	
		
			102 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| Index: include/rpc/xdr.h
 | |
| ===================================================================
 | |
| RCS file: /home/ncvs/src/include/rpc/xdr.h,v
 | |
| retrieving revision 1.21
 | |
| diff -u -r1.21 xdr.h
 | |
| --- include/rpc/xdr.h	28 Apr 2002 15:18:45 -0000	1.21
 | |
| +++ include/rpc/xdr.h	20 Mar 2003 01:08:13 -0000
 | |
| @@ -121,7 +121,7 @@
 | |
|  	char *	 	x_public;	/* users' data */
 | |
|  	void *		x_private;	/* pointer to private data */
 | |
|  	char * 		x_base;		/* private used for position info */
 | |
| -	int		x_handy;	/* extra private word */
 | |
| +	u_int		x_handy;	/* extra private word */
 | |
|  } XDR;
 | |
|  
 | |
|  /*
 | |
| Index: lib/libc/xdr/xdr_mem.c
 | |
| ===================================================================
 | |
| RCS file: /home/ncvs/src/lib/libc/xdr/xdr_mem.c,v
 | |
| retrieving revision 1.11
 | |
| diff -u -r1.11 xdr_mem.c
 | |
| --- lib/libc/xdr/xdr_mem.c	22 Mar 2002 21:53:26 -0000	1.11
 | |
| +++ lib/libc/xdr/xdr_mem.c	20 Mar 2003 01:08:13 -0000
 | |
| @@ -126,8 +126,9 @@
 | |
|  	long *lp;
 | |
|  {
 | |
|  
 | |
| -	if ((xdrs->x_handy -= sizeof(int32_t)) < 0)
 | |
| +	if (xdrs->x_handy < sizeof(int32_t))
 | |
|  		return (FALSE);
 | |
| +	xdrs->x_handy -= sizeof(int32_t);
 | |
|  	*lp = ntohl(*(u_int32_t *)xdrs->x_private);
 | |
|  	xdrs->x_private = (char *)xdrs->x_private + sizeof(int32_t);
 | |
|  	return (TRUE);
 | |
| @@ -139,8 +140,9 @@
 | |
|  	const long *lp;
 | |
|  {
 | |
|  
 | |
| -	if ((xdrs->x_handy -= sizeof(int32_t)) < 0)
 | |
| +	if (xdrs->x_handy < sizeof(int32_t))
 | |
|  		return (FALSE);
 | |
| +	xdrs->x_handy -= sizeof(int32_t);
 | |
|  	*(u_int32_t *)xdrs->x_private = htonl((u_int32_t)*lp);
 | |
|  	xdrs->x_private = (char *)xdrs->x_private + sizeof(int32_t);
 | |
|  	return (TRUE);
 | |
| @@ -153,8 +155,9 @@
 | |
|  {
 | |
|  	u_int32_t l;
 | |
|  
 | |
| -	if ((xdrs->x_handy -= sizeof(int32_t)) < 0)
 | |
| +	if (xdrs->x_handy < sizeof(int32_t))
 | |
|  		return (FALSE);
 | |
| +	xdrs->x_handy -= sizeof(int32_t);
 | |
|  	memmove(&l, xdrs->x_private, sizeof(int32_t));
 | |
|  	*lp = ntohl(l);
 | |
|  	xdrs->x_private = (char *)xdrs->x_private + sizeof(int32_t);
 | |
| @@ -168,8 +171,9 @@
 | |
|  {
 | |
|  	u_int32_t l;
 | |
|  
 | |
| -	if ((xdrs->x_handy -= sizeof(int32_t)) < 0)
 | |
| +	if (xdrs->x_handy < sizeof(int32_t))
 | |
|  		return (FALSE);
 | |
| +	xdrs->x_handy -= sizeof(int32_t);
 | |
|  	l = htonl((u_int32_t)*lp);
 | |
|  	memmove(xdrs->x_private, &l, sizeof(int32_t));
 | |
|  	xdrs->x_private = (char *)xdrs->x_private + sizeof(int32_t);
 | |
| @@ -183,8 +187,9 @@
 | |
|  	u_int len;
 | |
|  {
 | |
|  
 | |
| -	if ((xdrs->x_handy -= len) < 0)
 | |
| +	if (xdrs->x_handy < len)
 | |
|  		return (FALSE);
 | |
| +	xdrs->x_handy -= len;
 | |
|  	memmove(addr, xdrs->x_private, len);
 | |
|  	xdrs->x_private = (char *)xdrs->x_private + len;
 | |
|  	return (TRUE);
 | |
| @@ -197,8 +202,9 @@
 | |
|  	u_int len;
 | |
|  {
 | |
|  
 | |
| -	if ((xdrs->x_handy -= len) < 0)
 | |
| +	if (xdrs->x_handy < len)
 | |
|  		return (FALSE);
 | |
| +	xdrs->x_handy -= len;
 | |
|  	memmove(xdrs->x_private, addr, len);
 | |
|  	xdrs->x_private = (char *)xdrs->x_private + len;
 | |
|  	return (TRUE);
 | |
| @@ -221,10 +227,10 @@
 | |
|  	char *newaddr = xdrs->x_base + pos;
 | |
|  	char *lastaddr = (char *)xdrs->x_private + xdrs->x_handy;
 | |
|  
 | |
| -	if ((long)newaddr > (long)lastaddr)
 | |
| +	if (newaddr > lastaddr)
 | |
|  		return (FALSE);
 | |
|  	xdrs->x_private = newaddr;
 | |
| -	xdrs->x_handy = (int)((long)lastaddr - (long)newaddr);
 | |
| +	xdrs->x_handy = (u_int)(lastaddr - newaddr); /* XXX sizeof(u_int) <? sizeof(ptrdiff_t) */
 | |
|  	return (TRUE);
 | |
|  }
 | |
|  
 |