X-Git-Url: http://git.ozlabs.org/?p=ppp.git;a=blobdiff_plain;f=pppd%2Futils.c;h=935f56272a87e8ea55db72265095d4011e0d5e97;hp=580363a950dec0ee7f77afb1681c60f2880217b3;hb=c062322f9e8757b85a3c2281a3190d8af14bcd9b;hpb=cc593def97b4f6f271fad15805b61c4773c4e30a diff --git a/pppd/utils.c b/pppd/utils.c index 580363a..935f562 100644 --- a/pppd/utils.c +++ b/pppd/utils.c @@ -17,7 +17,7 @@ * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ -#define RCSID "$Id: utils.c,v 1.14 2001/05/23 03:39:14 paulus Exp $" +#define RCSID "$Id: utils.c,v 1.17 2002/01/14 15:31:34 dfs Exp $" #include #include @@ -29,6 +29,7 @@ #include #include #include +#include #include #include #include @@ -790,7 +791,7 @@ dump_packet(const char *tag, unsigned char *p, int len) return; } - dbglog("%s %P", tag, p - PPP_HDRLEN, len + PPP_HDRLEN); + dbglog("%s %P", tag, p, len); } /* Procedures for locking the serial device using a lock file. */ @@ -820,7 +821,7 @@ lock(dev) result = mklock (dev, (void *) 0); if (result == 0) { - strlcpy(lock_file, sizeof(lock_file), dev); + strlcpy(lock_file, dev, sizeof(lock_file)); return 0; } @@ -851,9 +852,20 @@ lock(dev) major(sbuf.st_rdev), minor(sbuf.st_rdev)); #else char *p; + char lockdev[MAXPATHLEN]; + + if ((p = strstr(dev, "dev/")) != NULL) { + dev = p + 4; + strncpy(lockdev, dev, MAXPATHLEN-1); + lockdev[MAXPATHLEN-1] = 0; + while ((p = strrchr(lockdev, '/')) != NULL) { + *p = '_'; + } + dev = lockdev; + } else + if ((p = strrchr(dev, '/')) != NULL) + dev = p + 1; - if ((p = strrchr(dev, '/')) != NULL) - dev = p + 1; slprintf(lock_file, sizeof(lock_file), "%s/LCK..%s", LOCK_DIR, dev); #endif