mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-20 15:43:16 +00:00
Fix a minor security problem in libc_r.
Submitted by: Alexandre Snarskii <snar@paranoia.ru> Approved by: John Birrell Reminded me that I'd been sitting on this too long: snar@paranoia.ru
This commit is contained in:
parent
dcda29feba
commit
d0c4729014
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=42500
@ -36,6 +36,7 @@
|
||||
#include <unistd.h>
|
||||
#ifdef _THREAD_SAFE
|
||||
#include <pthread.h>
|
||||
#include <errno.h>
|
||||
#include "pthread_private.h"
|
||||
|
||||
struct s_thread_info {
|
||||
@ -73,11 +74,31 @@ _thread_dump_info(void)
|
||||
int i;
|
||||
int j;
|
||||
pthread_t pthread;
|
||||
char tmpfile[128];
|
||||
|
||||
/* Open the dump file for append and create it if necessary: */
|
||||
if ((fd = _thread_sys_open("/tmp/uthread.dump",
|
||||
O_RDWR | O_CREAT | O_APPEND, 0666)) < 0) {
|
||||
/* Can't open the dump file. */
|
||||
for (i = 0; i < 100000; i++) {
|
||||
snprintf(tmpfile, sizeof(tmpfile), "/tmp/uthread.dump.%u.%i",
|
||||
getpid(), i);
|
||||
/* Open the dump file for append and create it if necessary: */
|
||||
if ((fd = _thread_sys_open(tmpfile, O_RDWR | O_CREAT | O_EXCL,
|
||||
0666)) < 0) {
|
||||
/* Can't open the dump file. */
|
||||
if (errno == EEXIST)
|
||||
continue;
|
||||
/*
|
||||
* We only need to continue in case of
|
||||
* EEXIT error. Most other error
|
||||
* codes means that we will fail all
|
||||
* the times.
|
||||
*/
|
||||
return;
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (i==100000) {
|
||||
/* all 100000 possibilities are in use :( */
|
||||
return;
|
||||
} else {
|
||||
/* Output a header for active threads: */
|
||||
strcpy(s, "\n\n=============\nACTIVE THREADS\n\n");
|
||||
|
@ -36,6 +36,7 @@
|
||||
#include <unistd.h>
|
||||
#ifdef _THREAD_SAFE
|
||||
#include <pthread.h>
|
||||
#include <errno.h>
|
||||
#include "pthread_private.h"
|
||||
|
||||
struct s_thread_info {
|
||||
@ -73,11 +74,31 @@ _thread_dump_info(void)
|
||||
int i;
|
||||
int j;
|
||||
pthread_t pthread;
|
||||
char tmpfile[128];
|
||||
|
||||
/* Open the dump file for append and create it if necessary: */
|
||||
if ((fd = _thread_sys_open("/tmp/uthread.dump",
|
||||
O_RDWR | O_CREAT | O_APPEND, 0666)) < 0) {
|
||||
/* Can't open the dump file. */
|
||||
for (i = 0; i < 100000; i++) {
|
||||
snprintf(tmpfile, sizeof(tmpfile), "/tmp/uthread.dump.%u.%i",
|
||||
getpid(), i);
|
||||
/* Open the dump file for append and create it if necessary: */
|
||||
if ((fd = _thread_sys_open(tmpfile, O_RDWR | O_CREAT | O_EXCL,
|
||||
0666)) < 0) {
|
||||
/* Can't open the dump file. */
|
||||
if (errno == EEXIST)
|
||||
continue;
|
||||
/*
|
||||
* We only need to continue in case of
|
||||
* EEXIT error. Most other error
|
||||
* codes means that we will fail all
|
||||
* the times.
|
||||
*/
|
||||
return;
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (i==100000) {
|
||||
/* all 100000 possibilities are in use :( */
|
||||
return;
|
||||
} else {
|
||||
/* Output a header for active threads: */
|
||||
strcpy(s, "\n\n=============\nACTIVE THREADS\n\n");
|
||||
|
@ -36,6 +36,7 @@
|
||||
#include <unistd.h>
|
||||
#ifdef _THREAD_SAFE
|
||||
#include <pthread.h>
|
||||
#include <errno.h>
|
||||
#include "pthread_private.h"
|
||||
|
||||
struct s_thread_info {
|
||||
@ -73,11 +74,31 @@ _thread_dump_info(void)
|
||||
int i;
|
||||
int j;
|
||||
pthread_t pthread;
|
||||
char tmpfile[128];
|
||||
|
||||
/* Open the dump file for append and create it if necessary: */
|
||||
if ((fd = _thread_sys_open("/tmp/uthread.dump",
|
||||
O_RDWR | O_CREAT | O_APPEND, 0666)) < 0) {
|
||||
/* Can't open the dump file. */
|
||||
for (i = 0; i < 100000; i++) {
|
||||
snprintf(tmpfile, sizeof(tmpfile), "/tmp/uthread.dump.%u.%i",
|
||||
getpid(), i);
|
||||
/* Open the dump file for append and create it if necessary: */
|
||||
if ((fd = _thread_sys_open(tmpfile, O_RDWR | O_CREAT | O_EXCL,
|
||||
0666)) < 0) {
|
||||
/* Can't open the dump file. */
|
||||
if (errno == EEXIST)
|
||||
continue;
|
||||
/*
|
||||
* We only need to continue in case of
|
||||
* EEXIT error. Most other error
|
||||
* codes means that we will fail all
|
||||
* the times.
|
||||
*/
|
||||
return;
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (i==100000) {
|
||||
/* all 100000 possibilities are in use :( */
|
||||
return;
|
||||
} else {
|
||||
/* Output a header for active threads: */
|
||||
strcpy(s, "\n\n=============\nACTIVE THREADS\n\n");
|
||||
|
Loading…
Reference in New Issue
Block a user