mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-17 15:27:36 +00:00
Fix a bum pointer dereference and make some variable
names more consistent. Stack trace supplied by: Joe Clarke <jclarke@cisco.com>
This commit is contained in:
parent
ac37ab22eb
commit
8dbb1e2bfd
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=47120
@ -23,7 +23,7 @@
|
|||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* $Id: tty.c,v 1.1 1999/05/08 11:07:50 brian Exp $
|
* $Id: tty.c,v 1.2 1999/05/12 09:49:07 brian Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
@ -154,51 +154,53 @@ tty_Unlock(struct physical *p)
|
|||||||
log_Printf(LogALERT, "%s: Can't uu_unlock %s\n", p->link.name, fn);
|
log_Printf(LogALERT, "%s: Can't uu_unlock %s\n", p->link.name, fn);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static struct device *
|
||||||
tty_SetupDevice(struct physical *p)
|
tty_SetupDevice(struct physical *p)
|
||||||
{
|
{
|
||||||
struct ttydevice *dev = device2tty(p->handler);
|
struct ttydevice *dev;
|
||||||
struct termios rstio;
|
struct termios ios;
|
||||||
int oldflag;
|
int oldflag;
|
||||||
|
|
||||||
tcgetattr(p->fd, &rstio);
|
if ((dev = malloc(sizeof *dev)) == NULL)
|
||||||
dev->ios = rstio;
|
return NULL;
|
||||||
|
|
||||||
|
tcgetattr(p->fd, &ios);
|
||||||
|
dev->ios = ios;
|
||||||
|
|
||||||
log_Printf(LogDEBUG, "%s: tty_SetupDevice: physical (get): fd = %d,"
|
log_Printf(LogDEBUG, "%s: tty_SetupDevice: physical (get): fd = %d,"
|
||||||
" iflag = %lx, oflag = %lx, cflag = %lx\n", p->link.name, p->fd,
|
" iflag = %lx, oflag = %lx, cflag = %lx\n", p->link.name, p->fd,
|
||||||
(u_long)rstio.c_iflag, (u_long)rstio.c_oflag,
|
(u_long)ios.c_iflag, (u_long)ios.c_oflag, (u_long)ios.c_cflag);
|
||||||
(u_long)rstio.c_cflag);
|
|
||||||
|
|
||||||
cfmakeraw(&rstio);
|
cfmakeraw(&ios);
|
||||||
if (p->cfg.rts_cts)
|
if (p->cfg.rts_cts)
|
||||||
rstio.c_cflag |= CLOCAL | CCTS_OFLOW | CRTS_IFLOW;
|
ios.c_cflag |= CLOCAL | CCTS_OFLOW | CRTS_IFLOW;
|
||||||
else {
|
else {
|
||||||
rstio.c_cflag |= CLOCAL;
|
ios.c_cflag |= CLOCAL;
|
||||||
rstio.c_iflag |= IXOFF;
|
ios.c_iflag |= IXOFF;
|
||||||
}
|
}
|
||||||
rstio.c_iflag |= IXON;
|
ios.c_iflag |= IXON;
|
||||||
if (p->type != PHYS_DEDICATED)
|
if (p->type != PHYS_DEDICATED)
|
||||||
rstio.c_cflag |= HUPCL;
|
ios.c_cflag |= HUPCL;
|
||||||
|
|
||||||
if (p->type != PHYS_DIRECT) {
|
if (p->type != PHYS_DIRECT) {
|
||||||
/* Change tty speed when we're not in -direct mode */
|
/* Change tty speed when we're not in -direct mode */
|
||||||
rstio.c_cflag &= ~(CSIZE | PARODD | PARENB);
|
ios.c_cflag &= ~(CSIZE | PARODD | PARENB);
|
||||||
rstio.c_cflag |= p->cfg.parity;
|
ios.c_cflag |= p->cfg.parity;
|
||||||
if (cfsetspeed(&rstio, IntToSpeed(p->cfg.speed)) == -1)
|
if (cfsetspeed(&ios, IntToSpeed(p->cfg.speed)) == -1)
|
||||||
log_Printf(LogWARN, "%s: %s: Unable to set speed to %d\n",
|
log_Printf(LogWARN, "%s: %s: Unable to set speed to %d\n",
|
||||||
p->link.name, p->name.full, p->cfg.speed);
|
p->link.name, p->name.full, p->cfg.speed);
|
||||||
}
|
}
|
||||||
tcsetattr(p->fd, TCSADRAIN, &rstio);
|
tcsetattr(p->fd, TCSADRAIN, &ios);
|
||||||
log_Printf(LogDEBUG, "%s: physical (put): iflag = %lx, oflag = %lx, "
|
log_Printf(LogDEBUG, "%s: physical (put): iflag = %lx, oflag = %lx, "
|
||||||
"cflag = %lx\n", p->link.name, (u_long)rstio.c_iflag,
|
"cflag = %lx\n", p->link.name, (u_long)ios.c_iflag,
|
||||||
(u_long)rstio.c_oflag, (u_long)rstio.c_cflag);
|
(u_long)ios.c_oflag, (u_long)ios.c_cflag);
|
||||||
|
|
||||||
if (ioctl(p->fd, TIOCMGET, &dev->mbits) == -1) {
|
if (ioctl(p->fd, TIOCMGET, &dev->mbits) == -1) {
|
||||||
if (p->type != PHYS_DIRECT) {
|
if (p->type != PHYS_DIRECT) {
|
||||||
log_Printf(LogWARN, "%s: Open: Cannot get physical status: %s\n",
|
log_Printf(LogWARN, "%s: Open: Cannot get physical status: %s\n",
|
||||||
p->link.name, strerror(errno));
|
p->link.name, strerror(errno));
|
||||||
physical_Close(p);
|
physical_Close(p);
|
||||||
return;
|
return NULL;
|
||||||
} else
|
} else
|
||||||
dev->mbits = TIOCM_CD;
|
dev->mbits = TIOCM_CD;
|
||||||
}
|
}
|
||||||
@ -210,11 +212,13 @@ tty_SetupDevice(struct physical *p)
|
|||||||
log_Printf(LogWARN, "%s: Open: Cannot get physical flags: %s\n",
|
log_Printf(LogWARN, "%s: Open: Cannot get physical flags: %s\n",
|
||||||
p->link.name, strerror(errno));
|
p->link.name, strerror(errno));
|
||||||
physical_Close(p);
|
physical_Close(p);
|
||||||
return;
|
return NULL;
|
||||||
} else
|
} else
|
||||||
fcntl(p->fd, F_SETFL, oldflag & ~O_NONBLOCK);
|
fcntl(p->fd, F_SETFL, oldflag & ~O_NONBLOCK);
|
||||||
|
|
||||||
physical_SetupStack(p, PHYSICAL_NOFORCE);
|
physical_SetupStack(p, PHYSICAL_NOFORCE);
|
||||||
|
|
||||||
|
return &dev->dev;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -295,7 +299,7 @@ static int
|
|||||||
tty_Raw(struct physical *p)
|
tty_Raw(struct physical *p)
|
||||||
{
|
{
|
||||||
struct ttydevice *dev = device2tty(p->handler);
|
struct ttydevice *dev = device2tty(p->handler);
|
||||||
struct termios rstio;
|
struct termios ios;
|
||||||
int oldflag;
|
int oldflag;
|
||||||
|
|
||||||
if (physical_IsSync(p))
|
if (physical_IsSync(p))
|
||||||
@ -307,17 +311,17 @@ tty_Raw(struct physical *p)
|
|||||||
log_Printf(LogDEBUG, "%s: Raw: descriptor = %d, mbits = %x\n",
|
log_Printf(LogDEBUG, "%s: Raw: descriptor = %d, mbits = %x\n",
|
||||||
p->link.name, p->fd, dev->mbits);
|
p->link.name, p->fd, dev->mbits);
|
||||||
|
|
||||||
tcgetattr(p->fd, &rstio);
|
tcgetattr(p->fd, &ios);
|
||||||
cfmakeraw(&rstio);
|
cfmakeraw(&ios);
|
||||||
if (p->cfg.rts_cts)
|
if (p->cfg.rts_cts)
|
||||||
rstio.c_cflag |= CLOCAL | CCTS_OFLOW | CRTS_IFLOW;
|
ios.c_cflag |= CLOCAL | CCTS_OFLOW | CRTS_IFLOW;
|
||||||
else
|
else
|
||||||
rstio.c_cflag |= CLOCAL;
|
ios.c_cflag |= CLOCAL;
|
||||||
|
|
||||||
if (p->type != PHYS_DEDICATED)
|
if (p->type != PHYS_DEDICATED)
|
||||||
rstio.c_cflag |= HUPCL;
|
ios.c_cflag |= HUPCL;
|
||||||
|
|
||||||
tcsetattr(p->fd, TCSANOW, &rstio);
|
tcsetattr(p->fd, TCSANOW, &ios);
|
||||||
|
|
||||||
oldflag = fcntl(p->fd, F_GETFL, 0);
|
oldflag = fcntl(p->fd, F_GETFL, 0);
|
||||||
if (oldflag < 0)
|
if (oldflag < 0)
|
||||||
@ -386,12 +390,12 @@ tty_Free(struct physical *p)
|
|||||||
static int
|
static int
|
||||||
tty_Speed(struct physical *p)
|
tty_Speed(struct physical *p)
|
||||||
{
|
{
|
||||||
struct termios rstio;
|
struct termios ios;
|
||||||
|
|
||||||
if (tcgetattr(p->fd, &rstio) == -1)
|
if (tcgetattr(p->fd, &ios) == -1)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return SpeedToInt(cfgetispeed(&rstio));
|
return SpeedToInt(cfgetispeed(&ios));
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
@ -473,22 +477,11 @@ tty_Create(struct physical *p)
|
|||||||
if (tty_Lock(p, p->dl->bundle->unit) == -1) {
|
if (tty_Lock(p, p->dl->bundle->unit) == -1) {
|
||||||
close(p->fd);
|
close(p->fd);
|
||||||
p->fd = -1;
|
p->fd = -1;
|
||||||
} else {
|
} else
|
||||||
struct ttydevice *dev = malloc(sizeof *dev);
|
return tty_SetupDevice(p);
|
||||||
|
|
||||||
if (dev != NULL)
|
|
||||||
tty_SetupDevice(p);
|
|
||||||
|
|
||||||
return &dev->dev;
|
|
||||||
}
|
|
||||||
} else if (tty_Lock(p, p->dl->bundle->unit) != -1) {
|
} else if (tty_Lock(p, p->dl->bundle->unit) != -1) {
|
||||||
struct ttydevice *dev = malloc(sizeof *dev);
|
|
||||||
log_Printf(LogDEBUG, "%s: Opened %s\n", p->link.name, p->name.full);
|
log_Printf(LogDEBUG, "%s: Opened %s\n", p->link.name, p->name.full);
|
||||||
|
return tty_SetupDevice(p);
|
||||||
if (dev != NULL)
|
|
||||||
tty_SetupDevice(p);
|
|
||||||
|
|
||||||
return &dev->dev;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user