forked from dlink-dir_819/openwrt
		
	Release notes:
new features:
- large dns record lookups via tcp fallback
- new getaddrinfo EAI_NODATA result to distinguish NODATA/NxDomain
- support for new RELR compressed format for relative relocations
- sysconf keys for querying signal stack size requirements
- real vfork on riscv64
performance:
- mallocng no longer uses MADV_FREE (high performance cost, little gain)
- vdso clock_gettime is supported once again on 32-bit arm
compatibility:
- gethostbyname family now distinguishes NO_DATA from HOST_NOT_FOUND
- res_send now works with caller-provided edns0 queries
- arpa/nameser.h RR types list is now up-to-date
- previously-missing POSIX confstr keys have been added
- mntent interfaces now accept missing fields
- alt signal stack, if any, is now used for internal signals
- the LFS64 macros are no longer exposed without _LARGEFILE64_SOURCE
- memmem (POSIX-future) is now exposed in default feature profile
- pthread_atfork now admits calls from an application-provided malloc
- debugger tracking of shared libraries now works on MIPS PIE binaries
- sendmsg now supports up to SCM_MAX_FD fds in SCM_RIGHTS messages
bugs fixed:
- gethostbyname[2]_r wrongly returned nonzero (error) on negative result
- parallel v4/v6 address queries could fail on query id collisions
- spurious getaddrinfo/AI_ADDRCONFIG failures due to errno clobbering
- dns search domains ending in dot (including lone dot) broke lookups
- ipv6 servers in resolv.conf broke lookups on systems with v6 disabled
- systems with bindv6only failed to query both v4 and v6 nameservers
- res_mkquery mishandled consecutive final dots in name
- res_send could malfunction for very small answer buffer sizes
- resolver dns backend accepted answers with wrong (A vs AAAA) RR type
- getservbyport_r returned junk or ENOENT (vs ERANGE) on buffer size errors
- dns result parsing of malformed responses could process uninitialized data
- freopen didn't reset stream orientation (byte/wide) & encoding rule
- fwprintf didn't print most fields on open_wmemstream FILEs
- wide printf %lc ignored field width
- wide printf erroneously processed %n after encoding errors
- use of wide printf %9$ argument slot overflowed undersized buffer
- swprintf malfunctioned on nul character in output
- strverscmp ordered digit sequences vs nondigits incorrectly
- timer_create/SIGEV_THREAD failure leaked the thread
- semaphores were subject to missed-wake under certain usage patterns
- several possible rare deadlocks with lock handling at thread exit
- several possible rare deadlocks with aio and multithreaded fork
- dynamic linker relro processing was broken on archs w/variable pagesize
- async cancellation could run cancellation handlers in invalid context
- pthread_detach was wrongly a cancellation point in rare race code path
- use-after-close/double-close errors in mq_notify error paths
- mq_notify event thread wrongly ran with signals unmasked
- wcs{,n}cmp, wmemcmp returned wrong results when difference overflowed
- accept4, pipe2, and dup3 handled unknown flags wrong in fallback cases
- CPU_SETSIZE macro had wrong unit
- select fallback for pre-time64 kernels truncated timeout (vs clamping)
arch-specific bugs fixed:
- x32 new socketcalls took fallback path due to pointer sign extension
- x32 wait4 didn't fill rusage structure (time64 regression)
- x32 semtimedop mismatched timespec ABI with kernel (time64 regression)
- sigaction signal mask was bogus on or1k, microblaze, mips, and riscv
- powerpc-sf longjmp asm clobbered value argument
- or1k poll function passed timeout to syscall in wrong form
Removed upstreamed:
- 800-mips_pie_debug.patch
Manually rebased:
- 600-nftw-support-common-gnu-extension.patch
Signed-off-by: Linhui Liu <liulinhui36@gmail.com>
		
	
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 6f1143425a3afc4eb5086e9c90e7efb3affd7cb7 Mon Sep 17 00:00:00 2001
 | |
| From: Tony Ambardar <Tony.Ambardar@gmail.com>
 | |
| Date: Sat, 11 Jul 2020 06:35:46 -0700
 | |
| Subject: [PATCH 2/2] nftw: support common gnu extension
 | |
| 
 | |
| Signed-off-by: Tony Ambardar <Tony.Ambardar@gmail.com>
 | |
| ---
 | |
|  include/ftw.h   |  8 ++++++++
 | |
|  src/misc/nftw.c | 35 ++++++++++++++++++++++++++++++-----
 | |
|  2 files changed, 38 insertions(+), 5 deletions(-)
 | |
| 
 | |
| --- a/include/ftw.h
 | |
| +++ b/include/ftw.h
 | |
| @@ -21,6 +21,14 @@ extern "C" {
 | |
|  #define FTW_CHDIR 4
 | |
|  #define FTW_DEPTH 8
 | |
|  
 | |
| +#ifdef _GNU_SOURCE
 | |
| +#define FTW_ACTIONRETVAL 16
 | |
| +#define FTW_CONTINUE 0
 | |
| +#define FTW_STOP 1
 | |
| +#define FTW_SKIP_SUBTREE 2
 | |
| +#define FTW_SKIP_SIBLINGS 3
 | |
| +#endif
 | |
| +
 | |
|  struct FTW {
 | |
|  	int base;
 | |
|  	int level;
 | |
| --- a/src/misc/nftw.c
 | |
| +++ b/src/misc/nftw.c
 | |
| @@ -1,3 +1,4 @@
 | |
| +#define _GNU_SOURCE
 | |
|  #include <ftw.h>
 | |
|  #include <dirent.h>
 | |
|  #include <fcntl.h>
 | |
| @@ -74,8 +75,20 @@ static int do_nftw(char *path, int (*fn)
 | |
|  		if (!fd_limit) close(dfd);
 | |
|  	}
 | |
|  
 | |
| -	if (!(flags & FTW_DEPTH) && (r=fn(path, &st, type, &lev)))
 | |
| -		return r;
 | |
| +	if (!(flags & FTW_DEPTH) && (r=fn(path, &st, type, &lev))) {
 | |
| +		if (flags & FTW_ACTIONRETVAL)
 | |
| +			switch (r) {
 | |
| +			case FTW_SKIP_SUBTREE:
 | |
| +				h = NULL;
 | |
| +			case FTW_CONTINUE:
 | |
| +				break;
 | |
| +			case FTW_SKIP_SIBLINGS:
 | |
| +			case FTW_STOP:
 | |
| +				return r;
 | |
| +			}
 | |
| +		else
 | |
| +			return r;
 | |
| +	}
 | |
|  
 | |
|  	for (; h; h = h->chain)
 | |
|  		if (h->dev == st.st_dev && h->ino == st.st_ino)
 | |
| @@ -103,7 +116,10 @@ static int do_nftw(char *path, int (*fn)
 | |
|  				strcpy(path+j+1, de->d_name);
 | |
|  				if ((r=do_nftw(path, fn, fd_limit-1, flags, &new))) {
 | |
|  					closedir(d);
 | |
| -					return r;
 | |
| +					if ((flags & FTW_ACTIONRETVAL) && r == FTW_SKIP_SIBLINGS)
 | |
| +						break;
 | |
| +					else
 | |
| +						return r;
 | |
|  				}
 | |
|  			}
 | |
|  			closedir(d);
 | |
| @@ -114,8 +130,16 @@ static int do_nftw(char *path, int (*fn)
 | |
|  	}
 | |
|  
 | |
|  	path[l] = 0;
 | |
| -	if ((flags & FTW_DEPTH) && (r=fn(path, &st, type, &lev)))
 | |
| -		return r;
 | |
| +	if ((flags & FTW_DEPTH) && (r=fn(path, &st, type, &lev))) {
 | |
| +		if (flags & FTW_ACTIONRETVAL)
 | |
| +			switch (r) {
 | |
| +				case FTW_SKIP_SIBLINGS:
 | |
| +				case FTW_STOP:
 | |
| +					return r;
 | |
| +			}
 | |
| +		else
 | |
| +			return r;
 | |
| +	}
 | |
|  
 | |
|  	return 0;
 | |
|  }
 | |
| @@ -140,3 +164,5 @@ int nftw(const char *path, int (*fn)(con
 | |
|  	pthread_setcancelstate(cs, 0);
 | |
|  	return r;
 | |
|  }
 | |
| +
 | |
| +#undef nftw64
 |