Fix ptsname_r(3) return type to match glibc
The gHardy man pages specify the return type of ptsname_r to be char*, but the return value to be 0 on success, negative on error and the gHardy stdlib.h defines extern int ptsname_r(...). Busybox telnetd fails to run successfully without this change.
This commit is contained in:
parent
0b5db51ea6
commit
6458c49c96
@ -132,7 +132,7 @@ static __inline__ void srandom(unsigned int __s)
|
|||||||
|
|
||||||
extern int unlockpt(int);
|
extern int unlockpt(int);
|
||||||
extern char* ptsname(int);
|
extern char* ptsname(int);
|
||||||
extern char* ptsname_r(int, char*, size_t);
|
extern int ptsname_r(int, char*, size_t);
|
||||||
extern int getpt(void);
|
extern int getpt(void);
|
||||||
|
|
||||||
static __inline__ int grantpt(int __fd)
|
static __inline__ int grantpt(int __fd)
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
char* ptsname_r( int fd, char* buf, size_t buflen)
|
int ptsname_r( int fd, char* buf, size_t buflen)
|
||||||
{
|
{
|
||||||
unsigned int pty_num;
|
unsigned int pty_num;
|
||||||
char buff[64];
|
char buff[64];
|
||||||
@ -40,17 +40,19 @@ char* ptsname_r( int fd, char* buf, size_t buflen)
|
|||||||
|
|
||||||
if (buf == NULL) {
|
if (buf == NULL) {
|
||||||
errno = EINVAL;
|
errno = EINVAL;
|
||||||
return NULL;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( ioctl( fd, TIOCGPTN, &pty_num ) != 0 )
|
if ( ioctl( fd, TIOCGPTN, &pty_num ) != 0 ) {
|
||||||
return NULL;
|
errno = ENOTTY;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
len = snprintf( buff, sizeof(buff), "/dev/pts/%u", pty_num );
|
len = snprintf( buff, sizeof(buff), "/dev/pts/%u", pty_num );
|
||||||
if (len+1 > (int)buflen) {
|
if (len+1 > (int)buflen) {
|
||||||
errno = ERANGE;
|
errno = ERANGE;
|
||||||
return NULL;
|
return -1;
|
||||||
}
|
}
|
||||||
memcpy( buf, buff, len+1 );
|
memcpy( buf, buff, len+1 );
|
||||||
return buf;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user