svn commit: r196575 - stable/8/usr.sbin/ppp
Brian Somers
brian at FreeBSD.org
Thu Aug 27 07:05:46 UTC 2009
Author: brian
Date: Thu Aug 27 07:05:46 2009
New Revision: 196575
URL: http://svn.freebsd.org/changeset/base/196575
Log:
MFC: When realloc()ing device memory for transfer to another ppp process,
don't continue to use the realloc()d pointer - it might have changed!
Remove some stray diagnostics while I'm here.
Approved by: re (kib)
Modified:
stable/8/usr.sbin/ppp/ (props changed)
stable/8/usr.sbin/ppp/ether.c
stable/8/usr.sbin/ppp/netgraph.c
stable/8/usr.sbin/ppp/tty.c
Modified: stable/8/usr.sbin/ppp/ether.c
==============================================================================
--- stable/8/usr.sbin/ppp/ether.c Thu Aug 27 00:45:00 2009 (r196574)
+++ stable/8/usr.sbin/ppp/ether.c Thu Aug 27 07:05:46 2009 (r196575)
@@ -193,17 +193,18 @@ static void
ether_device2iov(struct device *d, struct iovec *iov, int *niov,
int maxiov __unused, int *auxfd, int *nauxfd)
{
- struct etherdevice *dev = device2ether(d);
+ struct etherdevice *dev;
int sz = physical_MaxDeviceSize();
- iov[*niov].iov_base = realloc(d, sz);
- if (iov[*niov].iov_base == NULL) {
+ iov[*niov].iov_base = d = realloc(d, sz);
+ if (d == NULL) {
log_Printf(LogALERT, "Failed to allocate memory: %d\n", sz);
AbortProgram(EX_OSERR);
}
iov[*niov].iov_len = sz;
(*niov)++;
+ dev = device2ether(d);
if (dev->cs >= 0) {
*auxfd = dev->cs;
(*nauxfd)++;
Modified: stable/8/usr.sbin/ppp/netgraph.c
==============================================================================
--- stable/8/usr.sbin/ppp/netgraph.c Thu Aug 27 00:45:00 2009 (r196574)
+++ stable/8/usr.sbin/ppp/netgraph.c Thu Aug 27 07:05:46 2009 (r196575)
@@ -235,7 +235,6 @@ ng_Read(struct physical *p, void *v, siz
{
char hook[NG_HOOKSIZ];
-log_Printf(LogDEBUG, "ng_Read\n");
switch (p->dl->state) {
case DATALINK_DIAL:
case DATALINK_LOGIN:
@@ -282,17 +281,18 @@ static void
ng_device2iov(struct device *d, struct iovec *iov, int *niov,
int maxiov __unused, int *auxfd, int *nauxfd)
{
- struct ngdevice *dev = device2ng(d);
+ struct ngdevice *dev;
int sz = physical_MaxDeviceSize();
- iov[*niov].iov_base = realloc(d, sz);
- if (iov[*niov].iov_base == NULL) {
+ iov[*niov].iov_base = d = realloc(d, sz);
+ if (d == NULL) {
log_Printf(LogALERT, "Failed to allocate memory: %d\n", sz);
AbortProgram(EX_OSERR);
}
iov[*niov].iov_len = sz;
(*niov)++;
+ dev = device2ng(d);
*auxfd = dev->cs;
(*nauxfd)++;
}
Modified: stable/8/usr.sbin/ppp/tty.c
==============================================================================
--- stable/8/usr.sbin/ppp/tty.c Thu Aug 27 00:45:00 2009 (r196574)
+++ stable/8/usr.sbin/ppp/tty.c Thu Aug 27 07:05:46 2009 (r196575)
@@ -384,7 +384,6 @@ UnloadLineDiscipline(struct physical *p)
struct ttydevice *dev = device2tty(p->handler);
if (isngtty(dev)) {
-log_Printf(LogPHASE, "back to speed %d\n", dev->real.speed);
if (!physical_SetSpeed(p, dev->real.speed))
log_Printf(LogWARN, "Couldn't reset tty speed to %d\n", dev->real.speed);
dev->real.speed = 0;
@@ -582,17 +581,19 @@ tty_device2iov(struct device *d, struct
#endif
)
{
- struct ttydevice *dev = device2tty(d);
+ struct ttydevice *dev;
int sz = physical_MaxDeviceSize();
- iov[*niov].iov_base = realloc(d, sz);
- if (iov[*niov].iov_base == NULL) {
+ iov[*niov].iov_base = d = realloc(d, sz);
+ if (d == NULL) {
log_Printf(LogALERT, "Failed to allocate memory: %d\n", sz);
AbortProgram(EX_OSERR);
}
iov[*niov].iov_len = sz;
(*niov)++;
+ dev = device2tty(d);
+
#ifndef NONETGRAPH
if (dev->cs >= 0) {
*auxfd = dev->cs;
More information about the svn-src-stable
mailing list